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

相关文章

电脑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()方法方法二:使用字符数组方法三:使用自

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触

Python依赖库的几种离线安装方法总结

《Python依赖库的几种离线安装方法总结》:本文主要介绍如何在Python中使用pip工具进行依赖库的安装和管理,包括如何导出和导入依赖包列表、如何下载和安装单个或多个库包及其依赖,以及如何指定... 目录前言一、如何copy一个python环境二、如何下载一个包及其依赖并安装三、如何导出requirem

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Apache伪静态(Rewrite).htaccess文件详解与配置技巧

《Apache伪静态(Rewrite).htaccess文件详解与配置技巧》Apache伪静态(Rewrite).htaccess是一个纯文本文件,它里面存放着Apache服务器配置相关的指令,主要的... 一、.htAccess的基本作用.htaccess是一个纯文本文件,它里面存放着Apache服务器

Spring中@Lazy注解的使用技巧与实例解析

《Spring中@Lazy注解的使用技巧与实例解析》@Lazy注解在Spring框架中用于延迟Bean的初始化,优化应用启动性能,它不仅适用于@Bean和@Component,还可以用于注入点,通过将... 目录一、@Lazy注解的作用(一)延迟Bean的初始化(二)与@Autowired结合使用二、实例解