UEFI: 模块和包概述

UEFI规范中有两个最重要的概念:模块(Module)和包(Package)。

模块 Module

UEFI上最小的可单独编译的代码单元,或者是预编译的二进制文件比如efi执行文件。

包 Package

由模块、平台描述文件(DSC)和包声明文件(DEC)组成。可以包含模块,也可以不包含。例如前面用来做实验的MdeModulePkg和EmulatorPkg。

如果把包和Vistual Studio的工程相比,DSC相当于sln文件,描述多个project的信息;INF文件类似于某个project的proj文件,描述工程本身的信息,比如用到的库、源码位置等信息。

常见模块类型:

UEFI_DRIVER, UEFI_APPLICATION, PEI_CORE, PEIM, DXE_CORE, DXE_DRIVER等。对于非BIOS工程师来说,由于没有真实环境,所以涉及的是UEFI_APPLICATION和UEFI_DRIVER这两个。

关于UEFI_APPLICATION的补充:由三个类型:

1. UefiMain入口

可运行于DXE阶段和UEFI Shell环境

2. ShellAppMain入口

可运行于UEFI Shell环境

3. main入口

可以运行于UEFI Shell环境,它是用C标准库StdLib写的

参考:《UEFI编程实践》 罗冰

相关推荐
Petal9909127 天前
UEFI学习笔记(十八):ARM电源管理之PSCI和SCMI概述
arm开发·笔记·学习·uefi
修行者xxl10 天前
UEFI Shell命令(二)
shell·uefi
Petal9909121 个月前
UEFI学习笔记(十一):SMBIOS的概述与访问
笔记·学习·uefi
Petal9909122 个月前
UEFI学习笔记(十):系统表与ACPI表的遍历
笔记·学习·uefi
Petal9909122 个月前
UEFI学习笔记(五):EDK II PCD的概念、类型、使用
笔记·学习·uefi
Petal9909122 个月前
UEFI学习笔记(四):inf、dec和dsc
笔记·学习·uefi
Petal9909122 个月前
UEFI学习笔记(三):FDF文件及FD、FV、FFS
笔记·uefi
修行者xxl3 个月前
UEFI基础概念1——EFI SYSTEM TABLE
uefi·bios
修行者xxl3 个月前
UEFI开发——编写一个简单的PPI
uefi
修行者xxl3 个月前
标准UEFI Shell命令
shell·uefi