rEFInd
rEFInd provides a graphical boot menu for UEFI systems, that allows to boot operating systems that are found on the available partitions.
Installation
As of now, refind is available in the testing repository. It can be safely installed by following the guidelines.
The below command installs the alpine-linux rEFInd package:
# apk add refind@testing
Configuration
rEFInd's refind-install script creates a sample file /boot/refind_linux.conf.
# refind-install
The above steps should be sufficient for most cases to start using rEFInd as boot loader. A sample /boot/refind_linux.conf from rEFInd website for a system with ext4 filesystem is given below:
Contents of /boot/refind_linux.conf
This sample file defines three entries:
- The first entry uses options derived from the contents of /proc/cmdline when the script was run, unless the script was run from an emergency system, in which case refind-install tries to translate from options in /etc/default/grub.
- The second entry provides the same boot options as the first, but adds single, which causes most distributions to boot into a single-user maintenance mode.
- The final entry subtracts most options from the list, leaving only ro root=rootfs, where rootfs is the identified root (/) filesystem. This option may not be bootable on some systems that need unusual options, but if it does boot, it will normally do so with verbose startup messages, which can be helpful when debugging boot problems.
Given below is a sample /boot/refind_linux.conf created automatically by rEFInd for a system with Btrfs filesystem whose layout is given further below as blkid
output:
Contents of /boot/refind_linux.conf
Output of blkid
from Busybox is given below.
/dev/sda4: LABEL="_SWAP_" UUID="33899521-599f-458e-9bfe-f4b59254eb7c" TYPE="swap" /dev/sda3: LABEL="_SYS0_" UUID="aafbf6b0-7d54-4222-a3dd-a8f45c0ac607" TYPE="btrfs" /dev/sda1: LABEL="_BOOT_" UUID="6771-DB5C" TYPE="vfat"
The single-user mode and minimal options does not work in Alpine Linux for Btrfs filesystem as per user u/Xerotras in https://redd.it/1hbog74

Proceed to Manual configuration only if rebooting did not result in rEFInd appearing as boot loader.
Manual configuration
And a first (default) boot menu line needs to be configured with Alpine's default boot parameters. Assuming the bootable partition is mounted at /media/sdXY it can be done like this (at time of writing):
# echo '"Alpine" "modules=loop,squashfs,sd-mod,usb-storage quiet initrd=\boot\intel-ucode.img initrd=\boot\amd-ucode.img initrd=\boot\initramfs-lts"' > /media/sdXY/boot/refind_linux.conf
The path in the config file needs to be relative to the partition that the kernel resides on. If /boot resides on its own separate partition, then
\boot
needs to be removed from the paths.There is also a second config file, refind.conf which is located inside the EFI partition. The config file is self-explanatory and has to be manually edited. Refer refind website for additional information.
The below instructions assume esp partition is mounted as shown:
Contents of /etc/fstab
If your setup is different from above, adjust the path in below files accordingly.
For default alpine sys mode installation, a sample refind.conf to dual boot Alpine Linux and windows will be:
Contents of /boot/efi/EFI/refind/refind.conf
If you use btrfs filesystem, for the above /etc/fstab setup, the necessary boot entry for Alpine Linux is as follows:
Contents of /boot/efi/EFI/refind/refind.conf
Troubleshooting
Invalid loader file
starting vmlinux-lts using load options options 'root=UUID=823a3283-30a7-4fef-b50b-8a2230c71b5b rw rootflags=subvol=@alpine rootfstype=btrfs initrd=@alpine\boot\initramfs-lts' Invalid loader file! Error:Not found while loading vmlinuz-lts
If Btrfs filesystem is used, the above error is caused by missing drivers. Ensure that driver file btrfs_x64.efi
is copied from /usr/share/refind/drivers_x86_64/btrfs_x64.efi to the appropriate folder in efi partition for e.g /boot/efi/EFI/refind/drivers_x64/