UEFI
Поддержка UEFI в ALT Linux
В работе.
Результат
По состоянию на ноябрь 2012 доступен экспериментальный Live-образ, поддерживающий загрузку в EFI mode и Legacy mode, будучи записанным на CD/DVD-болванку или USB-флэшку. Проверен на ASUS/Gigabyte UEFI и MacBookPro EFI.
HOWTO
Приборы и материалы:
- свежий Sisyphus (в т.ч. xorriso 1.2.4+)
- syslinux 4.06 (task #83898)
- «простая» live-исошка (например, live-efi с нужными утилитами и live-install, но пока без EFI-загрузчика)
Действия от имени root (может быть удобно записать в скрипт):
cd ${TMP:-/tmp} apt-get install bsdtar dosfstools elilo syslinux xorriso rm -rf ISO mkdir ISO cd ISO wget -O - http://ftp.linux.kiev.ua/pub/Linux/ALT/people/mike/iso/mkimage-profiles/tmp/live-efi-20121107-x86_64.iso | bsdtar -xf - mkdir -p EFI/BOOT cp -a syslinux/alt0/{vmlinuz,full.cz} EFI/BOOT cp -a /usr/lib64/efi/elilo.efi EFI/BOOT/bootx64.efi cat > EFI/BOOT/elilo.conf << EOF prompt timeout="20" default="linux" image="vmlinuz" label="linux" read-only initrd=full.cz append="fastboot live lowmem showopts automatic=method:cdrom ramdisk_size=131072 stagename=live" EOF cd .. rm -rf EFIBOOT mkdir EFIBOOT dd if=/dev/zero of=efiboot.img bs=16384 count=1024 mkfs.vfat efiboot.img mount -o loop efiboot.img EFIBOOT cp -a ISO/EFI EFIBOOT wget -O EFIBOOT/shellx64.efi https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2/EdkShellBinPkg/FullShell/X64/Shell_Full.efi umount EFIBOOT mv efiboot.img ISO/EFI/ xorriso -as mkisofs -r -V ALT -isohybrid-mbr /usr/lib/syslinux/isohdpfx.bin \ -partition_offset 16 -J -l -b syslinux/isolinux.bin -c syslinux/boot.cat \ -no-emul-boot -boot-load-size 4 -boot-info-table -eltorito-alt-boot -e EFI/efiboot.img \ -no-emul-boot -isohybrid-gpt-basdat -o live-efi.iso ISO pwd echo rm -rf EFIBOOT ISO
Копия результата выполнения именно этого скрипта доступна здесь (116M).
Проверка
При загрузке в EFI-режиме загрузчиком будет текстовое ELILO, в BIOS-режиме -- синяя менюшка SYSLINUX; после собственно загрузки и логина именем root в EFI-режиме должны отработать команды modprobe efivars; efibootmgr, в BIOS-режиме вторая из них скажет
Fatal: Couldn't open either sysfs or procfs directories for accessing EFI variables. Try 'modprobe efivars' as root.
ВНИМАНИЕ: не пытайтесь запускать efibootmgr на оборудовании Apple, известны случаи повреждения его firmware таким образом.
Использование
В упомянутом образе есть скрипт live-install, подразумевающий ручную разбивку диска (которую следует осуществлять с помощью gdisk или parted, не забыв про FAT32 EFI System Partition). Не забудьте --no-lilo и конфигурирование вручную!
Linkdump
- http://www.rodsbooks.com/efi-bootloaders/index.html
- https://wiki.archlinux.org/index.php/UEFI
- http://www.linuxfoundation.org/news-media/blogs/browse/2012/10/linux-foundation-uefi-secure-boot-system-open-source
- http://en.opensuse.org/KVM/UEFI_Secure_boot_using_qemu-kvm
- http://www.suse.com/blogs/uefi-secure-boot-overview/
- http://www.suse.com/blogs/uefi-secure-boot-plan/
- http://www.suse.com/blogs/uefi-secure-boot-details/
- http://cdimage.debian.org/cdimage/unofficial/efi-development/upload4/
- https://help.ubuntu.com/community/UEFI
- https://wiki.archlinux.org/index.php/UEFI_Bootloaders
- https://felipec.wordpress.com/2012/01/18/efi-adventures/
- http://mjg59.dreamwidth.org/4957.html