1 基本概念及用法
FD:固件设备,指任何可以存储固件的设备或设备的集合,它存储代码和数据。
FV:固件卷,指在FD上一个连续的部分,我们可以把它看成一个逻辑设备,因为我们代码真正操作的是FV,而非FD。我们经常提到的FFS的概念也是以FV的形式存在,它描述了FV中的文件组织方式。FV之于FD,类似于thread之于package。
FF:固件文件,指在FV中组织代码和数据的一个集合。我们在PEI和DXE阶段都要Dispatch Modules,这个Modules指的就是FF。
1.1 如何找FF
要想找到FF,首先要找到FV,然后在FV中搜索是否有这个FF存在。我们来看一下DxeLoad中,如何找到Dxe Core的入口函数。
路径:mdemodulepkg\core\dxeiplpeim\dxeload.c(udk2014)
EFI_PEI_FILE_HANDLE
DxeIplFindDxeCore (
VOID
)
{
EFI_STATUS Status;
UINTN Instance;
EFI_PEI_FV_HANDLE VolumeHandle;
EFI_PEI_FILE_HANDLE FileHandle;
Instance = 0;
while (TRUE) {