UEFI 原理与编程 1 - UEFI开发环境EDK2搭建

概述

不同的厂商对UEFI有不同的实现,一种常见的开源实现是EDK2。EDK2是一个遵循UEFI标准和PI标准的跨平台固件开发环境。

EDK2支持多种操作系统,并且支持跨平台编译。

在Windows下配置开发环境之前,我曾尝试在物理机的Win10上进行安装,但经过一天的努力也没能成功配置环境,包括尝试使用WSL也都以失败告终。这一次,我直接在Win7的虚拟机上进行安装。

安装开发工具

  1. 安装VS 2015(VS2017也可以使用,但VS2015的文件相对较小。VS2019在2018年的EDK2中不受支持,尽管2019年的EDK2有支持,但由于进行了大量修改,网络上没有相应的教程)。微软的官方下载链接隐藏得比较深,可以参考这篇文章:https://www./link/4b929e1af82b7db73f9138d685a4ed68 .NET Framework 4.6.1。

  2. 安装Python2.7:https://www./link/0b214389fac101bf39d422494db14302\。

  3. 下载IASL编译器:https://www./link/a10118110deab18a25a4a3cb5cae6bb5。

  4. 下载NASM:https://www./link/fd6b4b8075b32ba75ffe0c9694d2f9af)。

  5. 下载Openssl:https://www./link/eb5c505e43f84a12f3e8340a2b679567。

  6. 下载edk2开发包并解压:https://www./link/928d86171c65a039d2eb1789fd1bf49f。

此时,根目录下应该有以下文件:

  1. 生成OPENSSL加密库。从https://github.com/openssl/openssl/archive/OpenSSL_1_1_0g.zip下载,解压到edk2\CryptoPkg\Library\OpensslLib中,并重命名为openssl。

  1. 预搭建base tools。从https://github.com/tianocore/edk2-BaseTools-win32下载并解压到edk2\BaseTools\Bin,并重命名为Win32。忽略此步骤会在接下来的搭建中遇到报错环境变量PYTHON_HOME的问题。

配置EDK2开发环境

cd .\edk2\
.\edksetup.bat

执行上述命令后,会在Conf目录下生成target.txt等文件。

编辑target.txt。将第60行修改为TOOL_CHAIN_TAG = VS2015,并检查tools_def.txt,确保编译器路径正确。

编译UEFI模拟器和UEFI工程

  1. 编译UEFI模拟器
edksetup.bat rebuild
edksetup.bat --nt32
build

执行上述命令后,会看到构建成功。

该过程可能会出现脚本在C:\Program Files\下寻找Windows Kits的情况,但通常Windows Kits位于C:\Program Files (x86)\下,而C:\Program Files\中没有此文件夹,因此会导致报错。此时,可以以管理员身份执行以下命令创建一个软链接:

mklink /j "C:\Program Files\Windows Kits" "C:\Program Files (x86)\Windows Kits"

之后:

build run