3. LubanCat_Gen_SDK

3.1. 简介

LubanCat_Gen_SDK是基于瑞芯微通用Linux SDK工程的深度定制版本,适用于以Rockchip处理器为主芯片的LubanCat-RK系列板卡。

整个SDK工程,目录包含有 debian、kernel、u-boot、device、rkbin、ubuntu等目录。 每个目录或其子目录会对应一个 git 工程,提交需要在各自的目录下进行。

  • debian:Debian根文件系统构建脚本,根据不同版本,分为debian11,debian12。

  • device/rockchip: 存放各芯片板级配置,以及构建进行相关的脚本等。

  • kernel: 存放 kernel 源码。

  • prebuilts: 存放交叉编译工具链。

  • rkbin: 存放 Rockchip 相关的 Binary 和工具。

  • rockdev: 存放编译输出的镜像文件(软链接到output/firmware)。

  • output: 存放编译过程中生成的过程文件、日志、编译出的镜像等。

  • tools: 存放 Linux 和 Windows 操作系统环境下常用工具。

  • u-boot:存放基于v2017.09版本进行开发的uboot代码。

  • ubuntu: Ubuntu根文件系统构建脚本。根据不同版本,分为ubuntu20.04,ubuntu22.04。

3.2. extboot分区介绍

extboot分区系统是野火基于瑞芯微Linux_SDK框架搭建的一种LubanCat-RK系列板卡通用镜像实现方式。 可以实现一个镜像烧录到LubanCat使用同一型号处理器的所有板卡,解决了默认rkboot分区方式设备树固定,导致一个镜像只能适配一款板卡的问题, 大大降低了由于型号众多导致的后期维护的复杂性。

extboot分区使用ext4文件系统格式,在编译过程中将所有LubanCat-RK系列板卡设备树都编译并打包到分区内, 并借助SDRADC读取板卡硬件ID,来实现设备树自动切换。同时支持设备树插件,自动更新内核deb包,在线更新内核和驱动模块等功能。

还对系统镜像的分区做了调整,删减一些冗余功能,实现了对系统存储的高效利用。

3.3. SDK 开发环境搭建

LubanCat_Gen_SDK是基于Ubuntu LTS 系统开发测试的,在开发过程中,主要是用Ubuntu 20.04版本, 推荐用户使用Ubuntu20.04或Ubuntu22.04,不支持Ubuntu20.04以下版本开发。

硬件配置推荐:64位系统,硬盘空间⼤于80G。如果您进⾏多个构建,将需要更⼤的硬盘空间。

安装SDK依赖的软件包

1
2
3
4
5
6
7
8
9
# 安装SDK构建所需要的软件包
# 整体复制下面内容到终端中安装
sudo apt-get update && sudo apt-get install git ssh make gcc libssl-dev \
liblz4-tool expect expect-dev g++ patchelf chrpath gawk texinfo chrpath \
diffstat binfmt-support qemu-user-static live-build bison flex fakeroot \
cmake gcc-multilib g++-multilib unzip device-tree-compiler ncurses-dev \
libgucharmap-2-90-dev bzip2 expat gpgv2 cpp-aarch64-linux-gnu libgmp-dev \
libmpc-dev bc python-is-python3 python3-pip python2 u-boot-tools curl \
python3-pyelftools dpkg-dev

3.4. 安装repo

repo是google⽤Python脚本写的调⽤git的⼀个脚本,主要是⽤来下载、管理项⽬的软件仓库。

1
2
3
4
5
6
7
mkdir ~/bin
curl https://storage.googleapis.com/git-repo-downloads/repo > ~/bin/repo
# 如果上面的地址无法访问,可以用下面的:
# curl -sSL  'https://gerrit-googlesource.proxy.ustclug.org/git-repo/+/master/repo?format=TEXT' |base64 -d > ~/bin/repo
chmod a+x ~/bin/repo
echo PATH=~/bin:$PATH >> ~/.bashrc
source ~/.bashrc

执行完上面的命令后来验证repo是否安装成功能正常运行。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
repo --version

#返回以下信息
#返回的信息根据Ubuntu版本的不同略有差异
<repo not installed>
repo launcher version 2.32
    (from /home/he/bin/repo)
git 2.25.1
Python 3.8.10 (default, Nov 14 2022, 12:59:47)
[GCC 9.4.0]
OS Linux 5.15.0-60-generic (#66~20.04.1-Ubuntu SMP Wed Jan 25 09:41:30 UTC 2023)
CPU x86_64 (x86_64)
Bug reports: https://bugs.chromium.org/p/gerrit/issues/entry?template=Repo+tool+issue

3.5. SDK源码获取

LubanCat_Gen_SDK的代码被划分为了若干git仓库分别进行版本管理, 可以使用repo工具对这些git仓库进行统一的下载,提交,切换分支等操作。

运行以下命令,将在当前用户的家目录下创建一个名为LubanCat_SDK的目录,用来放入SDK源码。

1
mkdir ~/LubanCat_SDK

3.5.1. 切换Python 3 版本

1
2
#查看当前Python版本
python -V

若返回的版本号为Python3版本,则无需再切换Python版本。若为Python2版本或未发现python,则可以用以下方式切换:

1
2
3
4
5
6
7
8
#查看当前系统安装的Python版本有哪些
ls /usr/bin/python*

#将python链接到python3
sudo ln -sf /usr/bin/python3 /usr/bin/python

#重新查看默认Python版本
python -V

此时系统默认Python版本切换为python3

../../_images/lubancat05.png

3.5.2. Git配置

设置自己的git信息,以确保后续拉取代码时正常进行,如果不需要提交代码的话可以随意设置用户名和邮箱地址。

1
2
git config --global user.name "your name"
git config --global user.email "your mail"

3.5.3. SDK在线下载并同步

LubanCat_Gen_SDK源码可以在线获取,源码托管在Github。由于在线下载的方式要从Github拉取大量的仓库, 体积很大,对于不能快速访问Github的用户不建议使用这种方式。

1
2
3
4
5
6
7
8
9
cd ~/LubanCat_SDK

# 拉取LubanCat_Linux_Generic_SDK
repo init -u https://github.com/LubanCat/manifests.git -b linux -m lubancat_linux_generic.xml

#如果运行以上命令失败,提示:fatal: Cannot get https://gerrit.googlesource.com/git-repo/clone.bundle
#则可以在以上命令中添加选项 --repo-url https://mirrors.tuna.tsinghua.edu.cn/git/git-repo

.repo/repo/repo sync -c -j4
../../_images/lubancat06.png

如果同步失败可以重新运行sync命令来同步

../../_images/lubancat07.png ../../_images/lubancat09.png

3.5.4. SDK离线安装下载

由于Github服务器在国外,拉取这么多的仓库需要很多时间,还可能因为网络不畅通而导致下载失败。 为此,我们将需要使用的仓库整体打包,使用网盘下载的方式,以减少连接Github导致的问题。

3.5.4.1. 下载地址

访问百度网盘资源介绍页面获取SDK源码压缩包: 8-SDK源码压缩包

下载最新日期的LubanCat_Linux_Generic_SDK压缩包即可。

注解

在开发过程中,当SDK源码进入Release版本或有重大Bug时,将会更新源码压缩包。源码压缩包解压到本地后,当有Release版本更新时,可以借助Github更新到最新版本。

3.5.4.2. 解压源码

以下过程以LubanCat_Linux_Generic_SDK进行演示,实际文件名称以自己下载的SDK为准

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
# 安装tar压缩工具,一般来说系统默认安装了
sudo apt install tar

# 在用户家目录创建LubanCat_SDK目录
mkdir ~/LubanCat_SDK

# 将下载的SDK源码移动到LubanCat_SDK目录下,xxx为日期
mv LubanCat_Linux_Generic_SDK_xxx.tgz ~/LubanCat_SDK

# 进入LubanCat_SDK目录
cd ~/LubanCat_SDK

# 解压SDK压缩包
tar -xzvf LubanCat_Linux_Generic_SDK_xxx.tgz

# 检出.repo目录下的git仓库
.repo/repo/repo sync -l

# 将所有的源码仓库同步到最新版本
.repo/repo/repo sync -c

如果repo sync -c执行时提示网络连接超时,请检查并能否通畅访问github。 确认可以正常访问github的话,可以重复多次执行repo sync -c命令来进行同步。 若无法访问github,可以忽略同步源码仓库到最新版本这一步骤。

../../_images/tar-sdk.jpg ../../_images/tar-sdk1.jpg

解压完成后checkout到指定的提交。

../../_images/lubancat12.png

一般情况下网盘保存的离线源码包已经是最新版本,如果距离离线源码包下载时间不久,可以忽略从Github在线更新这一步。

3.5.5. SDK更新

我们会对LubanCat_Gen_SDK不断更新,并将修改的内容实时同步到Github, 如果需要在本地LubanCat_Gen_SDK同步更新内容,则可以借助repo或git来实现。

3.5.5.1. 使用repo更新整个SDK

使用repo可以将SDK更新到提供的最新版本。

首先要更新.repo/manifests,里面保存了repo的配置文件,记录了仓库的版本信息。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
# 进入.repo/manifests目录
cd .repo/manifests

# 切换分支到Linux
git checkout linux

# 拉取最新的manifests
git pull

#进入SDK根目录
cd ~/LubanCat_SDK

# 同步远端仓库
.repo/repo/repo sync -c
../../_images/lubancat10.png

3.5.5.2. 使用Git更新单独的源码仓库

有时只想更新某个仓库,而不是去更新整个SDK。 或者已经对SDK的某些仓库做出了修改,使用repo同步的话就会失败。 此时就需要对单个仓库进行更新了。

这里以Kernel仓库为例

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
# 进入kernel目录下
cd kernel

# 检出到当前提交所在的分支
# 可以查看.repo/manifests/lubancat_linux/lubancat_linux_generic_release.xml
# name="kernel"条目中dest-branch就是要切换的分支
git checkout lbc-develop-5.10

# 拉取git仓库
git pull

注解

不同SDK或板卡使用的分支不同,详细分支支持情况请查看 Linux内核的编译 章节

3.6. LubanCat_Gen_SDK自动构建

LubanCat_Gen_SDK的构建脚本可以实现自动构建,具体操作方式如下:

在SDK根目录下,执行以下命令,以选择要构建的板卡主芯片型号和SDK的配置文件。

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
# 选择SDK配置文件
./build.sh chip

1. rk312x
2. rk3528
3. rk3562
4. rk3566_rk3568
5. rk3588

# 输入想要构建的板卡主芯片型号的编号,并确认,这里选择rk3588。
Which would you like? [1]: 5

# 选择要构建的根文件系统配置文件
6. rockchip_defconfig
7. LubanCat_rk3588_debian_gnome_defconfig
8. LubanCat_rk3588_debian_lite_defconfig
9. LubanCat_rk3588_ubuntu_gnome_defconfig
10. LubanCat_rk3588_ubuntu_lite_defconfig
Which would you like? [1]: 2

注解

芯片型号编号和配置文件编号顺序可能发生变化,以实际为准。

../../_images/sdk-chip.jpg

如果已经选择过了主芯片,需要切换同一主芯片其他板卡或文件系统类型。

1
2
3
4
5
# 选择SDK配置文件
./build.sh lunch

# 输入想要构建的板卡及文件系统配置文件编号,并确认,这里选择配置文件LubanCat_rk3588_debian_gnome_defconfig。
Which would you like? [0]: 2
../../_images/sdk-lunch.jpg

也可以直接设置SDK配置文件,方法如下

1
2
# 选择构建LubanCat-RK3588系列板卡debian系统gnome桌面镜像
./build.sh LubanCat_rk3588_debian_gnome_defconfig
../../_images/sdk-config.jpg

选择SDK配置文件以后,还要安装debian根文件系统构建依赖的软件包,操作如下。

1
2
3
4
# 安装本地软件包
# 如果SDK中debian目录是具体的debian11或者debian12,需要将下面命令中的debian目录路径替换为实际的路径。都有则选择较高版本的安装。
sudo dpkg -i debian/ubuntu-build-service/packages/*
sudo apt-get install -f
../../_images/lubancat21.png

注意

由于debian和ubuntu根文件系统不同版本构建所需的依赖包版本不同,当切换了根文件系统版本的选择以后,就需要根据自己所选的根文件系统版本安装不同的依赖包。

如果选择了ubuntu根文件系统的SDK配置文件,就需要安装ubuntu根文件系统构建的依赖软件包,操作如下。

1
2
3
4
#安装本地软件包
# 如果SDK中ubuntu目录是具体的ubuntu20.04或者ubuntu22.04,需要将下面命令中的debian目录路径替换为实际的路径。都有则选择较高版本的安装。
sudo dpkg -i ubuntu/ubuntu-build-service/packages/*
sudo apt-get install -f

安装过程中可能会报错,这是正常现象,忽略即可。待软件包安装完成后,就可以进行一键构建了。

1
2
# 一键编译u-Boot,kernel,Rootfs并打包为update.img镜像
./build.sh
../../_images/build.jpg

警告

如果在编译过程中出现如下图所示的提示,请根据对应设备树文件中的&pmu_io_domains节点中的电压值选择, 并注意顺序从pmuio2-supply开始。其中vccio_acodec为3v3、vccio_sd为3v3。

../../_images/lubancat01.png

构建好的镜像保存在rockdev/目录下,可以继续使用 ./build.sh release 命令在output-release/目录下进行镜像压缩归档。

3.7. LubanCat_Gen_SDK单独构建模块

在进行固件开发时,一键构建就显得过于耗时了,每一个改动都要构建整个镜像并重新打包, 这无疑是巨大的时间浪费。此时可以使用SDK单个模块构建的功能。

3.7.1. 选择SDK配置文件

首先,还是要选择SDK的配置文件,如果已经选择过了则这一步可以跳过,这里以LubanCat-RK3588系列板卡的debian系统gnome桌面镜像为例

1
2
# 选择SDK配置文件
./build.sh LubanCat_rk3588_debian_gnome_defconfig

3.7.2. U-Boot构建

1
./build.sh uboot

构建生成的U-boot镜像为u-boot/uboot.img

3.7.3. Kernel构建

extboot分区内核镜像,要先生成内核deb包,然后再编译内核并将生成的deb包打包进extboot分区。

按顺序执行以下命令,将自动完成 kernel 的构建及打包。

1
2
3
./build.sh kerneldeb

./build.sh extboot

构建生成的kernel镜像为kernel/extboot.img

3.7.4. rootfs构建

LubanCat主要支持Ubuntu、Debian、OpenWrt这几种rootfs, 不同rootfs的构建过程不同,这里分开说明。

注解

由于OpenWrt系统的构建不使用LubanCat_Gen_SDK,所以不在此处说明,具体构建过程查看LubanCatWRT构建说明

3.7.4.1. Debian

目前提供debian11/debian12的根文件系统构建脚本,Kernel-5.10搭配debian11,Kernel-6.1则搭配debian12。 具体的对应情况在SDK配置文件中已经配置好,用户无需特殊关心。

首先要确保SDK的配置文件与要构建的rootfs一致, 如果当前配置文件与要构建的rootfs不一致,需要先切换配置文件。

1
2
3
4
5
# 选择SDK配置文件
./build.sh LubanCat_rk3588_debian_gnome_defconfig

# 构建Debian
./build.sh debian

构建生成的rootfs镜像为debian/linaro-rk3588-gnome-rootfs.img,同时被软链接到rockdev/rootfs.img

注意

为了加速SDK构建效率,只有不存在debian/linaro-rk3588-gnome-rootfs.img时,才会重新构建Debian根文件系统。如果要重新构建根文件系统,需要先手动删除linaro-rk3588-gnome-rootfs.img。

3.7.4.2. Ubuntu

目前提供20.04/22.04的根文件系统构建脚本,Kernel-5.10搭配Ubuntu20.04,Kernel-6.1则搭配Ubuntu22.04。 具体的对应情况在SDK配置文件中已经配置好,用户无需特殊关心。

首先要确保SDK的配置文件与要构建的rootfs一致, 如果当前配置文件与要构建的rootfs不一致,需要先切换配置文件。

1
2
3
4
5
# 选择SDK配置文件
./build.sh LubanCat_rk3588_ubuntu_gnome_defconfig

# 构建Ubuntu
./build.sh ubuntu

构建生成的rootfs镜像为ubuntu/ubuntu-rk3588-gnome-rootfs.img,同时被软链接到rockdev/rootfs.img

注意

只有不存在ubuntu/ubuntu-rk3588-gnome-rootfs.img时,才会重新构建Ubuntu根文件系统。如果要重新构建根文件系统,需要先手动删除ubuntu-rk3588-gnome-rootfs.img。

3.7.5. 镜像打包

当u-boot,kernel,Rootfs都构建完成以后,需要再执行./mkfirmware.sh 进行固件打包, 主要是检查分区表文件是否存在,各个分区是否与分区表配置对应,并根据配置文件将所有的文件复制或链接到rockdev/内。

为了方便镜像的发布,还可以将各个分立的分区打包成一个文件,打包好的文件就能用于烧录了。

1
2
3
4
5
# 固件打包
./mkfirmware.sh

# 生成update.img
./build.sh updateimg

以debian系统为例,rockdev/目录下的文件如下所示

rockdev/

链接文件

boot.img

kernel/boot.img

MiniLoaderAll.bin

u-boot/rk3588_spl_loader_v1.17.113.bin

parameter.txt

device/rockchip/.chips/rk3588/parameter.txt

rootfs.img

debian/linaro-rk3588-gnome-rootfs.img

uboot.img

u-boot/uboot.img

3.8. ./build.sh构建脚本

./build.sh 脚本是整个SDK功能的入口,SDK配置文件的选择、修改; 系统各部分配置文件的修改、编译;以及镜像打包等,都离不开./build.sh脚本

可以使用./build.sh help命令查看所有支持的功能。

注意

由于SDK是经二次开发,增删了部分功能,help返回命令中,有些是不生效的,以实际情况为准。

../../_images/help.jpg

3.8.1. SDK配置文件修改

可以使用./build.sh config命令来修改SDK配置文件

../../_images/gen-sdk-config.jpg

./build.sh savedefconfig命令可以将最小SDK配置文件保存在选择的配置文件里

在SDK配置中,可以对rootfs、loader、kernel、分区表、扩展分区、镜像打包等各部分做详细配置, 不过一般情况下直接使用已经保存好的配置文件即可,修改可能会导致编译失败。

3.8.2. 内核相关命令

使用./build.sh kernel-config或./build.sh kconfig可以直接打开内核配置界面。

当我们退出配置页面后,又会将对内核的修改同步到我们在SDK配置文件中选中的内核配置文件。