使用 Buildroot SDK
交叉编译
这里的交叉编译是指在 X86 的 PC 上编译 Jupiter 的固件。
开发环境
硬件配置
推荐配置:
- CPU:12th Gen Intel(R) Core(TM) i5 或以上
- Memory:16GB 或以上
- Disk:SSD,256GB 或以上
操作系统
推荐 Ubuntu 20.04,其他 Linux 发行版本尚未测试。
安装依赖
-
Ubuntu 16.04 and 18.04
sudo apt-get install git build-essential cpio unzip rsync file bc wget python3 libncurses5-dev libssl-dev dosfstools mtools u-boot-tools flex bison python3-pip zip
sudo pip3 install pyyaml
-
Ubuntu 20.04
sudo apt-get install git build-essential cpio unzip rsync file bc wget python3 python-is-python3 libncurses5-dev libssl-dev dosfstools mtools u-boot-tools flex bison python3-pip zip
sudo pip3 install pyyaml
下载源码
使用 repo(版本 >= 2.41)下载完整SDK。如果没有 repo,请参考 Git Repo 镜像使用帮助 安装。
使用 repo 前请检查 git 环境是否配置了 user 信息,如果没有配置,可以参考如下命令配置:
git config --global user.email "[email protected]"
git config --global user.name "Your Name"
创建并进入工作目录:
mkdir jupiter-linux
cd jupiter-linux
下载代码,例如下载 bl-v1.0.y
分支:
repo init -u https://github.com/milkv-jupiter/manifests.git -b main -m bl-v1.0.y.xml
repo sync
repo start bl-v1.0.y --all
后续需要同步最新的代码时,直接执行 repo sync
即可。
Buildroot 在编译过程中,会下载一些源码包,为避免因网络原因出现下载失败的情况,可以使用如下命令提前从 spacemit 服务器下载所需的源码包:
wget -c -r -nv -np -nH -R "index.html*" http://archive.spacemit.com/buildroot/dl
下载的源码包在 buildroot/dl
目录中。
目录结构:
├── bsp-src # Linux kernel,uboot and opensbi source code
│ ├── linux-6.1
│ ├── opensbi
│ └── uboot-2022.10
├── buildroot # Buildroot main directory
│ ├── dl # Buildroot dependent packages
├── buildroot-ext # Customized ext, such as board, configs, package, and patches
├── Makefile # Top Makefile
├── package-src # Locally deployed application or library source directory
│ ├── ai-support
│ ├── drm-test
│ ├── img-gpu-powervr
│ ├── k1x-cam
│ ├── k1x-jpu
│ ├── k1x-vpu-firmware
│ ├── k1x-vpu-test
│ ├── mesa3d
│ ├── mpp
│ └── v2d-test
└── scripts # Scripts used during compilation
首次完整编译
首次编译,建议使用 make envconfig
完整编译。后续如果修改了 buildroot-ext/configs/spacemit_k1_defconfig
,要使用 make envconfig
编译。其他情况,使用 make
编译即可。
make envconfig
Available configs in buildroot-ext/configs/:
1. spacemit_k1_defconfig
2. spacemit_k1_minimal_defconfig
3. spacemit_k1_plt_defconfig
4. spacemit_k1_v2_defconfig
your choice (1-4):
输入 1
,然后回车即开始编译。
编译完成,可以看到:
Images successfully packed into /build/jupiter-linux/output/k1/images/bianbu-linux-k1.zip
Generating sdcard image...................................
INFO: cmd: "mkdir -p "/build/jupiter-linux/output/k1/build/genimage.tmp"" (stderr):
INFO: cmd: "rm -rf "/build/jupiter-linux/output/k1/build/genimage.tmp"/*" (stderr):
INFO: cmd: "mkdir -p "/build/jupiter-linux/output/k1/images"" (stderr):
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'bootinfo' from 'factory/bootinfo_sd.bin' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'fsbl' (in MBR) from 'factory/FSBL.bin' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'env' (in MBR) from 'env.bin' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'opensbi' (in MBR) from 'fw_dynamic.itb' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'uboot' (in MBR) from 'u-boot.itb' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'bootfs' (in MBR) from 'bootfs.img' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition 'rootfs' (in MBR) from 'rootfs.ext4' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition '[MBR]' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition '[GPT header]' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition '[GPT array]' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): adding partition '[GPT backup]' ...
INFO: hdimage(bianbu-linux-k1-sdcard.img): writing GPT
INFO: hdimage(bianbu-linux-k1-sdcard.img): writing protective MBR
INFO: hdimage(bianbu-linux-k1-sdcard.img): writing MBR
Successfully generated at /build/jupiter-linux/output/k1/images/bianbu-linux-k1-sdcard.img
生成的镜像有两个:
- bianbu-linux-k1.zip 适用于 titanflasher 工具,或者解压后用 fastboot 刷机。
- bianbu-linux-k1-sdcard.img 为 sd 卡固件,解压后可以用 dd 命令或者 balenaEtcher 写入 sd 卡。
详细的刷机方法请参考:Milk-V Jupiter 安装操作系统。
固件默认用户名:root
,密码:bianbu
。
修改配置
如果默认的配置不满足您的需求,比如需要修改 kernel,或者添加 buildroot 的包,可以参考如下方法修改后,重新编译。
Buildroot
调出 buildroot 的配置界面:
make menuconfig
根据需求调整好配置后,保存配置,默认保存到 buildroot-ext/configs/spacemit_k1_defconfig
:
make savedefconfig
Linux Kernel
调出 kernel 的配置界面:
make linux-menuconfig
根据需求调整好配置后,保存配置,默认保存到 bsp-src/linux-6.1/arch/riscv/configs/k1_defconfig
:
make linux-update-defconfig
U-boot
调出 u-boot 的配置界面:
make uboot-menuconfig
根据需求调整好配置后,保存配置,默认保存到 bsp-src/uboot-2022.10/configs/k1_defconfig
:
make uboot-update-defconfig
编译指定包
u-boot
编译 u-boot:
make uboot-rebuild
kernel
编译 kernel:
make linux-rebuild
buildroot
buildroot 支持编译指定的 package,可以 make help
查看指南。
常用命令:
- 删除
<pkg>
的编译目录:make <pkg>-dirclean
- 编译
<pkg>
:make <pkg>
编译指定包之后,可以单独下载到设备验证,或者编进固件:
make
单独编译引导程序和内核
如果不需要编译整个镜像,只编译 opensbi、u-boot、linux kernel,可以使用如下方法分别单独编译。
交叉编译器下载地址:http://archive.spacemit.com/toolchain/,解压即可使用。
设置环境变量:
export PATH=/path/to/spacemit-toolchain-linux-glibc-x86_64-v0.3.3/bin:$PATH
export CROSS_COMPILE=riscv64-unknown-linux-gnu-
export ARCH=riscv