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