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 [09/08/2013 19:02]
mytux [Refind boot from UEFI]
doc:install:refind-boot-uefi [18/08/2013 14:20]
mytux [UEFI & EFI]
Ligne 1: Ligne 1:
-(//non testé// - **mytux** 09/08/13) Le retour sur le forum est ici : [[http://​debian-facile.org/​viewtopic.php?​id=7225|[WIKI] Tuto, Refind boot iso]] from UEFI ou EFI 
-   ​N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs ! 
  
-====== Refind boot from UEFI ====== 
  
-  * Objet : Comment démarrer une image iso n'​ayant pas le support pour l'UEFI ? 
-  * Niveau requis : Tous 
-  * Commentaires : Ce tuto, concerne les personnes disposant d' une carte mère intègrant le firmware EFI ou UEFI.  
-  * Débutant, à savoir : [[manuel:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-) 
-  * Suivi : {{tag>​en-chantier à-tester à-placer}} 
-    
-==== A : Introduction ==== 
  
-Depuis peucertain ordinnateurs achetés dans le commerce avec windows préinstallé sont équipés de ce nouveau firmware apppelé UEFI+   ​N'​hésitez pas à y faire part de vos remarquessuccès, améliorations ou échecs ! 
 +(//non testé// - **mytux** 09/08/13)  
 +Le retour sur le forum est ici : [[http://​debian-facile.org/​viewtopic.php?​id=7225|[WIKI] Tuto, Refind boot iso from UEFI ou EFI ]]
  
-Qu'est ce que l'UEFI ? 
  
-//Citation Wipedia : +====== ​UEFI EFI======
-"La norme Unified Extensible Firmware Interface (UEFI, « interface micro-logicielle extensible unifiée ») définit un logiciel intermédiaire ​    ​entrele micrologiciel (firmware) et le système d'​exploitation (OS) d'un ordinateur. Cette interface succède sur certaines cartes-mères au BIOS. Elle fait suite à EFI (Extensible Firmware Interface), conçue par Intel pour les processeurs Itanium."//​+
  
-Malheureusement toutes ​les distributions ne sont pas équipés d' un bootloader capable ​de démarrer sur ce nouveau logiciel, heureusement un certain Roderick W.Smith ​à développer un fork de Refit. Refind un bootmanager qui donne la main à un bootloader traditionnel+Toutes ​les versions 64bits des PC qui exécutent Windows certifié par le programme ​de certification Windows utilisent l’UEFI ​à la place du BIOS.
  
-Page officiel de Refindhttp://​www.rodsbooks.com/refind/  +  * Objet Boot d'une distribution non compatible avec EFI & UEFI
- +  * Niveau requis ​Tous 
-==== B Installation ==== +  * Commentaires ​Ce tuto, concerne les personnes disposant d' une carte mère intègrant des firmware EFI & UEFI.  
- +  ​* Débutantà savoir : [[manuel:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-
-== Prérequis ​== +  ​* Suivi : {{tag>en-chantier à-tester à-placer}}
- +
-  ​- Un support usb (de 1 à 2 go minimumselon la taille ​de votre iso+
-  - Les droits root.+
    
-=== 1 : Téléchargement des binaires et création de l'​arborescence du répertoire de boot. ===+=====Le BIOS=====
  
-== a : Téléchargement ==+A l'aube de l'ère du premier PC en 1981, IBM livrait son Personal Computer 5150, avec un firmware connu sous le nom de  Basic Input/​Output System (BIOS). Le BIOS était destiné à être une interface entre le matériel ​ et le système d'​exploitation DOS (Disk Operating System) à l'​époque.
  
-Commençons tout d'abord par télécharger ce fameux bootmanager,​ rendez vous à :​http://​sourceforge.net/​projects/​refind/ ​et télécharger le la dernière version en paquet debian enregistrer le par exemple dans **~/​refind**+Le rôle du BIOS étatit ​d'éffectuer des tests de base t d'​appliquer une séquence linéaire de recherche afin de trouver un périphérique amorçable sur lque un secteur de 512 octetspouvaient être lus et éxécuté.Ce premier secteur qu'on appella MBR devait ensuite pouvaoir passer ​la main à un autre périphériue ou au système d'​exploitation.
  
-== b : Extraction ​des fichiers. ==+Le bios est généralement écrit en assembleur et est seulement capable d'​éxécuté ​des instructions sur 16bits aloars que les OS modernes eux, éxécutent des instructions sur 32 et 64bitsLes OS avancés n'ont puent continuer à utiliser le Bios sans pertes de performance.  
 +=====EFI et UEFI=====
  
-En ligne de commande on extrait cet archive ​à l'aide de dpkg.+J'​utilise le terme EFI pour se référer soit à EFI 1.X ou plus l'UEFI.
  
-   $ cd ~/refind +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 BIOSLes capcités de l' EFI sont plus grandes celles du BIOS, EN effet un EFI peut lire une tables de partitions et un système de fichiers, ce qu’ un BIOS ne sait pas faire.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 normauxUne 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. <​note>​ Ubuntu et Fedora, ont achetés cette clé à Microsoft ​ </note> 
-   $ dpkg -x refind_0.7.3-1_amd64.deb ./ +=====Structures de disques EFI=====
-   $ ls +
-   etc/ usr/+
  
-Les fichiers qui nous intéresses sont situés dans **usr/​share/​refind-0.7.3/​refind/​**+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. 
 +GPT offre deux avantages :   
  
-   $ cd  usr/​share/​refind-0.7.3/refind/ +  *Il supporte les disques de Plus de 2.2 to
-   $ls +  ​*Il a une limite de 128 partitions primaires.
-   ​drivers_x64 ​ icons  tools_x64 ​ refind_x64.efi ​ refind.conf-sample+
  
-On renomme **refind_x64.efi**+ 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. L'ESP devrait officiellement utiliser un système de fichiers FAT32, bien que de nombreuses distributions Linux utilise un système de fichiers FAT16. 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.
  
-   $ mv refind_x64.efi bootx64.efi 
  
-== c : Création de l'​arborescence de boot.== 
  
-Premièrement nous allons créer les répertoire qui vont accueillir notre bootmanager.+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**
  
-   $ mkdir -p ~/​EFI/​boot/ ​+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**.
  
-On copie tout ce qui est dans le répertoire ​**~/​refind/​usr/​share/​refind-0.7.3/refind/** dans **~/EFI/boot/**+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.
  
-   $ cp -a ~/​refind/​usr/​share/​refind-0.7.3/​refind/​* ~/EFI/boot/ 
-   $ cd  ~/EFI/boot/ 
-   $ ls -l 
-   ​-rw-r--r-- 1 axel axel 173608 août   7 18:05 bootx64.efi 
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 drivers_x64 
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 icons 
-   ​-rw-r--r-- 1 axel axel  17925 juil. 20 21:56 refind.conf-sample 
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 tools_x64 
  
-On rend éxècutable tous ça. 
  
-   $ chmod -R +x * 
  
-=== B : Préparation de la clé usb. === 
  
-== 1 : Table de partition GPT == 
  
-Cette partie va se faire principalement en root donc un petit : +===== rEFIND =====
  
-   $ sudo su +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.
-   #+
  
-Nous allon créer ​une table de partition GPT sur notre clé usbensuite une partition de démarrage EFI Filesystem pour refindune seconde partion Linux Filesystem ​ pour acceuillir notre image iso.+Vous pouvez l'​installer, ​une clé USBun disque durun cdrom, ce qui le rend très polyvalent, et pratique
  
-Pour cela nous aurons besoin ​de gdisk. +<​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>​
-Généralement il n'est pas installé par défault, vous aurez besoin de l'​installer.+
  
-   # sudo apt-get install gdisk 
-   # gdisk /dev/sdb (ou le périphérique correspondant à votre clé usb) 
-   GPT fdisk (gdisk) version 0.8.5 
-   ​Partition table scan: 
-   MBR: MBR only 
-   BSD: not present 
-   APM: not present 
-   GPT: not present 
-   ​*************************************************************** 
-   Found invalid GPT and valid MBR; converting MBR to GPT format. 
-   THIS OPERATION IS POTENTIALLY DESTRUCTIVE! Exit by typing '​q'​ if 
-   you don't want to convert your MBR partitions to GPT format! 
-   ​*************************************************************** 
-   ​Warning! Secondary partition table overlaps the last partition by 
-   33 blocks! 
-   You will need to delete this partition or resize it in another utility. 
-   ​Command (? for help): ?  
  
-Comande h ou ? pour afficher l'​aide. 
  
-   ​b back up GPT data to a file +http://​www.rodsbooks.com/​refind/​
-   ​c change a partition'​s name +
-   ​d delete a partition +
-   ​i show detailed information on a partition +
-   ​l list known partition types +
-   n add a new partition  +
-   ​o create a new empty GUID partition table (GPT) +
-   ​p print the partition table +
-   ​q quit without saving changes +
-   ​r recovery and transformation options (experts only) +
-   ​s sort partitions +
-   ​t change a partition'​s type code +
-   ​v verify disk +
-   ​w write table to disk and exit +
-   ​x extra functionality (experts only) +
-   ?​ print this menu +
-   ​Command (? for help)o+
  
-Commande <o> pour créer une nouvelle table de partition.  ​+=====Obtenir rEFIND=====
  
-   This option deletes all partitions and creates a new protective MBR. +Aller à la page de téléchargement de [[http://​www.rodsbooks.com/refind/​getting.html|rEFIND]].
-   ​Proceed?​ (Y/N): y +
  
-Vous pouvez confirmer, assurez vous d'​avoir sauvegarder vos données existante.+Télécharger les fichiers correspondant à votre périphériques.
  
-    +Dans cet exemple je vais utiliser une image disque USB. 
-Commande (? for help): n  + 
-  +
-   ​Partition number (1-128, default 1): 1                  +
-    +
-Commande <1 ou enter> pour le choix par défaut  +
-    +
-   First sector (34-7716830,​ default = 2048) or {+-}size{KMGTP}:​ 2048          +
-    +
-   ​Commande <​entrer>​ choix par défaut +
-   Last sector (2048-7716830,​ default = 7716830) or {+-}size{KMGTP}:​ +10M        +
-    +
-Commande <​+50M>​ 50 Mo suffiront largement +
-    +
-   ​Current type is 'Linux filesystem'​ +
-   Hex code or GUID (L to show codes, Enter = 8300): L   ​  ​        +
-    +
-Commande <L> pour connaître les codes connues +
-    +
-   0700 Microsoft basic data  0c01 Microsoft reserved ​   2700 Windows RE           +
-   4200 Windows LDM data      4201 Windows LDM metadata ​ 7501 IBM GPFS             +
-   7f00 ChromeOS kernel ​      7f01 ChromeOS root         7f02 ChromeOS reserved ​   +
-   8200 Linux swap            8300 Linux filesystem ​     8301 Linux reserved ​      +
-   8e00 Linux LVM             a500 FreeBSD disklabel ​    a501 FreeBSD boot         +
-   a502 FreeBSD swap          a503 FreeBSD UFS           a504 FreeBSD ZFS          +
-   a505 FreeBSD Vinum/​RAID ​   a580 Midnight BSD data     a581 Midnight BSD boot    +
-   a582 Midnight BSD swap     a583 Midnight BSD UFS      a584 Midnight BSD ZFS     +
-   a585 Midnight BSD Vinum    a800 Apple UFS             a901 NetBSD swap          +
-   a902 NetBSD FFS            a903 NetBSD LFS            a904 NetBSD concatenated  +
-   a905 NetBSD encrypted ​     a906 NetBSD RAID           ab00 Apple boot           +
-   af00 Apple HFS/​HFS+ ​       af01 Apple RAID            af02 Apple RAID offline ​  +
-   af03 Apple label           af04 AppleTV recovery ​     af05 Apple Core Storage ​  +
-   be00 Solaris boot          bf00 Solaris root          bf01 Solaris /usr & Mac Z +
-   bf02 Solaris swap          bf03 Solaris backup ​       bf04 Solaris /var         +
-   bf05 Solaris /home         bf06 Solaris alternate se  bf07 Solaris Reserved 1   +
-   bf08 Solaris Reserved 2    bf09 Solaris Reserved 3    bf0a Solaris Reserved 4   +
-   bf0b Solaris Reserved 5    c001 HP-UX data            c002 HP-UX service ​       +
-   ef00 EFI System ​           ef01 MBR partition scheme ​ ef02 BIOS boot partition  +
-   fd00 Linux RAID             +
-   Hex code or GUID (L to show codes, Enter = 8300): ef00        +
-    +
-Commande <​ef00>​ pour un système EFI.+
  
-Créer une seconde partition ​de même sur le reste de la clé ou d'une taille suffisante pour copier votre image iso dessus, mais cette fois avec le Filesystem Linux par défaut (Hex code 8300).+Après décompression je copie l' image disque à l'​aide ​de <dd>, afin de récupérer les fichiers de l'​image.
  
-    +<​code>​ 
-   Command (? for help): p  ​     ​ +$ dd if=refind-flashdrive-0.7.3.img of=/dev/sdx bs=1M   ​# Copie sur la clef USB 
-   Disk /dev/sdb: 7716864 sectors, 3.7 GiB +$ mount /dev/sdb1 /​media/​usb0 ​                           
-   Logical sector size: 512 bytes +$ cd /media/usb0 
-   Disk identifier (GUID): 734165E0-59BE-47CE-8773-64FCCC709443 +$ls 
-   Partition table holds up to 128 entries +EFI  shellia32.efi ​ shellx64.efi ​                       # On récupère les fichiers. 
-   First usable sector is 34, last usable sector is 7716830 +$ cp -r * ~/ 
-   Partitions will be aligned ​on 2048-sector boundaries +$ umount /​media/​usb0 ​                                   # Et on démonte, pour préparer le système de fichier
-   Total free space is 7696317 sectors (3.7 GiB) +</​code>​
-   Number ​ Start (sector) ​   End (sector) ​ Size       ​Code ​ Name +
-   ​1 ​           2048           ​22527 ​  50.0 MiB    EF00  EFI System +
-   ​2 ​          ​22528 ​        ​7716830 ​  3.7 GiB     ​8300 ​ Linux filesystem+
  
-Commande <p> pour afficher la table de partition. +=====Système ​de fichiers EFI=====
-    +
-   ​Command (? for help): w  +
-   Final checks complete. About to write GPT data. THIS WILL OVERWRITE EXISTING +
-   ​PARTITIONS!! +
-   Do you want to proceed? (Y/N): y +
-   OK; writing new GUID partition table (GPT) to /dev/sdb. +
-   ​Warning:​ The kernel is still using the old partition table. +
-   The new table will be used at the next reboot. +
-   The operation has completed successfully. +
-   $+
  
-Commande <w> pour sauvegarder ​les changements +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.
-   +
  
-Voilà on notre partition ​EFI pour accueillir Refind+On va utiliser <​gdisk>,​ ce soft est similaire à fdisk, mais nous permettre de manipuler des tables de partition ​GPT. 
 +Sur la plupart des distributions il n'est pas installer par défault.
  
-Créer une seconde partition ​de même sur le reste de la clé ou d'une taille suffisante pour copier votre image iso dessus, mais cette fois avec le Filesystem Linux par défaut ​(Hex code 8300)+<​code>​ 
 +$ sudo apt-get install gdisk  
 +$ sudo gdisk /dev/sdb 
 +$ o                           # ​Créer une nouvelle table de partion GPT 
 +$ n                           # Créer ​une nouvelle partition 
 +$ 1                           # Par défault partition numéro 1 
 +$ 2048                        # Premier secteur ​par défault 
 +$ +100M                       # 100 MB je pense que cela suffira, si vous rencontrez des problèmes, augmenter sa taille.  
 +$ ef00                        # ef00 (EFI File System) 
 +</​code>​
  
-== 2 : Création d'un systéme de fichiers vfat sur les deux partitions==+Création d'une seconde partion pour notre image iso.
  
-   mkfs.vfat -F32 /dev/sdb1 +<​code>​ 
-   mkfs.vfat 3.0.14 (23 Jan 2023) +$ n 
-   ​mkfs.vfat -F32 /dev/sdb2 +$ 206848 ​                    206848 par défault à la suite de l'ESP 
-   ​mkfs.vfat 3.0.14 ​(23 Jan 2023+$ +1000M ​                    # 1 GB, à adapter selon la taille de votre iso
-   ​blkid +$ 8300                       8300 (Linux File System
-   /dev/sdb1: LABEL="​jump"​ UUID="​339F-2ABE"​ TYPE="​vfat"​ SEC_TYPE="​msdos"​  +$ w                          ​On sauvegarde 
-   /dev/sdb2: UUID="​3568-43B4"​ TYPE="​vfat" ​+</code>
  
-== 3 : Montage des périphériques==+Ensuite, il faut redémarer pour que le Kernel relise la table de partitions.
  
-   # mkdir -p /​media/​refind +<​code>​ 
-   # mkdir -p /media/iso +$ sudo shutdown ​-r now 
-   # mount /dev/sdb1 /​media/​refind +</code>
-   # mount /dev/sdb2 /media/iso+
  
-== 4 : Copie des fichiers sur la clef ==+Création d' un système de fichiers ​FAT32 sur les deux partions :
  
-   # cp -r ~/EFI /media/refind+<​code>​ 
 +$ mkfs.vfat ​-F32 /dev/sdb1 
 +$ mkfs.vfat -F32 /dev/sdb2 
 +</code>
  
-Pour la seconde partitions nous allons utiliser Unetbootin.+===== Installation =====
  
-Télécharger une image iso, par exemple Crunbang ou LMDE, 64bit. +Pour l'​installation on aura juste à copier les fichiers que étaient dans l'image flashdrive de rEFIND dans notre ESP; et utiliser Unetbootin pour copier notre iso sur notre seconde partition.
-Installer votre iso sur /dev/sdb2, avec Unetbootin.+
  
-Une fois terminer éxécuter mount. +Montage des périphériques :
-Vous devriez avoir quelque chose comme ça en sortie.+
  
 <​code>​ <​code>​
-$ mount +sudo mount /dev/sdx1 /media/usb0 
-/dev/sdb1 on /media/refind type vfat (rw) +$ sudo mount /dev/sdx2 /media/usb1
-/dev/sdb2 on /media/Debian-Live type vfat (rw,​nosuid,​nodev,​uid=1000,​gid=1000,​shortname=mixed,​dmask=0077,​utf8=1,​showexec,​flush,​uhelper=udisks2)+
 </​code>​ </​code>​
  
 +Copie de rEFIND sur la premiere partition :
  
-==== B : Configuration ====+<​code>​ 
 +$ sudo cp -r EFI shellx64.efi ​ /​media/​usb0 ​                                                 # x64 ou ia32 selon votre  architecture (ia32 sur MAC) 
 +$ cd /​media/​usb0 
 +$ ls 
 +bootia32.efi ​ bootx64.efi ​ drivers_ia32 ​ drivers_x64 ​ icons  refind.conf 
 +$ rm -r bootia32.efi drivers_ia32 ​                                                          #​Supression des fichiers inutiles 
 +$ mv refind.conf exemple.conf ​                                                              #​Jeter un oeil à ce fichier, il y-a plein de commentaire. 
 +</​code>​
  
-Pour cette seconde troisième partie nous allons nous attaquer le fichier de configuration **refind.conf** qui ce trouve sur notre clé usb.+Ensuite installons ​notre iso avec Unetbootin :
  
-cd /​media/​refind/​EFI/​boot +<​code>​ 
- +sudo apt-get install unetbootin 
-Là vous devriez avoir un fichier **refind.conf-sample**, vous pouvez l' éxaminer, il est assez long mais il y a plein de commentaires et quelques modèles. +$ sudo unetbootin & 
- +</code>
-J 'ai récupérer le refind.conf de l'iso de Manjaro (//non testé// - **mytux** 09/08/13) Le retour sur le forum est ici : [[http://​debian-facile.org/​viewtopic.php?​id=7225|[WIKI] Tuto, Refind boot iso]] from UEFI ou EFI +
-   ​N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs ! +
- +
-====== Refind boot from UEFI ====== +
- +
-  * Objet : Comment démarrer une image iso n'​ayant pas le support pour l'UEFI ? +
-  * Niveau requis : Tous +
-  * Commentaires : Ce tuto, concerne les personnes disposant d' une carte mère intègrant le firmware EFI ou UEFI.  +
-  * Débutant, à savoir : [[manuel:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-) +
-  * Suivi : {{tag>en-chantier à-tester à-placer}} +
-    +
-==== Introduction ==== +
- +
-Depuis peu, certain ordinnateurs achetés dans le commerce avec windows préinstallé sont équipés de ce nouveau firmware apppelé UEFI.  +
- +
-Qu'est ce que l'UEFI ? +
- +
-//Citation Wipedia : +
-"La norme Unified Extensible Firmware Interface (UEFI, « interface micro-logicielle extensible unifiée ») définit un logiciel intermédiaire ​    ​entrele micrologiciel (firmware) et le système d'​exploitation (OS) d'un ordinateur. Cette interface succède sur certaines cartes-mères au BIOS. Elle fait suite à EFI (Extensible Firmware Interface), conçue par Intel pour les processeurs Itanium."//​ +
- +
-Malheureusement toutes les distributions ne sont pas équipés d' un bootloader capable de démarrer sur ce nouveau logiciel, heureusement un certain Roderick W.Smith à développer un fork de Refit. Refind un bootmanager qui donne la main à un bootloader traditionnel.  +
- +
-Page officiel de Refind: http://​www.rodsbooks.com/​refind/ ​+
  
-==== Installation ====+Bon là pas besoin de moi, vous installez une iso qui vous fais des misères (Crunchbang,​ LMDE) sur /dev/sdx2.
  
-== Prérequis : ==+Dans cet exemple j'​utilise Crunchbang.
  
-  - Un support usb (de 1 à 2 go minimum, selon la taille de votre iso) +=====Configuration=====
-  - Les droits root.+
    
-=== A : Téléchargement des binaires ​et création de l'​arborescence du répertoire de boot===+On approche de la fin, et on entame la partir la plus marrante.
  
-== 1 : Téléchargement ==+Toutes la configuration ce fait dans le fichier refind.conf.
  
-Commençons tout d'​abord par télécharger ce fameux bootmanagerrendez vous à :http://sourceforge.net/​projects/​refind/ ​et télécharger le la dernière version en paquet debian enregistrer le par exemple dans **~/​refind**+Jeter un oeil sur la page de Roderick W. Smith[[http://www.rodsbooks.com/refind/configfile.html|Configuring the Boot manager]].
  
-== 2 : Extraction des fichiers. == +Et aussi, ​le fichier example.conf qu'on a rennomer tout à l'heure.
- +
-En ligne de commande on extrait cet archive à l'aide de dpkg. +
- +
-   $ cd ~/refind +
-   $ dpkg -x refind_0.7.3-1_amd64.deb ./ +
-   $ ls +
-   etc/ usr/ +
- +
-Les fichiers qui nous intéresses sont situés dans **usr/​share/​refind-0.7.3/​refind/​** +
- +
-   $ cd  usr/​share/​refind-0.7.3/​refind/​ +
-   $ls +
-   ​drivers_x64 ​ icons  tools_x64 ​ refind_x64.efi ​ refind.conf-sample +
- +
-On renomme **refind_x64.efi** +
- +
-   $ mv refind_x64.efi bootx64.efi +
- +
-== 3 : Création de l'​arborescence de boot.== +
- +
-Premièrement nous allons créer les répertoire qui vont accueillir notre bootmanager. +
- +
-   $ mkdir -p ~/EFI/boot/  +
- +
-On copie tout ce qui est dans le répertoire **~/​refind/​usr/​share/​refind-0.7.3/​refind/​** dans **~/​EFI/​boot/​** +
- +
-   $ cp -a ~/​refind/​usr/​share/​refind-0.7.3/​refind/​* ~/​EFI/​boot/​ +
-   $ cd  ~/​EFI/​boot/​ +
-   $ ls -l +
-   ​-rw-r--r-- 1 axel axel 173608 août   7 18:05 bootx64.efi +
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 drivers_x64 +
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 icons +
-   ​-rw-r--r-- 1 axel axel  17925 juil. 20 21:56 refind.conf-sample +
-   ​drwxr-xr-x 2 axel axel   4096 août   7 18:05 tools_x64 +
- +
-On rend éxècutable tous ça. +
- +
-   $ chmod -R +x * +
- +
-=== B : Préparation de la clé usb. === +
- +
-== 1 : Table de partition GPT == +
- +
-Cette partie va se faire principalement en root donc un petit :  +
- +
-   $ sudo su +
-   # +
- +
-Nous allon créer une table de partition GPT sur notre clé usb, ensuite une partition de démarrage EFI Filesystem pour refind, une seconde partion Linux Filesystem ​ pour acceuillir notre image iso. +
- +
-Pour cela nous aurons besoin de gdisk. +
-Généralement il n'est pas installé par défault, vous aurez besoin de l'​installer. +
- +
-   # sudo apt-get install gdisk +
-   # gdisk /dev/sdb (ou le périphérique correspondant à votre clé usb) +
-   GPT fdisk (gdisk) version 0.8.5 +
-   ​Partition table scan: +
-   MBR: MBR only +
-   BSD: not present +
-   APM: not present +
-   GPT: not present +
-   ​*************************************************************** +
-   Found invalid GPT and valid MBR; converting MBR to GPT format. +
-   THIS OPERATION IS POTENTIALLY DESTRUCTIVE! Exit by typing '​q'​ if +
-   you don't want to convert your MBR partitions to GPT format! +
-   ​*************************************************************** +
-   ​Warning! Secondary partition table overlaps the last partition by +
-   33 blocks! +
-   You will need to delete this partition or resize it in another utility. +
-   ​Command (? for help): ?  +
- +
-Comande h ou ? pour afficher l'​aide. +
- +
-   ​b back up GPT data to a file +
-   ​c change a partition'​s name +
-   ​d delete a partition +
-   ​i show detailed information ​on a partition +
-   l list known partition types +
-   n add a new partition  +
-   ​o create a new empty GUID partition table (GPT) +
-   ​p print the partition table +
-   ​q quit without saving changes +
-   ​r recovery and transformation options (experts only) +
-   ​s sort partitions +
-   ​t change a partition's type code +
-   ​v verify disk +
-   ​w write table to disk and exit +
-   ​x extra functionality (experts only) +
-   ?​ print this menu +
-   ​Command (? for help): o +
- +
-Commande <o> pour créer une nouvelle table de partition. ​  +
- +
-   This option deletes all partitions and creates a new protective MBR. +
-   ​Proceed?​ (Y/N): y  +
- +
-Vous pouvez confirmer, assurez vous d'​avoir sauvegarder vos données existante. +
- +
-    +
-Commande (? for help): n  +
-  +
-   ​Partition number (1-128, default 1): 1                  +
-    +
-Commande <1 ou enter> pour le choix par défaut  +
-    +
-   First sector (34-7716830,​ default = 2048) or {+-}size{KMGTP}:​ 2048          +
-    +
-   ​Commande <​entrer>​ choix par défaut +
-   Last sector (2048-7716830,​ default = 7716830) or {+-}size{KMGTP}:​ +10M        +
-    +
-Commande <​+50M>​ 50 Mo suffiront largement +
-    +
-   ​Current type is 'Linux filesystem'​ +
-   Hex code or GUID (L to show codes, Enter = 8300): L   ​  ​        +
-    +
-Commande <L> pour connaître les codes connues +
-    +
-   0700 Microsoft basic data  0c01 Microsoft reserved ​   2700 Windows RE           +
-   4200 Windows LDM data      4201 Windows LDM metadata ​ 7501 IBM GPFS             +
-   7f00 ChromeOS kernel ​      7f01 ChromeOS root         7f02 ChromeOS reserved ​   +
-   8200 Linux swap            8300 Linux filesystem ​     8301 Linux reserved ​      +
-   8e00 Linux LVM             a500 FreeBSD disklabel ​    a501 FreeBSD boot         +
-   a502 FreeBSD swap          a503 FreeBSD UFS           a504 FreeBSD ZFS          +
-   a505 FreeBSD Vinum/​RAID ​   a580 Midnight BSD data     a581 Midnight BSD boot    +
-   a582 Midnight BSD swap     a583 Midnight BSD UFS      a584 Midnight BSD ZFS     +
-   a585 Midnight BSD Vinum    a800 Apple UFS             a901 NetBSD swap          +
-   a902 NetBSD FFS            a903 NetBSD LFS            a904 NetBSD concatenated  +
-   a905 NetBSD encrypted ​     a906 NetBSD RAID           ab00 Apple boot           +
-   af00 Apple HFS/​HFS+ ​       af01 Apple RAID            af02 Apple RAID offline ​  +
-   af03 Apple label           af04 AppleTV recovery ​     af05 Apple Core Storage ​  +
-   be00 Solaris boot          bf00 Solaris root          bf01 Solaris /usr & Mac Z +
-   bf02 Solaris swap          bf03 Solaris backup ​       bf04 Solaris /var         +
-   bf05 Solaris /home         bf06 Solaris alternate se  bf07 Solaris Reserved 1   +
-   bf08 Solaris Reserved 2    bf09 Solaris Reserved 3    bf0a Solaris Reserved 4   +
-   bf0b Solaris Reserved 5    c001 HP-UX data            c002 HP-UX service ​       +
-   ef00 EFI System ​           ef01 MBR partition scheme ​ ef02 BIOS boot partition  +
-   fd00 Linux RAID             +
-   Hex code or GUID (L to show codes, Enter = 8300): ef00        +
-    +
-Commande <​ef00>​ pour un système EFI. +
- +
-Créer une seconde partition de même sur le reste de la clé ou d'une taille suffisante pour copier votre image iso dessus, mais cette fois avec le Filesystem Linux par défaut (Hex code 8300). +
- +
-    +
-   ​Command (? for help): p  ​      +
-   Disk /dev/sdb: 7716864 sectors, 3.7 GiB +
-   ​Logical sector size: 512 bytes +
-   Disk identifier (GUID): 734165E0-59BE-47CE-8773-64FCCC709443 +
-   ​Partition table holds up to 128 entries +
-   First usable sector is 34, last usable sector is 7716830 +
-   ​Partitions will be aligned on 2048-sector boundaries +
-   Total free space is 7696317 sectors (3.7 GiB) +
-   ​Number ​ Start (sector) ​   End (sector) ​ Size       ​Code ​ Name +
-   ​1 ​           2048           ​22527 ​  50.0 MiB    EF00  EFI System +
-   ​2 ​          ​22528 ​        ​7716830 ​  3.7 GiB     ​8300 ​ Linux filesystem +
- +
-Commande <p> pour afficher la table de partition. +
-    +
-   ​Command (? for help): w  +
-   Final checks complete. About to write GPT data. THIS WILL OVERWRITE EXISTING +
-   ​PARTITIONS!! +
-   Do you want to proceed? (Y/N): y +
-   OK; writing new GUID partition table (GPT) to /dev/sdb. +
-   ​Warning:​ The kernel is still using the old partition table. +
-   The new table will be used at the next reboot. +
-   The operation has completed successfully. +
-   $ +
- +
-Commande <w> pour sauvegarder les changements +
-    +
- +
-Voilà on a notre partition EFI pour accueillir Refind.  +
- +
-Créer une seconde partition de même sur le reste de la clé ou d'une taille suffisante pour copier votre image iso dessus, mais cette fois avec le Filesystem Linux par défaut (Hex code 8300) +
- +
-== 2 : Création d'un systéme de fichiers vfat sur les deux partitions. == +
- +
-   # mkfs.vfat -F32 /dev/sdb1 +
-   ​mkfs.vfat 3.0.14 (23 Jan 2023) +
-   # mkfs.vfat -F32 /dev/sdb2 +
-   ​mkfs.vfat 3.0.14 (23 Jan 2023) +
-   # blkid +
-   /​dev/​sdb1:​ LABEL="​jump"​ UUID="​339F-2ABE"​ TYPE="​vfat"​ SEC_TYPE="​msdos"​  +
-   /​dev/​sdb2:​ UUID="​3568-43B4"​ TYPE="​vfat"​  +
- +
-== 3 : Montage des périphériques. == +
- +
-   # mkdir -p /​media/​refind +
-   # mkdir -p /​media/​iso +
-   # mount /dev/sdb1 /​media/​refind +
-   # mount /dev/sdb2 /​media/​iso +
- +
-== 4 : Copie des fichiers sur la clef == +
- +
-   # cp -r ~/EFI /​media/​refind +
- +
-Pour la seconde partitions nous allons utiliser Unetbootin. +
- +
-Télécharger une image iso, par exemple Crunbang ou LMDE, 64bit. +
-Installer votre iso sur /dev/sdb2, avec Unetbootin. +
- +
-Une fois terminer éxécuter mount. +
-Vous devriez avoir quelque chose comme ça en sortie.+
  
 <​code>​ <​code>​
-mount +nano refind.conf
-/dev/sdb1 on /media/refind ​type vfat (rw) +
-/dev/sdb2 on /​media/​Debian-Live type vfat (rw,​nosuid,​nodev,​uid=1000,​gid=1000,​shortname=mixed,​dmask=0077,​utf8=1,​showexec,​flush,​uhelper=udisks2)+
 </​code>​ </​code>​
  
 +Mon fichier refind.conf: ​
  
-==== Configuration ==== +<code
- +timeout ​10
-Pour cette seconde troisième partie nous allons nous attaquer le fichier de configuration **refind.conf** qui ce trouve sur notre clé usb. +
- +
-$ cd /​media/​refind/​EFI/​boot +
- +
-Là vous devriez avoir un fichier refind.conf-sample,​ vous pouvez l' éxaminer, il est assez long mais il y a plein d '​explications et quelques modèles. +
- +
-Nous nous allons en créer beaucoup plus cours sans commentaires. +
- +
- +
-<file+
-timeout ​5+
  
-hideui singleuser+icons_dir EFI/​boot/​icons
  
 textonly textonly
-#resolution 1024 768 
  
-use_graphics_for ​osx+use_graphics_for ​linux
  
-showtools about,​reboot,shutdown,exit+showtools ​shell, ​about, reboot, exit
  
 scan_driver_dirs EFI/​boot/​drivers_x64 scan_driver_dirs EFI/​boot/​drivers_x64
  
-scanfor ​manual,internal,​external,​optical+scanfor internal,​external,​optical,manual
  
 scan_delay 1 scan_delay 1
  
-#​also_scan_dirs boot+scan_all_linux_kernels
  
-dont_scan_dirs EFI/boot+dont_scan_dirs EFI/linuxmint,boot
  
-#​scan_all_linux_kernels+default_selection Crunch_Live
  
-max_tags 0 +menuentry ​Crunch_Live ​
- +  icon /​EFI/​boot/​icons/​os_debian.icns  
-default_selection "​Debian Live"​ +  volume 1: 
- +  loader /​live/​vmlinuz 
-menuentry ​"​Debian Live" ​+  initrd /​live/​initrd.img 
-        icon /​EFI/​boot/​icons/​os_linux.icns  +  options "ro root=UUID=C847-7244 add_efi_memmap config boot=live"​ 
-        volume 1: +  osype Linux 
-        loader /​live/​vmlinuz +  graphics off 
-        initrd /​live/​initrd.img +
-        ​ostype Linux +
- graphics off +
- options "ro root=UUID=3568-43B4 add_efi_memmap config boot=live"​+
 } }
  
-menuentry ​"UEFI x64 Shell v2" ​+menuentry ​Crunch_Install ​
- icon /​EFI/​boot/​icons/​tool_shell.icns +  icon /​EFI/​boot/​icons/​os_debian.icns  
- loader /EFI/tools/shellx64_v2.efi +  ​volume 1: 
- graphics off+  ​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>​
  
-menuentry "UEFI x64 Shell v1" { +<note important>​ 
- icon /​EFI/​boot/​icons/​tool_shell.icns +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 
- loader /​EFI/​tools/​shellx64_v1.efi +C'est pour cela qu'il n' ya pas de commentaires dans le fichier, ci-dessus.  
- graphics off +</​note> ​
-}+
  
-</​file>​ 
  
-Bien sûr ceci n'est qu'un exemple il faut que vous éditiez refind.conf en prenant exemple sur les fichiers qui sont sur votre iso.+Pour vous aider vous aurez besoin du fichier syslinux.cfg générer par Unetbootin :
  
-== Quelques poins important :==+<​code>​ 
 +$ cd /​media/​usb1 
 +$ cat syslinux.cfg 
 +default menu.c32 
 +prompt 0 
 +menu title UNetbootin 
 +timeout 100
  
-**scan_driver_dir** : Faites attention que le chemin corresponde bien.+label unetbootindefault 
 +menu label Default 
 +kernel /ubnkern 
 +append initrd=/​ubninit boot=live config quiet
  
-**volume 1:** : Correspond au deuxième périphérique de stockage donc votre clé usb <0:> étant ​/dev/sda.+label ubnentry0 
 +menu label Live Session 
 +kernel ​/live/vmlinuz 
 +append initrd=/​live/​initrd.img boot=live config quiet
  
-**loader** ​Correspond au chemin de l'​image du noyau.+label ubnentry1 
 +menu label Install 
 +kernel /​install/​gtk/​vmlinuz 
 +append initrd=/​install/​gtk/​initrd.gz video=vesa:ywrap,mtrr vga=788 quiet file=/​cdrom/​install/​crunchbang.cfg
  
-**initrd** : Correspond au chemin de l' image RAM.+label ubnentry2 
 +menu label Memory Test 
 +kernel /​live/​memtest 
 +append ​initrd=/​ubninit ​
  
-**ro root=UUID=3568-43B4** : Un simple blkid vous renseigne sur ce numéro.+
 +</​code>​
  
-Options : reporter les options qui sont dans le fichier **isolinux/​live.cfg**,​ n'​oubliez pas les guillemets et **add_efi_memmap**+===== Utilisation =====
  
-Pour les autres Optionsregardez ​le fichier **refind.conf-sample**.+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.
  
-Vous remarquerez la présence de **menuentry "UEFI x64 Shell v2"**+Essayons Crunch_Live ...
  
-Et oui, il ya un Shell UEFI vous pouvez les télécharger sur [[https://​wiki.archlinux.org/​index.php/​Unified_Extensible_Firmware_Interface#​UEFI_Shell| Archlinux]]+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.
  
-Et pour la forme: [[http://​software.intel.com/​en-us/​articles/​efi-shells-and-scripting/​|EFI Shells and Scripting]] 
  
 +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 =====
  
-==== Utilisation ====+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.
  
-Si les fichier de configuration sont niquelset que vous les avez préparer au petits oignons. ​ +<​note>​  
-On peut redémmarer, ​<échapou je ne sais quelle touche, pour booter UEFI USB NMAP je sais pas quoi.+Le Shell EFI est en Qwertyentraîné vous un peu avant ! Il faut que vous repériez ou sont les caractères spéciaux ! 
 +</note>
  
-Normalement Refind se lanceil scan vos disqueset là si tous est bien configurer vous choisisssez Debian Live.+Dans le menu de rEFINDvous choisissez Shell EFI, là du texte jaune sur un fond noir c'est le Shell EFI.
  
-Si cela ne fonctionne pas revoyez votre refind.conf.//​(cette iso ma beaucoup aidé pour comprendre le fonctionnement de refind)//, ce qui donne: ​+La syntaxe ressemble beaucoup à DOS.
  
-<​file>​ +Les systèmes de fichiers sont représentés par des fs0fs1fs3 etc... , fs0étant ​la première partition ​de votre clef USB, si vous lancez ce Shell depuis celle-ciL'​antislash est de rigueur.
-timeout 5 +
- +
-hideui singleuser +
- +
-textonly +
-#resolution 1024 768 +
- +
-use_graphics_for osx +
- +
-showtools about,​reboot,​shutdown,​exit +
- +
-scan_driver_dirs EFI/​boot/​drivers_x64 +
- +
-scanfor manual,​internal,​external,​optical +
- +
-scan_delay 1 +
- +
-#​also_scan_dirs boot +
- +
-dont_scan_dirs EFI/boot +
- +
-#​scan_all_linux_kernels +
- +
-max_tags 0 +
- +
-default_selection "​Debian Live"​ +
- +
-menuentry "​Debian Live" { +
-        icon /​EFI/​boot/​icons/​os_linux.icns  +
-        volume 1: +
-        loader /​live/​vmlinuz +
-        initrd /​live/​initrd.img +
-        ostype Linux +
- graphics off +
- options "ro root=UUID=3568-43B4 add_efi_memmap config boot=live"​ +
-+
- +
-menuentry "UEFI x64 Shell v2" { +
- icon /​EFI/​boot/​icons/​tool_shell.icns +
- loader /​EFI/​tools/​shellx64_v2.efi +
- graphics off +
-+
- +
-menuentry "UEFI x64 Shell v1" { +
- icon /​EFI/​boot/​icons/​tool_shell.icns +
- loader /​EFI/​tools/​shellx64_v1.efi +
- graphics off +
-+
- +
-</​file>​ +
- +
-Bien sûr ceci n'est qu'un exemple il faut que vous éditiez refind.conf en prenant exemple sur les fichiers ​qui sont sur votre iso. +
- +
-== Quelques poins important :== +
- +
-**scan_driver_dir** : Faites attention que le chemin corresponde bien. +
- +
-**volume 1:** : Correspond au deuxième périphérique de stockage donc votre clé usb <0:> étant /dev/sda. +
- +
-**loader** : Correspond au chemin de l'​image du noyau. +
- +
-**initrd** : Correspond au chemin de l' image RAM. +
- +
-**ro root=UUID=3568-43B4** : Un simple blkid vous renseigne sur ce numéro. +
- +
-Options : reporter les options qui sont dans le fichier **isolinux/​live.cfg**n'​oubliez pas les guillemets et **add_efi_memmap** +
- +
-Pour les autres Optionsregardez le fichier **refind.conf-sample**. +
- +
-Vous remarquerez la présence de **menuentry "UEFI x64 Shell v2"​** +
- +
-Et ouiil ya un Shell UEFI vous pouvez les télécharger sur [[https://​wiki.archlinux.org/​index.php/​Unified_Extensible_Firmware_Interface#​UEFI_Shell| Archlinux]] +
- +
-Et pour la forme: [[http://​software.intel.com/​en-us/​articles/​efi-shells-and-scripting/​|EFI Shells and Scripting]] +
- +
- +
- +
- +
-==== C : Utilisation ==== +
- +
-Si les fichier ​de configuration sont niquels, et que vous les avez préparer au petits oignons.  +
-On peut redémmarer,​ <​échap>​ ou je ne sais quelle touche, pour booter UEFI USB NMAP je sais pas quoi. +
- +
-Normalement Refind se lanceil scan vos disques, et là si tous est bien configurer ​vous choisisssez Debian Live. +
- +
-Si cela ne fonctionne pas revoyez votre refind.conf.+
  
 +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