Efibootmgr

The application interacts with the UEFI firmware on the system. It is a popular tool for manipulating the EFI settings in order to create and manage boot entries capable of booting Linux (or any other EFI operating system).

The application is not a bootloader. It is a tool that interacts with the EFI firmware of the system, which itself is acting as a bootloader. Using boot entries can be created, reshuffled, edited, and removed.

Kernel
CONFIG_EFI_VARS support needs to be enabled:

Emerge
The package does not have any USE flags. All that is needed is to install it:

EFI vars
In order to successfully use the EFI variables filesystem must be accessible. This requires that the system has been booted in EFI mode (and not through the firmware's MBR mode) as otherwise the EFI variables themselves cannot be accessed. If the system is in MBR mode, reboot and do what is necessary in order to tell the system firmware to boot in EFI mode. Usually this involved either changing an option in the firmware's settings or selecting an EFI boot entry in the system's boot menu.

When the system is in EFI mode, run the following command to check for the existence of efivarfs:

If it is not mounted (it should be mounted through the init script), it is possible to manually mount it using the following command:

Preconditions
In an EFI System Partition (ESP) does not exist one needs to be created, see EFI System Partition

Listing boot entries
To list the current boot entries by using the  option:

Creating a boot entry
To create an EFI boot entry, a couple of arguments are passed to :


 * to create a new entry;
 * followed by the partition number on which the EFI System Partition is hosted;
 * followed by the disk on which the EFI System Partition is hosted;
 * followed by the label to use as the boot entry;
 * followed by the path of the EFI image to boot

For instance:

Deleting a boot entry
Before deleting an entry, first figure out what ID the entry has.

To delete the Gentoo entry as shown above (which has Boot0002 as the identifier), ask to delete the entry with id 2, passing the arguments   with the identifier, and   to delete the entry: