UEFI模塊認知

目錄

包與模塊

工具鏈

模塊類型

模塊工程文件inf

標準應用程序模塊

標準應用程序模塊編譯

標準應用程序模塊編譯加載過程

UEFI驅動模塊類型


包與模塊

包(Package).是一組模塊及平臺描述文件(.dsc文件)、包聲明文件(.dec文件)則、組成的集合,多在以*pkg命名的文件夾中,一般也稱這樣的文件夾爲一個包。
模塊(Module)是UEFI系統的一個特色。模塊(可執行文件,即.efi文件)像插件一樣可以動態地加載到UEFI內核中。對應到源文件,EDK2中的每個工程模塊由元數據文件(.inf)和源文件(有些情況也可以包含.efi文件)組成。

 

工具鏈

 

模塊類型

模塊工程文件inf

 

標準應用程序模塊

標準應用程序模塊編譯

編譯過程:main.c  ___編譯器____>  main.obj  ___連接器____>  main.dll ___GenFw____> main.efi

 

標準應用程序模塊編譯加載過程

InternalShellExecuteDevicePath()   +ShellPkg/Application/Shell/ShellProtocol.c

  • Shell使用gBs->LoadImage()將main.efi文件加載到內存生成Image對象。
  • 使用gBs->StartImage()找到Image的入口函數並執行它,啓動Image對象。

CoreStartImage()   +MdeModulePkg/Core/Dxe/Image/Image.c

  • SetJump/LongJump爲程序的執行提供錯誤處理機制
  • Image->EntryPoint()進入到程序Image的入口地址(_ModuleEntryPoint)。控制權才交給程序

_ModuleEntryPoint  +/MdePkg/Library/UefiApplicationEntryPoint/ApplicationEntryPoint.c

  • 調用模塊的入口函數ProcessLibraryDestructorList()

 

UEFI驅動模塊類型

  • UEFI驅動:UEFI_DRIVER
  • DXE驅動:DXE__DRIVER/DXE_SAL_DRIVER/DXE_SMM_DRIVER/DXE_RUNTIME_DRIVER

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章