Qemu支持ATF + u-boot + linux kernel

qemu环境搭建及ATF/u-boot/linux kernel的编译等,参考

从零开始搭建qemu调试环境 - 知乎

ATF编译:

wmx@wmx-VirtualBox:~/work/arm-trusted-firmware$ cat build-atf.sh

export ARCH=arm64

export CROSS_COMPILE=/home/wmx/Downloads/gcc-linaro-7.4.1-2019.02-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-

make PLAT=qemu BL33=/home/wmx/work/u-boot/u-boot.bin all fip DEBUG=1

u-boot编译:

wmx@wmx-VirtualBox:~/work/u-boot$ cat build-uboot.sh

export ARCH=arm64

export CROSS_COMPILE=/home/wmx/Downloads/gcc-linaro-7.4.1-2019.02-x86_64_aarch64-linux-gnu/bin/aarch64-linux-gnu-

make qemu_arm64_defconfig

make

qemu+atf+uboot+linux启动:

wmx@wmx-VirtualBox:~/work$ cat qemu-atf-kernel.sh

qemu-system-aarch64 \

-nographic \

-M virt,secure=on,gic_version=3 \

-cpu cortex-a53 \

-smp 2 \

-m 2048 \

-d guest_errors,unimp \

-bios /home/wmx/work/arm-trusted-firmware/build/qemu/debug/bl1.bin \

-drive file=/home/wmx/work/buildroot/output/images/rootfs.ext4,if=none,id=blk1,format=raw \

-device virtio-blk-device,drive=blk1 \

-kernel /home/wmx/work/linux-4.19.294/arch/arm64/boot/Image \

-semihosting-config enable=on,target=native

代码执行流程:

1)BL1加载BL2并跳转到BL2入口

2)BL2加载BL31

3)BL2加载BL33,即加载u-boot.bin

前面的加载过程会用到plat/qemu/common/qemu_io_storage.c中定义的文件名,需要修改为本机的实际存储位置

4)BL2返回到BL1,并从BL1进入BL31

此时BL31由于尚未设置其自身的smc异常处理程序而无法直接处理该异常,因此,为了完成跳转流程,BL1需要先代理该异常的处理。因此BL1在退出之前先设置smc异常处理函数,

BL2触发smc启动BL31时,bl2/bl2_main.c 函数bl2_main中通过smc(BL1_SMC_RUN_IMAGE, (unsigned long)next_bl_ep_info, 0, 0, 0, 0, 0, 0); 进入BL1.

BL1捕获该异常,进入bl1/aarch64/bl1_exceptions.S 的 SynchronousExceptionA64-> smc_handler64 ,并根据BL2传入的参数设置BL31的入口地址和系统初始状态,并通过ERET跳转到BL31的入口地址处执行

5)BL31会初始化GICv3及runtime service(SMC调用的服务),并进入BL33(u-boot)执行

BL31:

runtime_svc.c->runtime_svc_init函数:

主要是初始化SMC调用时的处理函数,rt_svc_descs通过 DECLARE_RT_SVC声明,并链接到RT_SVC_DESCS_START和RT_SVC_DESCS_END范围内. 当前qemu平台上会有两个rt_svc_descs, 分别是arm_arch_svc和std_svc。 分别在services/arm_arch_svc/arm_arch_svc_setup.c 和services/std_svc/std_svc_setup.c中声明

相关推荐
Codigger官方6 分钟前
Linux 基金会牵头成立 React 基金会:前端开源生态迎来里程碑式变革
linux·前端·react.js
武文斌777 分钟前
项目学习总结:LVGL图形参数动态变化、开发板的GDB调试、sqlite3移植、MQTT协议、心跳包
linux·开发语言·网络·arm开发·数据库·嵌入式硬件·学习
爱吃喵的鲤鱼11 分钟前
仿mudou——Connection模块(连接管理)
linux·运维·服务器·开发语言·网络·c++
让子弹飞0220 分钟前
永久解决ubuntu网络连接问题
linux·运维·ubuntu
郝学胜-神的一滴43 分钟前
使用Linux的read和write系统函数操作文件
linux·服务器·开发语言·数据库·c++·程序人生·软件工程
pu_taoc1 小时前
深入剖析:基于epoll与主从Reactor模型的高性能服务器设计与实现
服务器·c语言·c++·vscode
七七七七072 小时前
【Linux 系统】打开文件和文件系统
linux·运维·spring
DeeplyMind2 小时前
第二章:模块的编译与运行-7 Loading and Unloading Modules
linux·驱动开发
敢敢J的憨憨L3 小时前
GPTL(General Purpose Timing Library)使用教程
java·服务器·前端·c++·轻量级计时工具库
---学无止境---3 小时前
Linux中驱动程序通过fasync异步通知应用程序的实现
linux