搭建edk2编译环境

简介: 搭建edk2编译环境

参考

作者

pengdonglin137@163.com

概述

在Ubuntu中安装ubuntu18.04的容器环境,在其中搭建编译和开发环境,支持运行UEFI模拟器。

步骤

安装docker

下载容器镜像

$ sudo docker pull ubuntu:18.04

启动容器

#!/bin/bash
sudo docker run -it -d --name edk2 -v $PWD:/root/work/ \
        -v /tmp/.X11-unix:/tmp/.X11-unix -e DISPLAY=$DISPLAY \
        -p 9090:22 \
        ubuntu:18.04

端口映射是为了后面ssh登录准备,X11以及DISPLAY是为了后面在容器里面启动模拟器准备

登录容器

$ sudo docker exec -it <container id> /bin/bash

配置软件源

# 备份容器中的原始软件源
root@97be60d27afa:/etc/apt# cp sources.list sources.list.bak
# 由于容器里没有编辑工具,可以将sources.list拷贝到共享目录下,然后在host上编辑,然后替换
root@97be60d27afa:~/work# cp /etc/apt/sources.list .
# 使用阿里云的软件源
deb http://mirrors.aliyun.com/ubuntu/ bionic main restricted
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates main restricted
deb http://mirrors.aliyun.com/ubuntu/ bionic universe
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates universe
deb http://mirrors.aliyun.com/ubuntu/ bionic multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-updates multiverse
deb http://mirrors.aliyun.com/ubuntu/ bionic-backports main restricted universe multiverse
# 替换
root@97be60d27afa:~/work# cp sources.list  /etc/apt/
# 更新
root@97be60d27afa:~/work# apt update

安装必备的软件包

下面这些软件包需要安装:

apt install vim git python3 python3-distutils uuid-dev nasm flex bison build-essential openssh-server

其余的后面编译报错时再安装

下载edk2仓库

# mkdir UEFIWorkspace
# cd UEFIWorkspace/
# git clone https://github.com/tianocore/edk2.git
# git clone https://github.com/tianocore/edk2-libc.git
# git clone https://github.com/acpica/acpica.git

此时在UEFIWorkspace下会看到下面几个目录:

UEFIWorkspace$ ls
acpica  edk2  edk2-libc
  • 同步edk2下的submodule
# cd edk2
# git submodule update --init

编译ACPICA

# make -C acpica/
  • 编译报错
/bin/sh: 1: m4: not found
make[1]: *** [Makefile:325: obj/aslcompiler.y] Error 127

安装软件包: apt install automake

编译BaseTools

# cd edk2
# make -C BaseTools
  • 编译报错
/bin/sh: 1: python: not found
GNUmakefile:11: recipe for target 'test' failed
make[1]: *** [test] Error 127
make[1]: Leaving directory '/root/work/UEFIWorkspace/edk2/BaseTools/Tests'
GNUmakefile:19: recipe for target 'Tests' failed
make: *** [Tests] Error 2

创建python软连接:

# cd /usr/bin
# ln -sf python3 python

创建设置环境变量的脚本

# 在UEFIWorkspace目录下
UEFIWorkspace# ls
acpica  edk2  edk2-libc  myexport.sh
root@97be60d27afa:~/work/UEFIWorkspace# cat myexport.sh
#!/bin/bash
export WORKSPACE=$PWD
export PACKAGES_PATH=$PWD/edk2:$PWD/edk2-libc
export IASL_PREFIX=$PWD/acpica/generate/unix/bin/
export PYTHON_COMMAND=/usr/bin/python3

设置环境变量,编译64位模拟器

设置环境变量

root@97be60d27afa:~/work/UEFIWorkspace# . ./myexport.sh
root@97be60d27afa:~/work/UEFIWorkspace# . ./edk2/edksetup.sh
Using EDK2 in-source Basetools
WORKSPACE: /root/work/UEFIWorkspace
EDK_TOOLS_PATH: /root/work/UEFIWorkspace/edk2/BaseTools
CONF_PATH: /root/work/UEFIWorkspace/edk2/Conf
Copying $EDK_TOOLS_PATH/Conf/build_rule.template
     to /root/work/UEFIWorkspace/edk2/Conf/build_rule.txt
Copying $EDK_TOOLS_PATH/Conf/tools_def.template
     to /root/work/UEFIWorkspace/edk2/Conf/tools_def.txt
Copying $EDK_TOOLS_PATH/Conf/target.template
     to /root/work/UEFIWorkspace/edk2/Conf/target.txt

编译模拟器

# build -p edk2/EmulatorPkg/EmulatorPkg.dsc -t GCC5 -a X64
  • 编译报错1
/root/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64/MdePkg/Library/BaseLib/BaseLib/OUTPUT/X64/DisablePaging64.iii:35: error: symbol `InternalX86DisablePaging64.0' undefined

参考:https://blog.csdn.net/weixin_44490152/article/details/129064676

是由于nasm工具版本太老导致,参考上面的博客,编译安装新的nasm即可。

wget http://www.nasm.us/pub/nasm/releasebuilds/2.15.05/nasm-2.15.05.tar.bz2
tar xfj nasm-2.15.05.tar.bz2
cd nasm-2.15.05/
./autogen.sh
./configure --prefix=/usr/local/ 
make 
sudo make install
  • 编译报错2
/root/work/UEFIWorkspace/edk2/EmulatorPkg/Unix/Host/X11GraphicsWindow.c:15:10: fatal error: X11/Xlib.h: No such file or directory
#include <X11/Xlib.h>
          ^~~~~~~~~~~~

安装软件包: apt-get install libghc-x11-dev

编译UEFI程序

先按照上一步的操作设置环境变量。

build -p edk2-libc/AppPkg/AppPkg.dsc -t GCC5 -a X64
build -p edk2/MdeModulePkg/MdeModulePkg.dsc -m edk2/MdeModulePkg/Application/HelloWorld/HelloWorld.inf -a X64 -t GCC5

设置sshd

前面已经安装了openssh-server,下面进行一下配置,允许root用户登录和X11 forward。

允许root用户登录

  • 编译/etc/ssh/sshd_config

  • 编译/etc/hosts.allow,添加下面的内容

  • 重启sshd服务
root@97be60d27afa:~/work/UEFIWorkspace# /etc/init.d/ssh restart
 * Restarting OpenBSD Secure Shell server sshd                                                                               [ OK ]
root@97be60d27afa:~/work/UEFIWorkspace# /etc/init.d/ssh status
 * sshd is running
  • 修改root用户的密码
# passwd root

X11 Forward

编译/etc/ssh/sshd_config

修改完毕,重启sshd服务。

通过SSH登录容器,并且执行UEFI模拟器

$ ssh -X -p 9090 root@localhost
root@97be60d27afa:~/work/UEFIWorkspace# . ./myexport.sh
root@97be60d27afa:~/work/UEFIWorkspace# . edk2/edksetup.sh                                                                          Loading previous configuration from /root/work/UEFIWorkspace/edk2/Conf/BuildEnv.sh
Using EDK2 in-source Basetools
WORKSPACE: /root/work/UEFIWorkspace
EDK_TOOLS_PATH: /root/work/UEFIWorkspace/edk2/BaseTools                                                                             CONF_PATH: /root/work/UEFIWorkspace/edk2/Conf
root@97be60d27afa:~/work/UEFIWorkspace# cd Build/EmulatorX64/DEBUG_GCC5/X64/
root@97be60d27afa:~/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64#
root@97be60d27afa:~/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64# ./Host
EDK II UNIX Host Emulation Environment from http://www.tianocore.org/edk2/
  BootMode 0x00
  OS Emulator passing in 128 KB of temp RAM at 0x40000000 to SEC
  FD loaded from ../FV/FV_RECOVERY.fd at 0x102000000 contains SEC Core
0x102000400 Loading /root/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64/EmulatorPkg/Sec/Sec/DEBUG/EmuSec.dll with entry point
0x1020017b3
SEC Has Started
0x102002800 Loading /root/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64/MdeModulePkg/Core/Pei/PeiMain/DEBUG/PeiCore.dll with e
ntry point 0x10200c230
0x102014880 Loading /root/work/UEFIWorkspace/Build/EmulatorX64/DEBUG_GCC5/X64/MdeModulePkg/Universal/ReportStatusCodeRouter/Pei/Repo
rtStatusCodeRouterPei/DEBUG/ReportStatusCodeRouterPei.dll with entry point 0x1020157bb
...

此时会弹出模拟器的GUI:

开发环境打包下载

sudo docker save -o edk2_dev.tar.gz edk2_dev:v1.0
BASH 复制 全屏
  • edk2_dev.tar.gz
  • UEFIWorkspace.tar.gz

链接:https://pan.baidu.com/s/1eKk2AkfeyA8W7ELSwciJnw?pwd=mfy0

提取码:mfy0

相关文章
|
算法 测试技术 编译器
掌握CTest:CTest综合指南
掌握CTest:CTest综合指南
1181 1
|
10月前
|
Ubuntu Linux 编译器
在Ubuntu Linux系统下如何搭建并安装EDK2
以上就是在Ubuntu Linux系统下搭建并安装EDK2的过程。这个过程可能会有些复杂,但只要按照步骤一步步来,应该不会有太大问题。如果在过程中遇到任何问题,都可以在网上找到相应的解决方案。希望这个指南能对你有所帮助!
498 17
|
传感器 机器人 API
NVIDIA Jetson TX1,TX2,TX2 NX,AGX Xavier 和 Nano开发板GPIO口配置及应用
NVIDIA Jetson TX1,TX2,TX2 NX,AGX Xavier 和 Nano开发板GPIO口配置及应用
|
Ubuntu Linux
ubuntu22.04禁止自动休眠的几种方式
在Ubuntu 22.04中禁用自动休眠可以通过多种方法实现,用户可以根据自己的技术水平和需求选择合适的方法。无论是通过图形界面还是命令行,都可以有效地防止系统进入自动休眠状态,确保长时间运行的任务不受干扰。通过理解和应用这些设置,可以更好地管理Ubuntu系统的电源行为,提高工作效率和系统稳定性。
5238 4
|
Ubuntu
Ubuntu禁止内核自动更新
通过上述步骤,您可以在Ubuntu系统中有效地禁用内核的自动更新。这些步骤包括锁定内核版本、禁用自动更新配置、移除不需要的内核包以及禁用相关的自动更新服务。这样可以确保系统在内核层面保持稳定,避免因内核自动更新导致的不必要问题。
3603 1
|
Ubuntu Linux 开发工具
E2000 UEFI使用设备树方式启动linux系统
E2000 UEFI使用设备树方式启动linux系统
4065 0
E2000 UEFI使用设备树方式启动linux系统
|
安全 Docker 容器
Docker中运行容器时Operation not permitted报错问题解决
【10月更文挑战第2天】Docker中运行容器时Operation not permitted报错问题解决
6176 4
|
机器学习/深度学习 人工智能 测试技术
NeurIPS D&B 2024 突破短视频局限!MMBench-Video解读MLLM视频理解能力
GPT-4o 四月发布会掀起了视频理解的热潮,而开源领军者Qwen2也对视频毫不手软,在各个视频评测基准上狠狠秀了一把肌肉。
|
Linux Windows
【Linux】grub命令行引导进入windows系统
【8月更文挑战第20天】在Linux中通过GRUB命令行引导Windows的方法包括:1) 进入GRUB命令行模式,启动时按`c`键;2) 使用`ls`查找含Windows引导文件的分区,如`bootmgr`或`ntldr`;3) 设置根设备`root=(hd0,msdos3)`与链加载器`chainloader +1`;4) 输入`boot`命令启动Windows。请注意实际步骤可能因系统配置而异。
2360 2
|
域名解析 存储 缓存
域名服务器 (DNS):工作原理及其优势
【8月更文挑战第19天】
2731 0