logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:install:refind-boot-uefi [14/08/2013 15:37]
mytux [Installation]
doc:install:refind-boot-uefi [18/08/2013 19:05]
mytux [Structures de disques EFI]
Ligne 7: Ligne 7:
  
  
-====== UEFI & EFI ( EN chantier )======+====== UEFI & EFI======
  
 Toutes les versions 64bits des PC qui exécutent Windows certifié par le programme de certification Windows utilisent l’UEFI à la place du BIOS. Toutes les versions 64bits des PC qui exécutent Windows certifié par le programme de certification Windows utilisent l’UEFI à la place du BIOS.
Ligne 17: Ligne 17:
   * Suivi : {{tag>​en-chantier à-tester à-placer}}   * Suivi : {{tag>​en-chantier à-tester à-placer}}
    
-===== EFI & UEFI =====   ​+=====Le BIOS=====
  
 +A l'aube de l'ère du premier PC en 1981, [[wp>​IBM]] livrait son [[wp>​Personal Computer]] 5150, avec un [[wp>​firmware]] connu sous le nom de [[wp>​BIOS]] (Basic Input/​Output System ). Le BIOS était destiné à être une interface entre le matériel ​ et le système d'​exploitation [[wp>​DOS]] (Disk Operating System) à l'​époque.
  
-A l'aube de l'ère du PC en 1981, IBM a livré son Personal Computer 5150 un firmware connu sous le nom de  Basic Input/​Output System (BIOS). +Le rôle du BIOS était d'éffectuer des tests de base et d'appliquer une séquence linéaire de recherche afin de trouver un périphérique amorçable sur un secteur ​de 512 octets pouvantt ​être lus et éxécuté. Ce premier secteur qu'on appella MBR devait ensuite passer la main à un autre périphérique ou au système d'​exploitation.
-Le BIOS était destiné à être une interface entre plusieurs périphériques ​et le Disk Operating System (DOS).+
  
-Au fil des ans,  le BIOS a été de moins en moins utilisé, car il était ​ ecrit   sur 16 bits, les systèmes d'​exploitation ont évolué ​sur 32 bits et, maintenant, en 64-bit. Les OS avancés n'ont puent continuer à utiliser le Bios sans pertes de performance.+Le bios est généralement écrit en assembleur et est seulement capable d'​éxécuté ​des instructions ​sur 16 bits alors que les OS modernes euxéxécutent des instructions ​sur 32 et 64bits. Les OS avancés n'ont puent continuer à utiliser le Bios sans pertes de performance. ​ 
 +=====EFI et UEFI=====
  
-Aujourd'hui, donc, le rôle principal du BIOS est de commencer le processus de démarrageUne fois que le système est démarré, le BIOS n’a plus d’intérêt. Pourtant, le démarrage de l'ordinateur est une tâche importante, et la vieille conception ​ du BIOS créé est limitée+J'utilise ​le terme EFI pour se référer soit à EFI 1.X et l'UEFI.
  
-=====EFI et UEFI=====+L'EFI (Extensible Firmware Interface) ​et sa variante plus récente, [[wp>UEFI]] (Unified EXtensible Firmware Interface), sont des conceptions de firmware qui sont destinés à remplacer le BIOS. EFI, a été dévelloppé par Intel pour sont nouveaux processeurs Itanium.
  
-J'​utilise le terme EFI pour se référer soit à EFI 1.X ou l'​UEFI. 
  
-L'Extensible Firmware Interface (EFI) et sa variante ​plus récente,UEFI (Unified EXtensible Firmware Interface)sont des conceptions ​de firmware qui sont destinés à remplacer le BIOS.+Les capcités de l'​EFI ​sont bien plus grandes celles du BIOSEN effet un EFI peut lire une tables de partitions et accèder au systèmes de fichiers, il ne prend pas en charge le multitâches mais peut éxécuter des applications en C/C++, pour les versions les plus récentes tel que l' ​UEFI, des applications graphiques avec prise en charge ​de la souris.
  
-Les implémentations ​EFI sont plus grandes que les implémentations du BIOS un EFI peut lire les tables de partitions et systèmes de fichiersce qu’ un BIOS ne  pourra ​ pas faire.+L'​amorçage ​EFI est donc bien plus souplecontrairement au bios qui lui liste simplement ​les périphériquesil lit leurs contenu à la recherche d'​éxécutable UEFI.
  
-Cela permet à plusieurs chargeurs de démarrage de coexister sur le disque dur, et d'​être accessible tout en utilisant des mécanismes d'​accès aux fichiers normaux.+Cela permet à plusieurs chargeurs de démarrage de coexister sur un même disque dur, et d'​être accessible tout en utilisant des mécanismes d'​accès aux fichiers normaux. ​
  
-Une autre caractéristique de l'​EFI ​est le **Secure Boot**. Cette fonctionnalité est destinée ​à améliorer la sécurité, ​en veillant à ce que seuls les chargeurs de démarrage signés avec une clé de chiffrement,​ pourront s'éxécuter. +Il est aussi possible de compiler un noyau Linux de sorte à le transformer ​en véritable applications UEFI, on pourra ensuite créer ​une entrée dans la NVRAM de notre carte mère à l'aide efibootmgr, du Shell EFI, ou utiliser un boot manager tel que rEFIND[[https://​wiki.archlinux.org/​index.php/​UEFI_Bootloaders#​Linux_Kernel_EFISTUB|Voir ​EFI stub loader sur ArchWiki]]
-=====Structures de disques ​EFI=====+
  
-Lorsque vous configurez un ordinateur pour démarrer en mode UEFI, il est généralement préférable ​de créer un disque GPT+Une autre caractéristique de l'​EFI ​est le [[http://​fr.wikipedia.org/​wiki/​Unified_Extensible_Firmware_Interface#​Lancement_s.C3.A9curis.C3.A9_.28secure_boot.29|Secure Boot]]. Cette fonctionnalité est destinée à améliorer la sécurité, en veillant à ce que seuls les chargeurs ​de démarrage signés avec une clé de chiffrement,​ pourront s'​éxécuter
  
-EFI repose sur une partition spéciale, connue sous le nom de la partition système EFI (ESP), pour stocker des données ​EFI spécifiques. ​+=====Structure ​de disque ​EFI=====
  
-L'ESP devrait officiellement utiliser un système ​de fichiers FAT32bien que de nombreuses distributions Linux utilise ​un système de fichiers FAT16.+Selon la version et le constructeur ​de votre fimwareces règles peuvent variées cependant voici un aperçu.
  
-Certains utilisateurs ont constaté que certains ​EFI ont des bugs qui causent des problèmes avec les ESP  infèrieure à 512MiB (537MB), certain fichiers ne peuvent ​ être lus par l'EFI, donc je vous recommande la création d’ une  ESP d’ au moins 550MiB.+Pout ous périphériqued de stockage ​EFI recherche un répertoire ​EFI, et liste un point amorce pour chaque fichier ressemblant à *x64.efi *ia32.efi.
  
-Chaque chargeur ​de démarrage ​EFI est stocké dans un sous-répertoire du répertoire ​EFI sur l'​ESP. ​+Deux format ​de tables sont pris en charges, MBR et GPT, cependant je vous recommadent le partitionnement sur une table GPT, elle accèpte jusqu' à 128 partitions primaires. 
 + 
 +Pour qu'un amorçage UEFI est lieu sur un dique sata, cd dernier doit comporter une partition spéciale ESP (EFI File System), ceci n'est valable pour un dique USB. 
 + 
 +L'ESP devrait officiellement utiliser un système de fichiers FAT32, bien que de nombreuses distributions Linux utilise un système de fichiers FAT16, quelque fois FAT12. 
 + 
 +GPT et FAT32 est un bon compromis. 
 + 
 +Certains utilisateurs ont constaté que certains ​EFI ont des bugs qui causent des problèmes avec les ESP  infèrieure à 512MiB (537MB), certain fichiers ne peuvent ​ être lus par l'EFI, donc je vous recommande la création d’ une  ​ESP d’ au moins 550MiB.
  
-Ces répertoires sont généralement nommés d'​après le système d'​exploitation qui les a créés. Par exemple, Ubuntu met ses fichiers EFI dans EFI / ubuntu, et Red Hat met ses  dans EFI / redhat. ​+Chaque chargeur de démarrage EFI est stocké dans un sous-répertoire du répertoire EFI sur l'​ESP. ​Ces répertoires sont généralement nommés d'​après le système d'​exploitation qui les a créés. Par exemple, Ubuntu met ses fichiers EFI dans **EFI/ubuntu**, et Red Hat met ses  dans **EFI/redhat**
  
-Une fois Linux installé, l'ESP est monté ​ dans / boot / efi, de sorte que l’arborescence soit : / boot / efi / EFI / ubuntu, et: / boot / efi / EFI / redhat.+Une fois Linux installé, l'ESP est monté ​ dans **/boot/efi**, de sorte que l’arborescence soit : **/​boot/​efi/​EFI/​ubuntu**, et: **/​boot/​efi/​EFI/​redhat**.
  
-Si vous avez besoin d'​installer un chargeur de démarrage indépendamment de  de votre système d'​exploitation,​ vous pouvez créer votre propre répertoire. Exemple :  EFI / refind pour Refind.+Si vous avez besoin d'​installer un chargeur de démarrage indépendamment de  de votre système d'​exploitation,​ vous pouvez créer votre propre répertoire. Exemple :  ​**EFI/refind** pour Refind.
  
  
Ligne 63: Ligne 70:
 ===== rEFIND ===== ===== rEFIND =====
  
-Refind est un un fork REFIT, c'est un boot manager pour les ordinateurs implémanté par l'​Extensible Firmware Interface (EFI) et Unified EFI (UEFI). ​+Refind est un un fork REFIT, c'est un boot manager pour les ordinateurs implémanté par l'​Extensible Firmware Interface (EFI) et Unified EFI (UEFI). ​Il faut faire la distinction entre un boot loader tel que GRUB et un boot mangager, comme rEFIND, rEFIND est indépendant du systèmes d'​exploitation,​ il va chercher ses fichiers de configuration et drivers dant le répertoire **EFI/​refind** de l' ESP, contrairement à GRUB qui lui va chercher ses fichiers de configuration dans **/​boot/​grub** monté sur la partition racine de Linux. 
 + 
 +Vous pouvez l'​installer,​ une clé USB, un disque dur, un cdrom, ce qui le rend très polyvalent, et pratique.  
 + 
 +<​note>​Il peut être utile d'​avoir une clé USB de secours avec une partition réservé juste pour rEFIND en cas de soucis au boot, vous pourrez alors démarrer votre OS indépendemment et ainsi débuguer votre EFI.</​note>​
  
-Il faut faire la distinction entre un boot loader tel que GRUB et un boot mangager, comme rEFIND, tous les ordinnateurs basé sur EFI incluent boot manager. 
  
-Il est assez simple d' utilistation,​ polyvalent et va nous permettre de booter une image iso n'​ayant pas le support pour l'EFI. 
  
 http://​www.rodsbooks.com/​refind/​ http://​www.rodsbooks.com/​refind/​
  
-====Téléchargement====+=====Obtenir rEFIND=====
  
 Aller à la page de téléchargement de [[http://​www.rodsbooks.com/​refind/​getting.html|rEFIND]]. Aller à la page de téléchargement de [[http://​www.rodsbooks.com/​refind/​getting.html|rEFIND]].
Ligne 78: Ligne 87:
  
 Dans cet exemple je vais utiliser une image disque USB. Dans cet exemple je vais utiliser une image disque USB.
 + 
  
 Après décompression je copie l' image disque à l'aide de <dd>, afin de récupérer les fichiers de l'​image. Après décompression je copie l' image disque à l'aide de <dd>, afin de récupérer les fichiers de l'​image.
Ligne 91: Ligne 101:
 </​code>​ </​code>​
  
-=====EFI ​file System=====+=====Système de fichiers ​EFI=====
  
 Une fois les fichiers récupérer nous devons créer une table de partition GPT, un ESP et une partition FAT32 sur notre clé USB, pour acceuillir notre bootmanager,​ et notre image iso. Une fois les fichiers récupérer nous devons créer une table de partition GPT, un ESP et une partition FAT32 sur notre clé USB, pour acceuillir notre bootmanager,​ et notre image iso.
Ligne 114: Ligne 124:
 $ n $ n
 $ 206848 ​                    # 206848 par défault à la suite de l'ESP $ 206848 ​                    # 206848 par défault à la suite de l'ESP
-$ +2000M                     # GB, je vois large.+$ +1000M                     # GB, à adapter selon la taille de votre iso.
 $ 8300                       # 8300 (Linux File System) $ 8300                       # 8300 (Linux File System)
 $ w                          # On sauvegarde $ w                          # On sauvegarde
Ligne 137: Ligne 147:
  
 Montage des périphériques : Montage des périphériques :
 +
 <​code>​ <​code>​
 $ sudo mount /dev/sdx1 /media/usb0 $ sudo mount /dev/sdx1 /media/usb0
Ligne 143: Ligne 154:
  
 Copie de rEFIND sur la premiere partition : Copie de rEFIND sur la premiere partition :
 +
 <​code>​ <​code>​
 $ sudo cp -r EFI shellx64.efi ​ /​media/​usb0 ​                                                 # x64 ou ia32 selon votre  architecture (ia32 sur MAC) $ sudo cp -r EFI shellx64.efi ​ /​media/​usb0 ​                                                 # x64 ou ia32 selon votre  architecture (ia32 sur MAC)
Ligne 179: Ligne 191:
 Mon fichier refind.conf: ​ Mon fichier refind.conf: ​
  
-<file> +<code>
-# Comme pour Grub délais avant la sélection par défaut.+
 timeout 10 timeout 10
  
-# Chemin du répertoire de vos icons 
 icons_dir EFI/​boot/​icons icons_dir EFI/​boot/​icons
  
-# Affichage en texte seulement, je trouve cela plus pratique. 
 textonly textonly
  
-Pour l'​afichage graphic +use_graphics_for linux
-#resolution 1024 768+
  
-# Util pour Mac et  Linux stub loader  ​ 
-#​use_graphics_for osx 
-#​use_graphics_for linux 
- 
-# Pour avoir accès au Shell EFI, quitté etc ... 
 showtools shell, about, reboot, exit showtools shell, about, reboot, exit
  
- 
-# Chemin du répertoire de vos drivers (super important) 
 scan_driver_dirs EFI/​boot/​drivers_x64 scan_driver_dirs EFI/​boot/​drivers_x64
  
-# Défaut sur PC 
 scanfor internal,​external,​optical,​manual scanfor internal,​external,​optical,​manual
  
-# Temps du scan. 
 scan_delay 1 scan_delay 1
  
-# Pour filtrer la sortie du scan.+scan_all_linux_kernels 
 dont_scan_dirs EFI/​linuxmint,​boot dont_scan_dirs EFI/​linuxmint,​boot
  
-# Pour le mode grahics nombre d'​étiquette sur l'​écran. 
-#max_tags 0 
- 
-#Sélection par défault. 
 default_selection Crunch_Live default_selection Crunch_Live
- 
-# Volume :            Deuxième partion de votre clé USB, < 0: > étant votre ESP.  
-# loader :            Chemin de votre kernel, voir < syslinux.cfg > 
-# initrd :            Chemin de votre image RAM, voir < syslinux.cfg > 
-# ro root=UUID= :     UUID de /dev/sdx2 ( commande <​blkid>​ )  
-# add_efi_memmap :    A mettre dans tous les cas. 
-# congfig boot=live : Voir < syslinux.cfg > 
- 
  
 menuentry Crunch_Live { menuentry Crunch_Live {
-        ​icon /​EFI/​boot/​icons/​os_debian.icns  +  ​icon /​EFI/​boot/​icons/​os_debian.icns  
-        volume 1: +  volume 1: 
-        loader /​live/​vmlinuz +  loader /​live/​vmlinuz 
-        initrd /​live/​initrd.img +  initrd /​live/​initrd.img 
-        options "ro root=UUID=C847-7244 add_efi_memmap config boot=live"​ +  options "ro root=UUID=C847-7244 add_efi_memmap config boot=live"​ 
-        osype Linux +  osype Linux 
-        graphics off+  graphics off 
 } }
  
 +menuentry Crunch_Install {
 +  icon /​EFI/​boot/​icons/​os_debian.icns ​
 +  volume 1:
 +  loader /​install/​vmlinuz
 +  initrd /​install/​initrd.gz
 +  options "ro root=UUID=C847-7244 add_efi_memmap file=/​cdrom/​install/​crunchbang.cfg"​
 +  osype Linux
 +  graphics off
 +}
 +</​code>​
 +
 +<note important>​
 +rEfind est assez capricieux, votre fichier refind.conf ne doit pas avoir un pet de travers, aussi quelquefois un simple reboot permet de lancer votre kernel tranquillement. oO
 +C'est pour cela qu'il n' ya pas de commentaires dans le fichier, ci-dessus. ​
 +</​note> ​
  
-</​file>​ 
  
 Pour vous aider vous aurez besoin du fichier syslinux.cfg générer par Unetbootin : Pour vous aider vous aurez besoin du fichier syslinux.cfg générer par Unetbootin :
Ligne 271: Ligne 273:
 $ $
 </​code>​ </​code>​
 +
 +===== Utilisation =====
 +
 +C'est le moment de vérité, on peut redémarer. Dans l'​interface de votre EFI, vous choisissez votre clé USB, la première partition si vous avez le choix.
 +Là normalement rEFIND se lance, il doit tout d'​abord scanner vos disques. En mode texte vous devriez avoir le choix entre votre os principal et ensuite les menuentry que l'on a ajouter dans notre refind.conf.
 +
 +Essayons Crunch_Live ...
 +
 +Si vous avez de la chance, il se lance, sinon comme je vous l'ai dit plus haut, il est très capricieux, il ne doit pas y avoir un pet de travers, dans votre fichier de configuration.
 +
 +
 +Enfin pas de paniques, il y a le **shell UEFI** pour éditer ce fichier sans avoir besoin de redémarrer,​ je l'ai mis dans les tools, un peu plus haut.  ​
  
  
    
 +===== UEFI Shell =====
 +
 +Si vous voulez editer vos fichiers, démarrer linux en ligne de commande ou ajouter une nouvelle entrée dans votre NVRAM, c'est là que ça se passe.
 +
 +<​note> ​
 +Le Shell EFI est en Qwerty, entraîné vous un peu avant ! Il faut que vous repériez ou sont les caractères spéciaux !
 +</​note>​
 +
 +Dans le menu de rEFIND, vous choisissez Shell EFI, là du texte jaune sur un fond noir c'est le Shell EFI.
 +
 +La syntaxe ressemble beaucoup à DOS.
 +
 +Les systèmes de fichiers sont représentés par des fs0, fs1, fs3 etc... , fs0: étant la première partition de votre clef USB, si vous lancez ce Shell depuis celle-ci. L'​antislash est de rigueur.
 +
 +Exemple : 
 +<​code>​
 +shell> cd fs0:​\EFI\boot
 +fs0:​\EFI\boot\>​ edit refind.conf ​
 +</​code>  ​
 +
 +
 +Quelques commandes utiles :
 +
 +  *cd : ce déplacer.
 +  *rm : supprimer un fichier
 +  *mkdir : créer un répertoire
 +  *map : pour lister vos périphériques
 +  *map -t hd : pour filtrer la sortie, sur vos disques de USB et sata.
 +  *edit : editeur de texte, f2 pour enregistrer et f3 pour quitter
 +  *exit : quitter le shell
 +  *reset : reboot
  
doc/install/refind-boot-uefi.txt · Dernière modification: 26/11/2015 18:38 par milou

Pied de page des forums

Propulsé par FluxBB