QEMU学习之路(8)— ARM32通过u-boot 启动Linux

QEMU学习之路(8)--- ARM32通过u-boot 启动Linux

一、前言

参考文章:
Linux内核学习------内核的编译和启动
Linux 内核的编译和模拟执行
Linux内核运行------根文件系统
Linux 内核学习------使用 uboot 加载内核

二、构建Linux内核

1、获取Linux源码

bash 复制代码
git clone https://mirrors.tuna.tsinghua.edu.cn/git/linux.git -b v5.4 linux-5.4

2、配置内核

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- vexpress_defconfig

3、编译内核

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j $(nproc)

编译出的 kernel image 位于 arch/arm/boot/zImage

三、构建busybox

1、获取busybox 源码

bash 复制代码
wget https://busybox.net/downloads/busybox-1.32.0.tar.bz2

解压,进入源码目录

bash 复制代码
tar xvf busybox-1.32.0.tar.bz2
cd busybox-1.32.0

2、配置静态编译

使用如下命令进入配置界面

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- menuconfig

使用以下选项,选择静态方式编译busybox,目的是将程序的所有依赖库直接打包进二进制文件,避免了Linux系统运行时依赖动态库。

bash 复制代码
Settings  --->
    [*] Build static binary (no shared libs) 

3、编译busybox

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j $(nproc)

4、安装

使用如下命令会将busybox默认安装到_install目录下

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- install

四、构建根文件目录

创建一个sdcard.img镜像,初始化为ext4格式

bash 复制代码
dd if=/dev/zero of=sdcard.img bs=1M count=16
mkfs.ext4 sdcard.img

把镜像挂载在rootfs目录下

bash 复制代码
mkdir rootfs
sudo mount -t ext4 sdcard.img rootfs/ -o loop

将busybox文件复制到rootfs目录下

bash 复制代码
sudo cp -r busybox-1.32.0/_install/* rootfs/

进入rootfs目录,新建如下文件夹

bash 复制代码
cd rootfs
sudo mkdir etc proc sys dev var boot

设置启动有关的配置脚本,将busybox 目录下启动的脚本直接拷贝过来

bash 复制代码
sudo cp -rf ../busybox-1.32.0/examples/bootfloppy/etc/* ./etc/

修改etc/fstab文件内容如下所示

bash 复制代码
proc    /proc   proc    defaults    0   0
sysfs   /sys    sysfs   defaults    0   0
tmpfs   /var    tmpfs   defaults    0   0

修改etc/init.d/rcS文件内容如下所示

bash 复制代码
#! /bin/sh

/bin/mount -a
/sbin/mdev -s

fstab 文件中的内容指定系统启动时需要挂载的文件系统以及挂载的选项,

rcS 文件是启动脚本,其中的 /bin/mount -a 表示挂载 fstab 中指定的文件系统,/sbin/mdev -s 则负责在Linux系统启动时自动检测和管理设备

回到镜像目录,将Imagedtb文件拷贝到rootfs文件夹下

bash 复制代码
cd ../
sudo cp linux-5.4/arch/arm/boot/zImage rootfs/boot/
sudo cp linux-5.4/arch/arm/boot/dts/vexpress-v2p-ca9.dtb rootfs/boot/

取消镜像挂载

bash 复制代码
sudo umount rootfs

五、构建U-Boot

1、获取uboot源码

bash 复制代码
git clone https://gitee.com/mirrors/u-boot.git -b v2020.10 u-boot_2020.10 

2、配置编译选项

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- vexpress_ca9x4_defconfig

3、编译uboot

bash 复制代码
make ARCH=arm CROSS_COMPILE=arm-linux-gnueabihf- -j $(nproc)

六、启动测试

使用如下命令启动

bash 复制代码
qemu-system-arm -M vexpress-a9 -m 512M -kernel u-boot_2020.10/u-boot -sd ./sdcard.img -nographic -no-reboot

启动界面如下

在u-boot命令行输入如下命令,将Image和dtb加载到内存中

bash 复制代码
load mmc 0:0 0x66000000 boot/zImage
load mmc 0:0 0x66500000 boot/vexpress-v2p-ca9.dtb

设置启动参数如下

bash 复制代码
setenv bootargs "root=/dev/mmcblk0 rw console=ttyAMA0,115200 init=/linuxrc"

使用如下命令启动

bash 复制代码
bootz 0x66000000 - 0x66500000

启动界面如下所示

相关推荐
辰海Coding1 小时前
MiniSpring框架学习笔记-解决循环依赖的简化IoC容器
笔记·学习
晓梦林2 小时前
cp520靶场学习笔记
android·笔记·学习
小鹏linux2 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
在角落发呆3 小时前
Linux转发配置:解锁网络互联的核心密码
linux·运维·网络
心中有国也有家3 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
Upsy-Daisy3 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习
齐潇宇3 小时前
Zabbix 7 概述与配置
linux·zabbix·监控告警
LuminousCPP4 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
江公望4 小时前
Ubuntu htop命令,10分钟讲清楚
linux·服务器
哎呦,帅小伙哦4 小时前
Linux 时间:从原子钟到 clock_gettime 的每一面
linux·运维·服务器