UEFI之Basetools技巧总结

2024-05-29 03:48
文章标签 总结 技巧 uefi basetools

本文主要是介绍UEFI之Basetools技巧总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概要

在EDK2中没有编写Makefile的过程,终止是通过Basetools生成编译文件和Makefile的,但是在我们使用中总是感觉没有使用Makefile顺手,所以这里进行总结;

生成静态库进行编译

这个过程就是,我编译生成一个静态库.lib文件,然后提供别人或自己在以后的编译中使用,省去了重新编译的时间,也可以实现只提供静态库和.h给别人使用;

这里以OpensslLib.inf为例,由于OpensslLib编译非常的慢,所以我就将它做成了一个静态库;

[Defines]INF_VERSION                    = 0x00010005BASE_NAME                      = OpensslLibMODULE_UNI_FILE                = OpensslLib.uniFILE_GUID                      = C873A7D0-9824-409f-9B42-2C158B992E69MODULE_TYPE                    = BASEVERSION_STRING                 = 1.0LIBRARY_CLASS                  = OpensslLib
# DEFINE OPENSSL_FLAGS           = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE -DNO_SYSLOG[Binaries.MIPS64EL]Lib|OpensslLib.lib
[Binaries.LOONGARCH64]Lib|OpensslLib_LA.lib

Binaries就是指定静态库的,后面可以跟架构类型;下面指定静态库的位置和名字,在dsc文件中指定即可完成编译;如下:

OpensslLib                       | Capsule/Library/OpensslLib/OpensslLib.inf

类似的方法也可以将.efi添加进行编译;如下:

[Binaries.MIPS64EL]Efi|OpensslLib..efi

在inf指定头文件目录

正常思路是在dec中指定头文件的目录,但是有时我们的头文件不想所有文件都包含,因为那样会出现定义冲突,所以想在inf中指定include的路径,想法是在BuildOptions的FLAGS中添加,但是发现这个只能实现但.h 的添加,
GCC:*_*_LOONGARCH64_CC_FLAGS == -IInclude/Library会报错,无法进行编译;发现在编译Openssl时生成一个cc_resp.txt文件,里面都是编译中要链接的路径,不只是dec中指定的,但是也没有找到其他的地方;

现在的解决办法,添加一个单独的dec进行实现,如下:
Universal/Capsule/Capsule.dec

[Defines]DEC_SPECIFICATION              = 0x00010005PACKAGE_NAME                   = CryptoPkgPACKAGE_UNI_FILE               = CryptoPkg.uniPACKAGE_GUID                   = 36470E80-36F2-4ba0-8CC8-937C7D9FF888PACKAGE_VERSION                = 0.98[Includes]Include/BaseCryptLib[Includes.Common.Private]Library/OpensslLib/openssl/includeLibrary/OpensslLib/openssl/crypto/include[LibraryClasses]##  @libraryclass  Provides basic library functions for cryptographic primitives.##BaseCryptLib|Include/Library/BaseCryptLib.h

指定编译或链接对应的.h

在inf文件中

[BuildOptions]
GCC:*_*_LOONGARCH64_CC_FLAGS == -include Include/Library/BaseCryptLib.h

CC 是编译中使用
DLINK 是链接使用

FDF 中直接包含文件

  • 直接包含二进制文件
    在对应的Section 下添加如下内容
    !include AmiModulePkg/NVRAM/NvramFdfFileStatement.txt
    NvramFdfFileStatement.txt 内容如下:
 FILE RAW = CEF5B9A3-476D-497f-9FDC-E98143E0422C {$(OUTPUT_DIRECTORY)/Nvram.bin}
  • 直接包含文件
FILE RAW = 812136D3-4D3A-433A-9418-29BB9BF78F6E { # gEdkiiSystemFmpCapsuleConfigFileGuid
Universal/Capsule/SystemFirmwareUpdateConfig/SystemFirmwareUpdateConfig.ini
}

更多详细使用可以查看UEFI之FDF

驱动中的依赖

写驱动时在哪inf文件中必须包含[Depex],作用是指定依赖的服务或设备,如何没有,驱动是不加载的,输出如下:

Driver 4A9B9DB8-EC62-4A92-818F-8AA0246D246E was discovered but not loaded!!
Driver AE587172-CC15-48E1-8BE0-29DDF05C6A1F was discovered but not loaded!!
Driver 8F2C127E-117D-484B-8A44-FBD911BE125E was discovered but not loaded!!
Driver 129F6AA7-AB69-4CB8-AED1-40985001115E was discovered but not loaded!!
Driver BC0B9FB8-97CF-4B17-9A9E-F574E62CBCC4 was discovered but not loaded!!
Driver 43788BEB-638F-434C-8A84-46D33A589E76 was discovered but not loaded!!

想强制加载,如下:

[Depex]TRUE#gEfiDxeIpmiTransportProtocolGuid

这篇关于UEFI之Basetools技巧总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1012559

相关文章

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl

java常见报错及解决方案总结

《java常见报错及解决方案总结》:本文主要介绍Java编程中常见错误类型及示例,包括语法错误、空指针异常、数组下标越界、类型转换异常、文件未找到异常、除以零异常、非法线程操作异常、方法未定义异常... 目录1. 语法错误 (Syntax Errors)示例 1:解决方案:2. 空指针异常 (NullPoi

电脑报错cxcore100.dll丢失怎么办? 多种免费修复缺失的cxcore100.dll文件的技巧

《电脑报错cxcore100.dll丢失怎么办?多种免费修复缺失的cxcore100.dll文件的技巧》你是否也遇到过“由于找不到cxcore100.dll,无法继续执行代码,重新安装程序可能会解... 当电脑报错“cxcore100.dll未找到”时,这通常意味着系统无法找到或加载这编程个必要的动态链接库

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自