uefi 是如何找到grubaa64.efi的

本文详细解析了UEFI环境下从BDS入口函数开始的启动流程,重点介绍了如何加载指定架构的启动文件,如AARCH64架构下从可移动媒体加载grubaa64.efi的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们使用的是intelframeworkmodule 这个包,因此bds的入口函数是在intelframeworkmodule/universal/bdsdxe/bsdentry.c其入口函数是BdsEntry
在BdsEntry->BdsBootDeviceSelect->BdsLibBootViaBootOption 这个函数中下面这段code
      Handle = BdsLibGetBootableHandle(DevicePath);
      if (Handle != NULL) {
        //
        // Load the default boot file \EFI\BOOT\boot{machinename}.EFI from removable Media
        //  machinename is ia32, ia64, x64, ...
        //
        FilePath = FileDevicePath (Handle, EFI_REMOVABLE_MEDIA_FILE_NAME);
        if (FilePath != NULL) {
          REPORT_STATUS_CODE (EFI_PROGRESS_CODE, PcdGet32 (PcdProgressCodeOsLoaderLoad));
          Status = gBS->LoadImage (
                          TRUE,
                          gImageHandle,
                          FilePath,
                          NULL,
                          0,
                          &ImageHandle
                          );
        }
      }
    }

这里的filepath是通过EFI_REMOVABLE_MEDIA_FILE_NAME 这个变量来找到的

#define EFI_REMOVABLE_MEDIA_FILE_NAME_IA32    L"\\EFI\\BOOT\\BOOTIA32.EFI"
#define EFI_REMOVABLE_MEDIA_FILE_NAME_IA64    L"\\EFI\\BOOT\\BOOTIA64.EFI"
#define EFI_REMOVABLE_MEDIA_FILE_NAME_X64     L"\\EFI\\BOOT\\BOOTX64.EFI"
#define EFI_REMOVABLE_MEDIA_FILE_NAME_ARM     L"\\EFI\\BOOT\\BOOTARM.EFI"
#define EFI_REMOVABLE_MEDIA_FILE_NAME_AARCH64 L"\\EFI\\GRUB2\\grubaa64.efi"

#if   defined (MDE_CPU_IA32)
  #define EFI_REMOVABLE_MEDIA_FILE_NAME   EFI_REMOVABLE_MEDIA_FILE_NAME_IA32
#elif defined (MDE_CPU_IPF)
  #define EFI_REMOVABLE_MEDIA_FILE_NAME   EFI_REMOVABLE_MEDIA_FILE_NAME_IA64
#elif defined (MDE_CPU_X64)
  #define EFI_REMOVABLE_MEDIA_FILE_NAME   EFI_REMOVABLE_MEDIA_FILE_NAME_X64
#elif defined (MDE_CPU_EBC)
#elif defined (MDE_CPU_ARM)
  #define EFI_REMOVABLE_MEDIA_FILE_NAME   EFI_REMOVABLE_MEDIA_FILE_NAME_ARM
#elif defined (MDE_CPU_AARCH64)
  #define EFI_REMOVABLE_MEDIA_FILE_NAME   EFI_REMOVABLE_MEDIA_FILE_NAME_AARCH64
#else
  #error Unknown Processor Type
#endif

由于我们是MDE_CPU_AARCH64,因此EFI_REMOVABLE_MEDIA_FILE_NAME 就等于L"\\EFI\\GRUB2\\grubaa64.efi"
因此在BdsLibBootViaBootOption 中通过gBS->LoadImage 来找到grubaa64.efi,最后还是在BdsLibBootViaBootOption 中通过下面的code  Status = gBS->StartImage (ImageHandle, ExitDataSize, ExitData);来跳转到grub的第一行代码。

### 通过PXE在UEFI模式下安装CentOS系统的指南 为了实现基于PXE的UEFI模式下的CentOS系统安装,需要完成以下几个方面的配置: #### 1. 安装必要的软件包 首先,在服务器上安装所需的软件包以支持DHCP、TFTP以及HTTP服务。这些工具分别负责IP地址分配、引导文件传输和操作系统镜像传输。 ```bash yum -y install dhcp tftp-server httpd syslinux xinetd grub2-efi ``` 上述命令会安装以下组件: - `dhcp`:动态主机配置协议(DHCP),用于向客户端分发IP地址和其他网络参数。 - `tftp-server`:简单文件传输协议(TFTP)服务器,用来传送启动所需的小型二进制文件。 - `httpd`:Apache HTTP Server,提供较大的ISO镜像或其他资源文件的服务。 - `syslinux` 和 `grub2-efi`:分别为BIOS和UEFI环境提供了不同的引导加载器选项[^2]。 #### 2. 配置 DHCP 服务 编辑 `/etc/dhcp/dhcpd.conf` 文件,定义子网范围并指明PXE客户机应使用的引导方式。对于UEFI设备来说,通常推荐使用GRUB EFI作为初始引导程序而不是传统的PXELINUX。 ```plaintext subnet 192.168.1.0 netmask 255.255.255.0 { range 192.168.1.100 192.168.1.200; option routers 192.168.1.1; option subnet-mask 255.255.255.0; if exists user-class and option user-class = "gPXE" { filename "http://<server-ip>/centos/7/os/x86_64/images/pxeboot/vmlinuz"; } else { match if substring(option vendor-class-identifier, 0, 3) = "PXE"; next-server <tftp-server-ip>; # For UEFI systems if option arch = 00:07 { # '07' indicates IA32_x86_64_EFI filename "/grubaa64.efi"; } # For BIOS systems elsif option arch = 00:00 { filename "pxelinux.0"; } } } ``` 此段脚本设置了针对不同架构类型的机器发送恰当的引导文件路径[^3]。 #### 3. 设置 TFTP 服务 确保`tftpd`已启用并且能够访问位于默认目录中的所有必要文件(如`grubaa64.efi`)。可以通过修改`/etc/xinetd.d/tftp`来确认这一点: ```ini service tftp { socket_type = dgram protocol = udp wait = yes user = root server = /usr/sbin/in.tftpd server_args = -s /var/lib/tftpboot disable = no # Set to 'no' } ``` 重启xinetd使更改生效:`systemctl restart xinetd`. 接着复制相应的引导文件至该位置: ```bash cp /usr/share/grub2/unicode.pf2 /var/lib/tftpboot/ cp /boot/efi/EFI/centos/grubaa64.efi /var/lib/tftpboot/ ``` #### 4. 创建 GRUB 菜单项 创建一个新的文本文件名为`grub.cfg`,放置于/var/www/html/(或者您所设定web根目录)/grub/,内容如下所示: ```cfg menuentry 'Install CentOS Linux 7' --class centos --class gnu-linux --class os { set background_color=black insmod efinet insmod gzio insmod part_gpt insmod ext2 search --set=root --file /images/pxeboot/vmlinuz linuxefi /images/pxeboot/vmlinuz inst.stage2=http://<your-http-server>/centos/7/os/x86_64/ ip=dhcp initrdefi /images/pxeboot/initrd.img } ``` 注意替换 `<your-http-server>` 成实际Web服务器地址. #### 5. 启动 Web 服务 最后一步就是开启apache web server以便远程下载iso image及其他大型数据集. ```bash systemctl start httpd.service systemctl enable httpd.service ``` 至此整个流程结束,当目标计算机从网络启动时它应该自动检测到可用的操作系统供选择安装。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值