【续行符源码】【资源分享模板源码】【互联主机源码下载】efi 源码

2025-01-01 12:33:30 来源:c解析json 源码 分类:休闲

1.编译BOOT.EFI总结
2.UEFI开发探索97 – EDK2模拟器搭建网络环境
3.UEFI之edk2 目录说明
4.UEFI开发探索43 – Protocol的使用2

efi 源码

编译BOOT.EFI总结

       编译loongnix1.0系统中的BOOTMIPS.EFI指南

       一、解压源码包

       二、应用压缩包中的补丁到源代码中

       三、运行配置脚本

       四、开始编译过程

       五、安装编译工具

       六、续行符源码生成启动镜像BOOT.EFI

       UEFI启动主要通过 /boot/EFI/BOOT/xxxx.EFI 来启动grub引导。而BOOTMIPS.EFI后跟的命令模块可以根据个人需求进行自定义添加。

       七、将文件复制到指定位置

       重启后,即可利用新编译的BOOTMIPS.EFI引导启动内核。

       若欲获取更多相关信息,可关注公众号。

UEFI开发探索 – EDK2模拟器搭建网络环境

       搭建EDK2开发环境与网络测试环境的详细步骤如下:

       1. 搭建环境:

       安装必要的开发工具:Visual Studio、Python、ASL和Nasm。

       下载EDK2和StdLib代码库,使用Git将代码下载到本地。

       在C盘新建目录edk,使用特定命令下载代码库。

       更新子模块,资源分享模板源码确保所有依赖库均可用。

       复制AppPkg、StdLib和StdLibPrivateInternalFiles到edk2目录,方便后续编译。

       使用Visual Studio的Native命令行编译BaseTools及其他工具。

       测试开发环境,通过检查编译结果是否成功。

       2. 搭建网络测试环境:

       安装Winpcap,用于在模拟器中提供访问网络底层的能力。

       下载并编译SnpNtIo,获取SnpNtIo.dll。

       在C盘创建NetNtIo文件夹,将源代码和Winpcap开发包放入其中。

       使用Visual Studio命令行编译SnpNtIo,生成Release_IA目录。

       编译位EDK2模拟器。

       配置模拟器网络环境,将SnpNtIo.dll复制到模拟器目录,并创建批处理文件loadnetwork.nsh加载相关驱动。

       启动模拟器并加载网络配置。互联主机源码下载

       3. 测试网络程序:

       使用已编译的EchoServerTCP4.exe和EchoTcp4.efi进行网络通信测试。

       运行服务器程序于宿主机,客户端程序于模拟器。

       使用网络调试助手辅助测试。

       注意防火墙设置、DHCP配置及网络通信的局域网限制。

       搭建完毕后,可进行网络程序测试,以验证环境搭建的正确性。遇到的问题包括防火墙影响、DHCP配置的不稳定性、服务端软件通信限制等,可参照实验记录和提供资源进行进一步分析与解决。

UEFI之edk2 目录说明

       UEFI之edk2:探索核心组件与功能目录

AppPkg:开发者的乐园

       UEFI Application Development Kit (AppPkg) 是一套全面的工具集,旨在降低UEFI应用程序开发的门槛。它包含标准依赖库、实用工具和示范项目,助力高效开发。

MdePkg:模块开发的基础

       MdePkg,全称为Module Development Environment Package,es7202源码是所有模块开发的基石。所有模块都依赖于此,它提供了模块开发所需的最小环境,并确保模块间的兼容性。

MdeModulePkg:标准与环境的载体

       MdeModulePkg不仅包含了符合UEFI/PI工业标准的模块,还提供开发环境,包括PPIs(Protocol Providers Interfaces)、PROTOCOLs(协议)和GUIDs(全局唯一标识符),以及必要的依赖库。

ArmPkg与ArmPlatformPkg:ARM架构的力量

       ArmPkg提供了ARM架构特有的PROTOCOLs,为ARM平台通用代码提供支持。ArmPlatformPkg则针对ARM开发板,集成通用组件,方便不同板型之间的移植。

从BaseTools到实战

       BaseTools包内含一系列编译工具,如AutoGen、Build等,为EDK和EDK2的构建提供必需的辅助。比如,GenSec、android会员页面源码GenFV等工具助力安全和固件生成。

BeagleBoardPkg:入门开发者的友好选择

       BeagleBoardPkg针对BeagleBoard,这是一款经济实惠的开发板,搭载了Cortex-A8处理器。包内包含对这款板子的定制化支持代码,便于开发者快速上手。

CorebootModulePkg:连接硬件与UEFI的桥梁

       CorebootModulePkg让Coreboot与UEFI标准融合,开发者可以借此轻松从Coreboot环境过渡到UEFI。它包括解析Coreboot表单、内存/IO资源报告等关键模块,位于硬件和UEFI环境的中间层。

CryptoPkg:加密防护的守护者

       CryptoPkg在UEFI 2.2版本后加入了安全特性,专为加密支持而设计,确保HLOS和平台固件间的通信安全可靠。

DuetPkg:模拟UEFI环境的开发助手

       DuetPkg是一款UEFI模拟器,基于Legacy BIOS,让开发者在BIOS环境中也能体验到UEFI的模拟环境,便于传统系统上的UEFI开发。

EdkCompatibilityPkg:跨代框架的兼容保证

       EdkCompatibilityPkg确保UEFI 2.0+ Framework 0.9x模式下的EDK编译兼容性,简化了不同版本的整合工作。

Shell世界的变化:EdkShellPkg与Shell 2.x

       EdkShellPkg和EdkShellBinPkg曾是Shell开发的主导,但已被Shell 2.x版本的包所取代,后者提供了官方的UEFI Shell实现。

EmbeddedPkg:内存映射控制器的协议实现

       EmbeddedPkg专为内存映射控制器提供协议支持,同时包含一个简单的EFI shell(EBL),简化开发流程。

EmulatorPkg:跨平台虚拟环境的革新

       EmulatorPkg作为虚拟环境的替代,取代了NtPkg和UnixPkg,支持跨平台编译和运行,提高开发的灵活性。

NtPkg与UnixPkg:逐渐式微的虚拟器

       NtPkg和UnixPkg作为UEFI在特定环境下的虚拟器,已被EmulatorPkg全面超越,不再推荐使用。

OvmfPkg:虚拟机的UEFI引导者

       OVMF Package (OvmfPkg) 提供对虚拟机的UEFI支持,配合QEMU和KVM,能引导HLOS在虚拟环境中运行。

NetworkPkg:网络功能的全方位支持

       NetworkPkg包含IPv6协议栈、IPsec驱动、PXE驱动和iSCSI驱动,以及网络配置相关的shell应用程序,为UEFI环境提供全面的网络服务。

Texas Instrument专有:OmapxxPkg

       OmapxxPkg是专为Texas Instrument OMAPxx平台设计的支持包,针对特定硬件的优化集成。

OptionRomPkg:PCI兼容Option ROM的支持

       OptionRomPkg是为了编译和加载PCI兼容Option ROM image而设计的,确保硬件扩展的兼容性。

SecurityPkg:强化安全特性

       SecurityPkg包含TPM(Trusted Platform Module)、用户身份验证、安全启动和认证变量等关键安全功能,为UEFI环境提供强大的防护。

StdLib与私有文件:标准库的基石

       StdLib是标准库的实现,而StdLibPrivateInternalFiles是其内部使用的专有包,仅限于StdLib内部引用。

UefiCpuPkg:CPU模块与库的UEFI兼容性

       UefiCpuPkg确保CPU模块和库与UEFI规范保持一致,为不同处理器架构提供支持。

SourceLevelDebugPkg:调试能力的提升

       SourceLevelDebugPkg提供强大的调试工具,帮助开发者深入到源代码层面进行问题排查和优化。

SignedCapsulePkg:安全升级与恢复的关键

       SignedCapsulePkg提供了一套签名和校验方案,确保固件更新的安全性和可恢复性,支持UEFI环境下的安全升级与恢复。

PcAtChipsetPkg:符合PcAt标准的接口实现

       PcAtChipsetPkg为符合PcAt标准的芯片组提供接口和实现,确保兼容性和稳定性。

FatPkg与FatBinPkg:FAT文件系统的支持

       FatPkg和FatBinPkg为UEFI环境下的FAT文件系统提供支持,方便数据存储和管理。

UEFI开发探索 – Protocol的使用2

       今天探索如何开发UEFI服务中的Protocol。在《UEFI原理与编程》一书中,已有关于UEFI服务开发的介绍,以视频解码为例,提供了完整的解码库。考虑到视频解码的兴趣不高,我将构建一个用于在屏幕上绘制几何图形的简单框架型代码,以熟悉Protocol开发。

       UEFI驱动大致分为两类:符合UEFI驱动模型的驱动和不遵循UEFI驱动模型的驱动。服务型驱动不管理设备,产生协议,初始化操作后即从系统内存中卸载;初始化驱动不产生任何句柄,仅进行初始化并返回错误代码;根桥驱动产生句柄,包含设备路径协议和I/O资源抽象协议;UEFI驱动模型驱动包含多个句柄、协议实例,支持子句柄和额外I/O协议。

       服务型驱动作为开发Protocol的起点,比较简单,主要用于生产协议。实例包括AcpiTableDxe、DebugSupportDxe等。这类驱动在模块初始化时安装所需协议。以HiiResourcesSampleDxe为基础,构建了一个服务型驱动框架,修改了*.inf文件,调整为UEFI_DRIVER类型,并加入UefiDriverEntryPoint。构建好Protocol后,在驱动入口函数中安装。

       构建Protocol需准备三个部分:Protocol GUID(使用微软工具或在线生成)、协议成员函数与结构体、实例化协议。成员函数需EFIAPI修饰,第一个参数为This指针。构造好的Protocol源代码展示了其结构。可以通过This指针传递内部私有数据,实现函数间的共享。

       为了测试,编写了服务驱动提供Protocol与测试程序。服务驱动中提供的Protocol包含三个成员函数,用于演示。通过命令加载服务驱动并测试协议,结果验证了自定义Protocol的正确性。

       具体实现与测试代码在文末提供下载链接。服务驱动中提供的Protocol具有简单的打印功能,用于展示。测试结果显示,安装自制协议后,测试程序能正确调用成员函数。

       Gitee项目地址:gitee.com/luobing/u...,项目代码位于FF RobinPkg下的Applications目录和Drivers目录,包括TestServiceDrvSample和ServiceDrvSample。

本文地址:http://j5.net.cn/html/33c938290584.html 欢迎转发