UEFI概念龟速学习:服务和驱动

UEFI服务

UEFI用驱动的形式提供服务,因为只有驱动才能常驻内存(应用程序不行),这种驱动称之为服务型驱动

驱动分2种,UEFI驱动模型驱动 和 DXE驱动。服务采用DXE驱动的方式开发

服务的开发分3步:

1. 服务接口的设计

2. 服务接口的实现

3. 服务驱动入口函数中gBS->InstallProtocolInterface,将Protocol的实例安装到自身Handle上


UEFI驱动

驱动的驱动服务部分:

1. Protocol头文件中定义一个Protocol(EFI_XXX_PROTOCOL),包括GUID,成员函数和变量的签名

2. 驱动程序源文件中定义私有数据(XXX_PRIVATE_DATA),包括Protocol和相关信息

     这里Protocol接口的实现要触及硬件设备(寄存器)

驱动的框架部分:

1. 实现EFI_DRIVER_BINDING_PROTOCOL的三个服务Supported、Start和Stop

     Start服务负责为私有数据分配内存、初始化私有数据,并在ControllerHandle上安装协议(InstallProtocolInterface)

2. 实现Component Name Protocol和Component Name2 Protocol

3. 模块入口函数中安装EDBP,ECNP,ECN2P(EfiLibInstallDriverBindingComponentName2)到Image Handle


 

你可能感兴趣的:(UEFI)