Legacy BIOS boot 介绍及启动光盘制作
Legacy BIOS boot 介绍
首先了解一下 Legacy BIOS 如何启动或引导。当系统首次引导时,或系统被重置时,处理器会执行一个位于已知位置处的代码。这个位置在基本输入 / 输出系统(BIOS) 中,它保存在主板上的闪存中。CPU 会调用这个重置向量来启动一个位于闪存 /ROM 中的已知地址处的程序。通常,它执行一个启动自测(POST)来检查机器。最后,它从引导驱动器上的主引导记录(MBR)加载第一个扇区。
这时第一阶段的引导加载程序开始了。引导程序 boot loader 就位于 MBR 第一个扇区里面。此时 boot loader 就被装入 RAM 并执行。这个引导加载程序在大小上小于 512 字节(一个扇区),其作用是加载第二阶段的引导加载程序。
当第二阶段的引导加载程序被装入 RAM 并执行时,通常会显示一个动画屏幕,并将 Linux 和一个可选的初始 RAM 磁盘(临时根文件系统)加载到内存中。在加载映像时,第二阶段的引导加载程序就会将控制权交给内核映像,然后内核就可以进行解压和初始化了。在这个阶段 中,第二阶段的引导加载程序会检测系统硬件、枚举系统链接的硬件设备、挂载根设备,然后加载必要的内核模块。完成这些操作之后启动第一个用户空间程序(init),并执行高级系统初始化工作。
图 1. 开机过程示意图
制作支持 EFI 平台的启动光盘的步骤
ELILO 是一种基于 EFI 开发的 boot loader,而不是基于 BIOS 平台 , ELILO 允许用户在系统开机过程中自己选择哪个系统或内核,同时也支持用户传参数给内核。 ELILO 的配置文件,一般位于 EFI 启动分区。下面的实例就是将 elilo 作为 EFI 平台的 boot loader。
步骤一:配置 elilo.conf
EFI 文件从 Suse 11 SP1 的光盘中获得,路径是 /boot/x86_64/efi.
清单 4. 查看 efi 文件命令
mount -o loop /boot/x86_64/efi efiimg |
在 efiimg/efi/boot 文件下,可以看到如下四个文件:
bootx64.efi elilo.conf initrd linux |
如果需要按自己需求更改 efi 文件,自己定制 efi boot image 方法如下
首先需要按自己需求更改 elilo.conf 文件,比如我的配置如下:
清单 5. 配置 elilo.conf 文件
prompt timeout=80 default=myEFIiso image=img2au label=myEFIiso initrd=img3au append="vga=0x317 root=/dev/ram0 rw ramdisk_size=140000 \ debug_level=1 silent_boot=no boot_src=3 media_boot=no iommu=soft" |
参数详解如下:
prompt —设定默认行为为交互模式
timeout=tsecs — 设置在菜单到自动启动系统前的时间,单位是 1/10 秒。无论是选定了默认开机选项或者没有设定默认开机项目,当超时时间过后,第一个开机选项会被选中。
default=name — 设置默认开机选项,这个参数的值必须和 label 参数中的值匹配。如果没有设定默认开机选项,那么第一个开机选项将会被选中。
image=kernel — 设定 Linux 开机的内核,通常情况下是 vmlinuz 文件
label=name — 这个参数的值是设定为可以指向读取的开机选项
initrd=image — 指定 initrd 文件,用于初始化和启动 linux 内核。这个镜像文件通常位于 EFI 分区
root=diskptn —指定 mount 为磁盘根分区的目标文件
append="options" — 指定内核载入开机中传递给内核的参数
步骤二:定制 EFI 文件
当自己定制的 elilo.conf initrd linux 准备完毕后,在 RHEL6.0 或者更高版本 :
清单 6. 定制 EFI 文件
# dd if=/dev/zero of=efibootimg bs=1M count=36 # mkfs.vfat efibootimg # mkdir -p /mnt/loop # mount -o loop efibootimg /mnt/loop # mkdir -p /mnt/loop/efi/boot/ # cp efiimg/efi/boot/bootx64.efi /mnt/loop/efi/boot/bootx64.efi # cp img2au /mnt/loop/efi/boot/ # cp img3au /mnt/loop/efi/boot/ # cp efiimg/efi/elilo.conf /mnt/loop/efi/boot/ # umount /mnt/loop |
步骤三:制作 EFI 平台启动光盘
清单 7. 制作 EFI 平台启动光盘的命令
# genisoimage -e efibootimg -no-emul-boot -J -R -c boot.catalog \ -hide boot.catalog -hide efibootimg -o /tmp/testcdimage.iso . |
其中参数 -e FILE 是指定 EFI boot image
制作同时满足 EFI 平台和 BIOS 平台的引导要求的启动光盘
在准备完制作支持 EFI 平台的启动光盘所需文件后,将定制好的 efibootimg 放在需要打包成 iso 格式的文件根目录下,目录结构如下
清单 8. MyBIOSEFIiso 目录结构
|---isolinux | |---isolinux.bin | |---isolinux.cfg |---efibootimg |---kernel |---initrd |---readme |
清单 9. 制作同时满足 EFI 平台和 BIOS 平台的引导要求的启动光盘命令
# mkisofs -quiet -b isolinux/isolinux.bin -c boot.cat -no-emul-boot \ -boot-load-size 4 -boot-info-table -eltorito-alt-boot \ -e efibootimg -no-emul-boot -R -J -o /tmp/testcd.iso . |