本教程给出了使用RustSBI和U-Boot SPL在QEMU中启动Test Kernel的基本流程。
请读者在其主机上安装必要的软件来尝试本教程的脚本。本教程是在Arch Linux上开发的。
环境配置小节给出了本教程的环境配置方法,用户在使用本教程时需要先完成环境配置小节内容。
本教程使用软件版本如下:
软件 | 版本 |
---|---|
riscv64-linux-gnu-gcc | 14.1.0 |
qemu-system-riscv64 | 9.0.1 |
RustSBI Prototyper | 0.0.0 |
U-Boot | 2024.04 |
Linux Kernel | 6.2 |
busybox | 1.36.0 |
For Arhc Linux:
$ sudo pacman -S git riscv64-linux-gnu-gcc qemu-system-riscv uboot-tools
For Ubuntu:
$ sudo apt-get update && sudo apt-get upgrade
$ sudo apt-get install git qemu-system-misc gcc-riscv64-linux-gnu u-boot-tools
For riscv64-linux-gnu-gcc:
$ riscv64-linux-gnu-gcc --version
它将输出以下版本信息
riscv64-linux-gnu-gcc (GCC) 14.1.0
Copyright (C) 2024 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
For QEMU:
$ qemu-system-riscv64 --version
它将输出以下版本信息
QEMU emulator version 9.0.1
Copyright (c) 2003-2024 Fabrice Bellard and the QEMU Project developers
创建工作目录并进入该目录
$ mkdir workshop && cd workshop
Clone RustSBI Prototyper
$ git clone https://github.com/rustsbi/prototyper.git && cd prototyper && git checkout main && cd ..
Clone U-Boot
$ git clone https://github.com/u-boot/u-boot.git && cd u-boot && git checkout v2024.04 && cd ..
进入prototyper目录
$ cd prototyper
编译RustSBI Prototyper和Test Kernel
$ cargo make test-kernel-itb
本小节将使用二进制文件 ./target/riscv64imac-unknown-none-elf/release/rustsbi-test-kernel.itb
。
进入U-Boot目录
$ cd u-boot
导出环境变量
$ export ARCH=riscv
$ export CROSS_COMPILE=riscv64-linux-gnu-
$ export OPENSBI=../prototyper/target/riscv64imac-unknown-none-elf/release/rustsbi-prototyper.bin
生成.config
文件
# To generate .config file out of board configuration file
$ make qemu-riscv64_spl_defconfig
# add bootcmd value
$ make menuconfig
编译U-Boot
# To build U-Boot
$ make -j$(nproc)
本小节将使用二进制文件 ./spl/u-boot-spl
。
进入workshop
目录
$ cd workshop
运行下面命令
$ qemu-system-riscv64 -M virt -smp 1 -m 256M -nographic \
-bios ./u-boot/spl/u-boot-spl \
-device loader,file=./prototyper/target/riscv64imac-unknown-none-elf/release/rustsbi-test-kernel.itb,addr=0x80200000