vendredi 1 septembre 2023

Blscfg et Fedora

Fedora utilise par défaut BLSCFG (Boot Loader Specification Configuration) comme on peut le vérifier dans le fichier /etc/defaults/grub qui contient GRUB_ENABLE_BLSCFG=true. De ce fait /boot/grub2/grub.cfg ne contient aucune entrée menuentry pour Fedora, mais seulement des entrées pour les autres systèmes d'exploitation.

Par contre on y trouve: 

insmod

blscfg

La commande blscfg ajoute des entrées au menu en se basant sur le contenu du dossier /boot/loader/entries. Ici le dossier contient 4 fichiers:

[toto@fedora ~]$ sudo ls -1 /boot/loader/entries 
7753b84a2ac148e7894de73d56d9be39-0-rescue.conf
7753b84a2ac148e7894de73d56d9be39-6.4.11-200.fc38.x86_64.conf
7753b84a2ac148e7894de73d56d9be39-6.4.12-200.fc38.x86_64.conf
7753b84a2ac148e7894de73d56d9be39-6.4.9-200.fc38.x86_64.conf

J'examine le contenu d'un des fichiers:

[toto@fedora ~]$ sudo -i
[sudo] Mot de passe de toto : 
[root@fedora ~]# cd /boot/loader/entries
[root@fedora entries]# cat 7753b84a2ac148e7894de73d56d9be39-6.4.12-200.fc38.x86_64.conf 
title Fedora Linux (6.4.12-200.fc38.x86_64) 38 (Workstation Edition)
version 6.4.12-200.fc38.x86_64
linux /boot/vmlinuz-6.4.12-200.fc38.x86_64
initrd /boot/initramfs-6.4.12-200.fc38.x86_64.img
options root=UUID=a7465ac8-7427-4c7b-a2f4-3b6dcb9fcfae ro resume=UUID=f17ebeb2-0767-4f7c-ba74-5ba3ed6acb92 rhgb quiet 
grub_users $grub_users
grub_arg --unrestricted
grub_class fedora
[root@fedora entries]# 

Pour une raison ou une autre, je veux ne pas utiliser blscfg. Donc dans /etc/defaults/grub je mets:

GRUB_ENABLE_BLSCFG=false

Ensuite je regénère grub.cfg avec la commande

[toto@fedora ~]$ sudo grub2-mkconfig -o /boot/grub2/grub.cfg

Tout va bien jusqu'au prochain changement de noyau:
catastrophe: kernel panic
Il faut alors booter sur le noyau précédent pour réparer les dégâts. Si j’examine grub.cfg, je constate que dans la commande linux qui permet de booter sur le nouveau noyau se trouve:
root=/dev/sdb5 (dans mon cas) au lieu de root=UUID=.....
Pour régler le problème, il suffit de régénérer grub.cfg comme précédemment. Il n'est même pas nécessaire de rebooter: on peut procéder dès que l'update est terminé.