Unified Extensible Firmware Interface (UEFI) est une interface logicielle désormais commune à tous les ordinateurs récents, particulièrement ceux vendus depuis 2010. Elle vient se placer entre le micrologiciel (firmware) et le système d'exploitation pour permettre de contrôler les paramètres de l'ordinateur. A ce titre, elle remplace la traditionnelle interface du BIOS. Puisqu'il s'agit d'un système différent du BIOS, il est important de comprendre ce qu'est l'UEFI avant d'entreprendre l'installation d'Ubuntu.
(On retrouve parfois l'appellation « EFI » pour désigner cette interface. A l'origine, EFI était développé par Intel. Les spécifications ont été reprises par un ensemble d'acteurs informatiques réunis en un seul groupe, l'UEFI Forum, puis distribuées sous l'appellation « UEFI ». Dans le présent document et dans les forums d'aide, à moins d'un avis contraire, ces deux termes désignent essentiellement la même chose.)
Si votre ordinateur est récent (>2010) et que vous ne savez pas ou vous n'avez pas besoin d'installer Ubuntu en mode UEFI, vous devriez être en mesure d'installer Ubuntu rapidement et correctement en suivant les étapes suivantes :
Une fois redémarré:
Avertissement: si vous êtes débutant, mieux vaut suivre les conseils du paragraphe précédent.
Le fait d'avoir un ordinateur équipé du système UEFI n'implique pas nécessairement que Ubuntu soit installé en mode EFI.
Pour le savoir : Sous Windows ouvrir le terminal en mode admin (démarrer → taper "cmd" et CTRL-MAJ-ENTER) et taper "bcdedit". S'affichent deux blocs d'informations. Dans le deuxième le "path" est le révélateur : s'il finit en efi le système est installé en efi.
.... Windows Boot Loader ------------------- identifier {current} device partition=C: path \Windows\system32\winload.efi description Windows 7 Home Premium (recovered) ....
Pour installer Ubuntu en mode EFI:
Cela n'est possible que si vous avez déjà installé Ubuntu sur le disque dur. Ou bien en regardant dans les réglages du BIOS (voir paragraphe ci-dessous).
Depuis une session Ubuntu installée sur le disque (à noter que ça fonctionne aussi pour une session liveCD ou liveUSB), il suffit d'ouvrir un terminal, et saisir la commande suivante:
[ -d /sys/firmware/efi ] && echo "Session EFI" || echo "Session non-EFI"
Remarque: si le démarrage est en mode classique (le résultat de la commande est "Session non-EFI"), soit le BIOS n'est pas de type UEFI, soit le BIOS est de type UEFI mais n'est pas réglé pour démarrer sur le disque dur en mode UEFI.
Remarque: même si votre PC démarre sur le CD (ou la Live USB) en mode EFI, il est possible qu'il démarre sur le disque dur en mode classique (et inversement).
Lorsqu'on démarre sur un CD Ubuntu compatible EFI:
Dans le cas d'une live USB MultiSystem, ce moyen d'identification à l'écran n'est pas possible : à la place, on peut utiliser depuis la session live la commande du paragraphe Identifier si l'ordinateur démarre sur le disque dur en mode EFI
Certains ordinateurs récents (2011 et +) permettent de régler le démarrage soit en mode classique (=mode BIOS) soit en mode UEFI. La manière d'effectuer ce réglage varie selon les ordinateurs, mais généralement ce réglage se situe dans l'onglet "Boot order" du BIOS/UEFI (il faut généralement appuyer sur une touche à l'allumage du PC pour y accéder, voir ce tutoriel).
Remarque: certains BIOS permettent de régler séparément le mode de démarrage sur CD et celui sur disque dur.
Par exemple, ci-dessous:
et voici un 2e exemple, plus simple, où le paramètre "Boot Mode" permet de choisir le mode de démarrage ("UEFI" ou "Legacy") sur tous les médias (disque dur, CD, USB…).
Il existe aussi des firmwares qui proposent une option "UEFI/Legacy Boot:" avec les choix [Legacy only], [UEFI only] et [Both], ce dernier démarrant en priorité en mode EFI, puis en mode Legacy si aucun fichier EFI n'est détecté.
Si le seul disque de votre ordinateur est neuf, il faut d'abord créer une table de partitionnement au format 'GPT' avec l'onglet 'périphériques' de gparted. Une partition EFI est indispensable pour installer Ubuntu en mode EFI via l'installateur manuel. Ubuntu ne sait actuellement utiliser que la partition EFI du premier disque. En cas d'installation de Ubuntu sur un second disque, ce n'est pas la peine de créer une partition EFI sur le second disque. C'est celle du premier disque qui sera utilisée.
/boot/efi
. 3)Depuis l'Ubuntu installé, ouvrir un terminal (Ctrl+Alt+T) et saisir la commande suivante:
[ -d /sys/firmware/efi ] && echo "Installé en mode EFI" || echo "Installé en mode classique"
Sinon, en analysant le Boot-Info réalisé depuis une session live, on peut trouver les indices suivants d'un Ubuntu installé en mode EFI :
Pour que cette conversion soit possible, il faut régler votre BIOS pour qu'il démarre sur le disque dur en mode EFI (voir le paragraphe "Régler le démarrage en mode EFI ou classique" ci-dessus). De plus, il faut opérer depuis une session live démarrée en mode EFI (voir le paragraphe "Identifier si l'ordinateur démarre sur le CD (ou la live USB) en mode EFI").
Le Secure Boot est une nouvelle fonctionnalité de l'UEFI, apparue en 2012 avec les ordinateurs pré-installés Windows 8. Sa prise en charge par Ubuntu a commencé avec 12.10 (et 12.04.2), mais elle n'est pas complète, donc vous risquez de devoir le désactiver pour pouvoir démarrer Ubuntu.
'
Ci-dessous un exemple de BIOS indiquant que le Secure Boot est activé :
Pour désactiver ou activer le Secure Boot, trouvez une option similaire dans votre BIOS et utilisez le clavier pour passer cette ligne de l'état Activé (Enabled) à Désactivé (Disabled).
Chaque constructeur ayant une manière différente de faire, si vous n'avez pas trouvé comment désactiver le Secure Boot, faites un tour dans cette documentation : Comment désactiver le secure boot
La méthode Boot-Repair prend en charge ce cas-là mais n'explique pas ce qui se passe. Voici donc une méthode alternative détaillée mais nécessitant de savoir utiliser un terminal). Voici les étapes à suivre, détaillées dans les sous-paragraphes suivants :
PS: Cette méthode fonctionne avec Debian Jessie, en veillant toutefois à remplacer ubuntu/shimx64.efi par le fichier présent dans /debian
sudo cp -R /boot/efi/ ~/EFI_sauvegarde/
find /boot/efi/ ~/EFI_sauvegarde/ -name "*.efi" -exec md5sum {} \; | sort
dbed1f7ed9e19e53bfc7f43122ce3d83 /boot/efi/EFI/Boot/bootx64.efi dbed1f7ed9e19e53bfc7f43122ce3d83 /boot/efi/EFI/HP/boot/bootmgfw.efi dbed1f7ed9e19e53bfc7f43122ce3d83 /boot/efi/EFI/Microsoft/Boot/bootmgfw.efi
Toujours sous Ubuntu :
sudo mv /boot/efi/EFI/Microsoft/Boot/bootmgfw.efi /boot/efi/EFI/Microsoft/Boot/bootmgfw_orig.efi
sudo rm /boot/efi/EFI/Boot/bootx64.efi sudo rm /boot/efi/EFI/HP/boot/bootmgfw.efi
sudo cp /boot/efi/EFI/ubuntu/shimx64.efi /boot/efi/EFI/Microsoft/Boot/bootmgfw.efi
/!\ il arrive parfois à windows de réécrire /boot/efi/EFI/Microsoft/Boot/bootmgfw.efi en cas de mise à jour… Dans ce cas, recommencer les étapes décrites ci-dessus /!\
Grub n'est plus en mesure de détecter correctement le programme d'amorçage de Windows car il n'est plus disponible sous son nom standard. Il faut donc lui permettre de retrouver le nouveau nom.
Principes : - Grub utilise la commande os-prober pour détecter les autres OS. Cette commande cherche un chemin standard pour détecter Windows. L'objectif est de modifier le résultat en sortie de cette commande pour tenir compte du renommage effectué plus tôt (bootmgfw.efi renommé en bootmgfw_orig.efi).
sudo os-prober
Le système Ubuntu étant régulièrement mis-à-jour, il faut que la modification opérée ne soit pas écrasée lors des mises-à-jour. Il faut donc créer un script supplémentaire, qui ne soit pas fourni par un paquet existant.
touch /tmp/za-windows8-hp ; sudo xdg-open /tmp/za-windows8-hp
#! /bin/sh set -e sed -i -e "s/item_in_dir bootmgfw.efi/item_in_dir bootmgfw_orig.efi/" /usr/lib/os-probes/mounted/efi/20microsoft exit 0
sudo mv /tmp/za-windows8-hp /etc/kernel/postinst.d/za-windows8-hp
sudo chmod ugo+x /etc/kernel/postinst.d/za-windows8-hp sudo chown root:root /etc/kernel/postinst.d/za-windows8-hp
sudo /etc/kernel/postinst.d/za-windows8-hp
sudo os-prober
sudo update-grub
Souvent l'utilisateur a tenté de faire un boot-repair qui n'a rien donné comme résultat positif sauf de fabriquer un fichier 25_custom contenant 3 entrées standards de boot.
sudo update-grub
.
Même si le démarrage par défaut se fait sur Ubuntu après installation, il peut arriver qu'il se remette sur Windows 8. Il suffit alors d'utiliser les "Options de démarrage avancées" de Windows (voir ici) pour redémarrer sur Ubuntu et depuis la session Ubuntu, passer la commande qui va remettre Ubuntu en priorité de démarrage :
sudo grub-install
A noter : il est possible que cette réparation simple ne fonctionne pas si le système UEFI a été bridé par le fabricant de l'ordinateur pour forcer le démarrage sur Windows.
Sur certains ordinateurs le bios a besoin d'un exécutable en 32 bits sur la clé pour démarrer, or par défaut Ubuntu le propose en 64 bits. Voir la solution ici.
rEFInd est un utilitaire à avoir en cas de problème avec le boot UEFI. En effet, il permet de redémarrer son système en mode UEFI, et donc de faire une réparation de celui-ci à partir d'Ubuntu, lancé sans passer par chroot ou autre.
Pour l'installer, coller cette commande dans un terminal:
sudo grub-install --target=x86_64-efi --efi-directory=/boot/efi --bootloader-id=ubuntu --recheck --debug /dev/sdaX
En remplaçant X (dans sdaX) par le numéro de votre partition
A noter: seule la version CD-R image supporte le boot avec Secure Boot activé, pas la version USB flash drive image file
Contributeurs principaux : YannUbuntu, fnx