mirror of
https://pagure.io/fedora-docs/quick-docs.git
synced 2024-12-01 07:39:48 +00:00
122 lines
3.6 KiB
Text
122 lines
3.6 KiB
Text
[[installing-grub-2-configuration-on-uefi-system]]
|
|
= Installing GRUB2 on a UEFI system
|
|
|
|
Normally, *GRUB2* will be installed and set up by the installer, *Anaconda*, during the installation process. You will probably never have to deal with manual installation of *GRUB2*. However, in certain situations , you will want to install *GRUB2* manually, especially if you need to repair the existing *GRUB2* installation or you want to change its configuration.
|
|
|
|
This procedure shows the steps to install *GRUB2* on a UEFI system on Fedora 18 or newer. The procedure consists of four parts.
|
|
|
|
[[create-an-esp]]
|
|
== Creating an EFI System Partition
|
|
|
|
The UEFI firmware requires to boot from an _EFI System Partition_ on
|
|
a disk with a GPT label. To create such a partition:
|
|
|
|
. List available block devices to find a place to create your ESP.
|
|
+
|
|
----
|
|
$ lsblk
|
|
----
|
|
|
|
. Create at least a 128 MiB disk partition using a GPT label on the primary hard disk.
|
|
+
|
|
----
|
|
# gdisk /dev/sda
|
|
----
|
|
+
|
|
For the sake of this procedure, we assume that the created partition is recognized as `/dev/sda1`.
|
|
|
|
. Format the partition with the _FAT32_ file system.
|
|
+
|
|
----
|
|
# mkfs.vfat /dev/sda1
|
|
----
|
|
|
|
. Create the `/boot/efi` directory as a mount point for the new partition.
|
|
+
|
|
----
|
|
# mkdir /boot/efi
|
|
----
|
|
|
|
. Mount the partition to the `/boot/efi` mount point.
|
|
+
|
|
----
|
|
# mount /dev/sda1 /boot/efi
|
|
----
|
|
|
|
. Proceed to the next part.
|
|
|
|
|
|
[[install-the-bootloader-files]]
|
|
== Install the bootloader files
|
|
|
|
In order to use *GRUB2* with on the UEFI systems, you need to install or re-install appropriate packages:
|
|
|
|
|
|
. Re-install the necessary packages.
|
|
+
|
|
----
|
|
# dnf reinstall grub2-efi grub2-efi-modules shim
|
|
----
|
|
|
|
. If the above command ends with an error, install the packages.
|
|
+
|
|
----
|
|
# dnf install grub2-efi grub2-efi-modules shim
|
|
----
|
|
|
|
.More information
|
|
|
|
* This installs the signed *shim* and the *GRUB2* binary.
|
|
|
|
|
|
[[create-a-grub-2-configuration]]
|
|
== Create a GRUB2 configuration
|
|
|
|
|
|
If you already have a working *GRUB2* EFI configuration file, you do not need to do anything else.
|
|
|
|
Otherwise, create the configuration file using the `grub2-mkconfig` command.
|
|
|
|
----
|
|
# grub2-mkconfig -o /boot/efi/EFI/fedora/grub.cfg
|
|
----
|
|
|
|
.More information
|
|
|
|
* Under EFI, *GRUB2* looks for its configuration in `/boot/efi/EFI/fedora/grub.cfg`.
|
|
* For newly installed kernels to work, `grubby` expects `/etc/grub2-efi.cfg` to be a symlink to the real grub.cfg (for example `/boot/efi/EFI/fedora/grub.cfg`).
|
|
|
|
|
|
[[solving-problems-with-uefi-bootloader]]
|
|
== Solving problems with UEFI bootloader
|
|
|
|
When you power on your system, your firmware will look for EFI variables that tell it how to boot. On running systems, which have booted into the EFI mode and their EFI runtime services are working correctly, you can configure your boot menu with `efibootmgr`.
|
|
|
|
If not, `shim` can help you bootstrap. The EFI program `/boot/efi/EFI/BOOT/fallback.efi` will look for files called `BOOT.CSV` in your ESP and will add boot entries corresponding to them. The `shim` command provides its own `BOOT.CSV` file that will add an entry for `grub2-efi`.
|
|
|
|
During the boot process, you can use the *EFI Shell* to invoke the `fallback.efi` profile to boot the system:
|
|
|
|
. Enter the boot partition.
|
|
+
|
|
----
|
|
> fs0:
|
|
----
|
|
|
|
. Navigate into the `EFI\BOOT` directory.
|
|
+
|
|
----
|
|
> cd EFI\BOOT
|
|
----
|
|
|
|
. Invoke the `fallback.efi` profile.
|
|
+
|
|
----
|
|
> fallback.efi
|
|
----
|
|
|
|
.More information
|
|
|
|
* If you have no boot entries at all, then just booting off your disk in UEFI mode should automatically invoke `/boot/efi/EFI/BOOT/BOOTX64.EFI`, which will, in turn, invoke `fallback.efi`.
|
|
|
|
* If you already have incorrect boot entries, you'll either need to delete them or to modify `BOOT.CSV` to create new entries with different names.
|
|
|