ฉันพยายามจำลองสภาพแวดล้อม EFI โดยใช้ QEMU (kmv); virtualbox ใช้เวลา 15 นาทีในการบูตในโหมด EFI โดยใช้ archboot
การใช้โหมด BIOS ดั้งเดิมฉันสามารถบูตโดยใช้คำสั่งนี้:
root@citsnmaiko-deb:/home/maiko/uefi/ovmf# qemu-system-x86_64 -kernel ../bzImage -initrd ../rootfs.gz -append "rw root=/dev/ram0 ramdisk_size=40960"
และใช้งานได้กับเคอร์เนลและระบบไฟล์ที่กำหนดเองของฉัน
file ../bzImage
../bzImage: Linux kernel x86 boot executable bzImage, version 3.6.1 (root@citsnmaiko-deb) #4 , RO-rootFS, swap_dev 0x3, Normal VGA
มันก็รองรับ EFI ด้วย
ฉันพยายามทำสิ่งเดียวกันกับไฟล์ EFI ที่ฉันดาวน์โหลดมาจากที่นี่
wget http://ufpr.dl.sourceforge.net/project/edk2/OVMF/OVMF-X64-r11337-alpha.zip -P ovmf
cd ovmf/
unzip -x OVMF-X64-r11337-alpha.zip
# rename the files for QEMU find them
mv OVMF.fd bios.bin
mv CirrusLogic5446.rom vgabios-cirrus.bin
# start QEMU
root@citsnmaiko-deb:/home/maiko/uefi/ovmf# qemu-system-x86_64 -L . -kernel ../bzImage -initrd ../rootfs.gz -append "rw root=/dev/ram0 ramdisk_size=40960"
Could not open option rom 'linuxboot.bin': No such file or directory
pci_add_option_rom: failed to find romfile "pxe-e1000.bin"
และฉันตกหล่นในเปลือก EFI ไม่สามารถเปิดใช้งานการบูต
ถ้าฉันใช้ Ubuntu รุ่นล่าสุดโดยใช้สภาพแวดล้อม EFI เดียวกัน
root@citsnmaiko-deb:/home/maiko/uefi/ovmf# qemu-system-x86_64 -L . -boot d -cdrom ../ubuntu-12.10-desktop-amd64.iso
pci_add_option_rom: failed to find romfile "pxe-e1000.bin"
... กระบวนการบูตทำงานได้ดี
ฉันพยายามแทนที่ไฟล์บูต Ubuntu ด้วยของฉัน แต่บางทีฉันก็ไม่เข้าใจการทำงานของมันอย่างสมบูรณ์ เมื่อฉันเพิ่งแทนที่ไฟล์หลังจากติดตั้ง ISO:
mkdir tmp
bsdtar xf ubuntu-12.10-desktop-amd64.iso -C tmp
cp bzImage tmp/casper/vmlinuz
cp rootfs.gz tmp/casper/initrd.lz
genisoimage -o customUbuntu.iso tmp/
qemu-system-x86_64 -L . -boot d -cdrom customUbuntu.iso
เชลล์ EFI เดียวกันจะปรากฏขึ้น มันโอเคไหม initrd.lz และ rootfs.gz นั้นใช้แทนกันได้ไหม? แล้ว bzImage และ vmlinuz ล่ะ?
ฉันพลาดอะไรไป