
请先按照开发环境搭建文档进行开发环境搭建,由于系统编译过程需下载相关软件工具包,因此请确保Ubuntu可正常访问互联网。本说明文档适用开发环境如下:
Windows开发环境:Windows 7 64bit、Windows 10 64bit
虚拟机:VMware16.2.5
开发环境:Ubuntu20.04.6 64bit
U-Boot:U-Boot-2017.09
Kernel:Linux-5.10.160、Linux-RT-5.10.160
Debian:Debian 11
LinuxSDK:LinuxSDK-[版本号](基于rk3588_linux_release_v1.2.1_20230720)
Debian系统相关软件包位于产品资料“4-软件资料\Debian\”目录下,具体如下表所示。其中,我司已提供U-Boot、Kernel、Filesystem和Debian系统镜像文件,U-Boot、Kernel、Filesystem源码位于LinuxSDK开发包内。
备注:我司推荐使用最新版本的LinuxSDK,亦可根据“4-软件资料\Debian\LinuxSDK\LinuxSDK-feature-support.pdf”的变更说明,自行替换对应模块(如device/rockchip)至旧版本LinuxSDK进行使用。

执行如下命令,安装LinuxSDK开发包依赖软件。
备注:安装过程中,请保证Ubuntu可正常访问互联网,若提示"*** is already the newest version ***"表示该软件已安装,请忽略。
Host# sudo apt-get install -y 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 libmpfr-dev


执行如下命令,将Python2和Python软链接为Python3。
Host# sudo ln -s /usr/bin/python3 /usr/bin/python2
Host# sudo ln -s /usr/bin/python3 /usr/bin/python
Host# ls -al /usr/bin/python*

执行如下命令,查看Python版本,确认是否链接成功。
备注:Python版本需3.8.0及以上。
Host# python --version
Host# python2 --version

请将产品资料“4-软件资料\Debian\Tools\”目录下的LZ4_old1-dev.zip压缩包拷贝至Ubuntu,执行如下命令进行解压。
Host# unzip LZ4_old1-dev.zip

执行如下命令,进行安装LZ4。
Host# cd LZ4_old1-dev/
Host# make
Host# sudo make install
Host# sudo install -m 0755 lz4 /usr/bin/lz4


执行如下命令,查看LZ4版本信息。
备注:LZ4版本需v1.9.3及以上。
Host# lz4 -v

执行如下命令,安装PPA。
Host# sudo apt install software-properties-common

执行如下命令,向PPA中更新Git软件源,需按回车键确认更新。
Host# sudo add-apt-repository ppa:git-core/ppa

执行如下命令,更新软件列表并安装Git。
备注:安装时长受网络速率影响,请耐心等待。
Host# sudo apt-get update
Host# sudo apt-get install git


执行如下命令,查看Git版本信息。
备注:建议将版本更新至2.38.0及以上,以免因版本过低导致LinuxSDK编译失败。
Host# git -v

请将产品资料“4-软件资料\Debian\Tools\”目录下的live-build-master.zip压缩包拷贝至Ubuntu系统live-build目录下,执行如下命令新建live-build目录,并进行解压。
Host# mkdir live-build
Host# cd live-build
Host# unzip live-build-master.zip


执行如下命令,安装live-build-master相关文件。
Host# cd live-build-master
Host# sudo apt-get remove live-build
Host# git clone https://salsa.debian.org/live-team/live-build.git --depth 1 -b debian/1%20230131

执行如下命令,编译相关配置。
Host# cd live-build
Host# rm -rf manpages/po/
Host# sudo make install -j8

由我司提供的LinuxSDK-[版本号].tar.gz开发包位于产品资料“4-软件资料\Debian\LinuxSDK\”目录下,基于瑞芯微的rk3588_linux_release_v1.2.1_20230720进行开发。
打开Ubuntu,执行如下命令,创建RK3588工作目录。
Host# mkdir -p /home/tronlong/RK3588

请将LinuxSDK开发包拷贝至RK3588工作目录,执行如下命令,将LinuxSDK开发包解压至RK3588工作目录。耗时5min后解压完成,生成rk3588_linux_release_v1.2.1文件夹,即为LinuxSDK源码目录。为了减少LinuxSDK大小,通过repo进行压缩,压缩后在LinuxSDK源码目录下生成.repo的隐藏目录。
备注:LinuxSDK版本号以实际情况为准。
Host# cd /home/tronlong/RK3588/
Host# tar -zxf LinuxSDK-v2.0.tar.gz

执行如下命令,查看当前LinuxSDK源码目录。
备注:LinuxSDK-v2.5.tar.gz及以上版本,无需从repo仓库更新LinuxSDK源码。
Host# cd rk3588_linux_release_v1.2.1/
Host# ls -al


请将产品资料“4-软件资料\Debian\LinuxSDK\”目录下的dl.tar.gz压缩包拷贝至"RK3588/rk3588_linux_release_v1.2.1/buildroot/"目录。dl.tar.gz压缩包用于存放从官网下载的开源软件包,LinuxSDK编译时可从该目录获取开源包,以节约下载时间,提高编译效率,且能避免因网络环境差异导致编译失败的问题。

执行如下命令,将dl.tar.gz压缩包解压至当前目录。
Host# tar -zxf dl.tar.gz

进入LinuxSDK源码目录,执行如下命令配置编译选项。
Host# ./build.sh device/rockchip/rk3588/tl3588_evm_defconfig

由于部分外设功能之间存在引脚复用关系,因此需通过不同的设备树文件进行配置。我司提供的设备树文件位于LinuxSDK源码"kernel/arch/arm64/boot/dts/rockchip/"目录,具体说明如下。

评估板使用的设备树文件存在多级的依赖关系,具体如下表所示。表中的下一级设备树文件,被上一级设备树文件所引用。

LinuxSDK默认编译的设备树文件为tl3588-evm.dts,如需替换为支持对应功能的其他设备树,请参考以下步骤修改。本次操作以替换为tl3588-evm-edp.dts设备树进行演示,如需使用支持其它设备树,修改方法同理。
执行如下命令,修改"device/rockchip/rk3588/tl3588_evm_defconfig"文件。
Host# vi device/rockchip/rk3588/tl3588_evm_defconfig

修改内容如下:
#RK_KERNEL_DTS_NAME="tl3588-evm" //添加注释符"#"
RK_KERNEL_DTS_NAME="tl3588-evm-edp" //删除注释符"#"

执行如下命令,配置编译选项。
Host# ./build.sh device/rockchip/rk3588/tl3588_evm_defconfig

我司默认配置的是Linux内核(推荐使用)。如需修改内核编译选项配置,请继续执行"make xxx menuconfig"命令打开图形配置界面。此命令通过读取当前目录的.config文件,以图形界面的方式提供内核编译配置查看和修改方法。如无需修改内核编译选项配置,可跳过此步骤。
menuconfig是一套图形化的配置工具,需要ncurses库支持。ncurses库提供了一系列的API函数供调用者生成基于文本的图形界面,因此需要先执行如下命令通过网络安装ncurses库。
Host# sudo apt-get install libncurses5-dev
Host# sudo apt-get install libncursesw5-dev

ncurses库安装完成后,执行如下命令打开图形配置界面。
Host# ./build.sh kernel-config


可通过键盘的方向键选中对应菜单栏。在<Select>被选中的情况下,可按Enter键进入子菜单。菜单选项中蓝色高亮的字母代表此菜单选项的快捷键,可在键盘上按下对应的字母快速选中对应的菜单选项。
每个菜单选项前的括号内容表示当前菜单选项的配置状态。选中对应的菜单选项后,按下Y键,会将相应的选项配置编译到内核中,同时菜单选项前面变为< * >。按下N键,不会将相应的选项配置编译到内核中。按下M键,会将相应的选项配置编译为内核模块,菜单选项前面变为< M >。如需搜索,可按下/键打开搜索框,然后输入要搜索的内容。

在图形配置界面中,进入"General setup -> Preemption Model (Voluntary Kernel Preemption (Desktop)) ---> "路径,选中"Fully Preemptible Kernel (Real-Time)"选项,即可配置为Linux-RT内核,此时菜单选项前面变为( X )。反之,则配置为Linux内核。

配置完毕后,可双击Esc键自动保存退出。

在LinuxSDK安装目录下执行如下命令,一键编译生成U-Boot、Kernel、Debian、Recovery等镜像,并打包生成Debian系统镜像。
Host# ./build.sh

由于当前模式为非root用户,因此在编译过程中若遇到如下提示,请输入用户密码,本次输入Tronlong。

预计耗时约2小时后编译完成,最终在rockdev目录下生成U-Boot、Kernel、Debian、Recovery等镜像和Debian系统镜像,如下图所示。



请参考《系统启动卡制作及系统固化》文档,将Debian系统镜像文件固化至Micro SD卡或eMMC。
备注:由于每次执行命令"./build.sh"编译LinuxSDK都会备份output目录下的镜像至"output/TL3588-EVM/DEBIAN/20231221_164609/IMAGES/"目录下,将会占用较多的存储空间,因此请根据实际情况删除无需保留的镜像文件,释放储存空间。

由于篇幅过长等原因,部分内容均不逐一展示,如需获取完整版详细资料,请关注创龙科技微信公众号或官网,或者评论区留言,感谢您的支持!
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。