这里提供两种编译方案,如果要直接编译就选方案一,如果想用docker编译就选方案二。
注意事项:
1. SDK 采用交叉编译,所以要在 X86_64 电脑上使用 SDK,不要将 SDK 下载到板子上。
2. 编译环境请使用 Ubuntu20.04/Ubuntu22.04(真机或 docker 容器),如果使用其他版本可能导致编译出错。
3. 不要在虚拟机共享文件夹以及非英文目录存放、解压SDK。
4. 获取、编译 SDK 请全程使用普通用户,不允许也不需要使用 root 权限(除非需要 apt 安装软件)
准备事项,根据自己的情况有选择的配置
从下载页面下载源码,放到x86 Ubuntu主机或者虚拟机里面。
资料下载,点击跳转
mkdir YY3588_Debian12
tar zxf yy3588_linux6.1_release_v0.0_20250429_sdk.tar.gz -C YY3588_Debian12
.repo/repo/repo sync -l
安装源码编译需要的依赖
sudo apt update
sudo apt-get install git ssh make gcc libssl-dev liblz4-tool expect g++ patchelf chrpath gawk texinfo chrpath diffstat binfmt-support qemu-user-static live-build bison flex fakeroot cmake gcc-multilib g++-multilib python2 unzip device-tree-compiler ncurses-dev
./yy3588-build.sh
完整编译得到完整的固件大小是4G多。烧录完整的固件花费的时间比较多,不利于驱动等程序调试。这里提供分步编译,需要
ubootcd u-boot
./make.sh rk3588
kernelcd kernel
make CROSS_COMPILE=../prebuilts/gcc/linux-x86/aarch64/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu- ARCH=arm64 rockchip_linux_defconfig rk3588_linux.config
make CROSS_COMPILE=../prebuilts/gcc/linux-x86/aarch64/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu- ARCH=arm64 rk3588s-yyt.img
reocvery./build.sh recovery
./build.sh firmware
./build.sh updateimg
安装源码编译需要的依赖
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
sudo apt update
apt-cache policy docker-ce
sudo apt install docker-ce
sudo groupadd docker
sudo usermod -aG docker $USER
sudo reboot
sudo systemctl status docker
./docker/docker-rm.sh
./docker/docker-start.sh
./yy3588-build.sh
./docker/docker-rm.sh
./docker/docker-start.sh
ubootcd u-boot
./make.sh rk3588
kernelcd kernel
make CROSS_COMPILE=../prebuilts/gcc/linux-x86/aarch64/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu- ARCH=arm64 rockchip_linux_defconfig rk3588_linux.config
make CROSS_COMPILE=../prebuilts/gcc/linux-x86/aarch64/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnu/bin/aarch64-none-linux-gnu- ARCH=arm64 rk3588s-yyt.img
reocvery./build.sh recovery
./build.sh firmware
./build.sh updateimg
这里提供两种编译方案,如果要直接编译就选方案一,如果想用docker编译就选方案二。
注意事项:
1. SDK 采用交叉编译,所以要在 X86_64 电脑上使用 SDK,不要将 SDK 下载到板子上。
2. 编译环境请使用 Ubuntu20.04/Ubuntu22.04(真机或 docker 容器),如果使用其他版本可能导致编译出错。
3. 不要在虚拟机共享文件夹以及非英文目录存放、解压SDK。
4. 获取、编译 SDK 请全程使用普通用户,不允许也不需要使用 root 权限(除非需要 apt 安装软件)
编译 Android 对机器的配置要求较高:
如果使用的是16g物理内存,要完成编译Android14源,需要再增加16G的交换内存,以下是增加交换内存步骤。
sudo fallocate -l 16G /swapfile
sudo chmod 600 /swapfile
sudo mkswap /swapfile
sudo swapon /swapfile
sudo swapon --show
sudo vim /etc/fstab
## 增加以下内容
/swapfile swap swap defaults 0 0
从下载页面下载源码,放到x86 Ubuntu主机或者虚拟机里面。
资料下载,点击跳转
解压源码步骤:
mkdir YY3588_Android14
cat yy3588_android14.0_release_v0.0_20250514_sdk.tgz* | tar zxf - -C YY3588_Android14
cd YY3588_Android14
.repo/repo/repo sync -l
在编译源码前需要安装一系列环境依赖。
sudo apt-get update
sudo apt-get install git gnupg flex bison gperf libsdl1.2-dev \
libesd-java libwxgtk3.0-dev squashfs-tools build-essential zip curl \
libncurses5-dev zlib1g-dev pngcrush schedtool libxml2 libxml2-utils \
xsltproc lzop libc6-dev schedtool g++-multilib lib32z1-dev lib32ncurses5-dev \
lib32readline-dev gcc-multilib libswitch-perl libssl-dev unzip zip device-tree-compiler \
liblz4-tool python-pyelftools python3-pyelftools -y
完整编译是将一系列分区固件如uboot、boot分区固件合并成一个完整的固件,烧录完整固件相比于分区烧录操作简单。
source build/envsetup.sh
lunch rk3588_u-userdebug
./build.sh -UKAu
分区编译是将各个分区源码单独编译成分区固件,分区固件体积相比于完整固件小很多,在驱动调试中,单独烧写对应的分区固件,无须烧录其他分区。大大提高烧录固件速度,以及调试速度。
source build/envsetup.sh
lunch rk3588_u-userdebug
uboot./build.sh -U
kernel./build.sh -K
android./build.sh -A
./build.sh -u
在编译源码前需要安装一系列环境依赖。
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
sudo apt update
apt-cache policy docker-ce
sudo apt install docker-ce
sudo groupadd docker
sudo usermod -aG docker $USER
sudo reboot
sudo systemctl status docker
完整编译是将一系列分区固件如uboot、boot分区固件合并成一个完整的固件,烧录完整固件相比于分区烧录操作简单。
./docker/docker-rm.sh
./docker/docker-start.sh
source build/envsetup.sh
lunch rk3588_u-userdebug
./build.sh -UKAu
分区编译是将各个分区源码单独编译成分区固件,分区固件体积相比于完整固件小很多,在驱动调试中,单独烧写对应的分区固件,无须烧录其他分区。大大提高烧录固件速度,以及调试速度。
./docker/docker-rm.sh
./docker/docker-start.sh
uboot./build.sh -U
kernel./build.sh -K
android./build.sh -A
./build.sh -u
sudo apt-get update && sudo apt-get install binutils git git-lfs gnupg flex bison gperf build-essential zip curl zlib1g-dev gcc-multilib g++-multilib libc6-dev-i386 lib32ncurses5-dev x11proto-core-dev libx11-dev lib32z1-dev ccache libgl1-mesa-dev libxml2-utils xsltproc unzip m4 bc gnutls-bin python3.8 python3-pip ruby
git config --global user.name "yourname"
git config --global user.email "your-email-address"
git config --global credential.helper store
curl -s https://gitee.com/oschina/repo/raw/fork_flow/repo-py3 \>
/usr/local/bin/repo \#如果没有权限,可下载至其他目录,并将其配置到环境变量中
chmod a+x /usr/local/bin/repo
pip3 install -i https://repo.huaweicloud.com/repository/pypi/simple requests
repo init -u http://dd.youyeetoo.cn:8000/ohos_yy3588/manifest_yy3588 -b master -m default.xml
repo sync -c
repo forall -c 'git lfs pull'
bash build/prebuilts_download.sh
./build.sh --product-name YY3588 –ccache
编译完成之后,固件生成到目录:
使用RKDevTool.exe烧录固件,在镜像目录中存在一个config.cfg,在RKDevTool.exe导入该配置,导入完配置确定一下你的镜像目录是不是全部正确。
板子按住RECOVERY键,然后上电,这时设备进入loader模式,RKDevTool.exe会显示发现一个LOADER设备,点击执行。
下载源码
资料下载,点击跳转
把源码分卷压缩包进行md5校验,确保下载的源码完整。在X86 Ubuntu系统中输入下面命令进行校验
md5sum YY3588-Ubuntu.tar.gz.0* -c YY3588-Ubuntu.tar.gz.md5
cat YY3588-Ubuntu.tar.gz.* | tar -xzv
cd YY3588-Ubuntu
./.repo/repo/repo sync -l
sudo apt-get install git gnupg flex bison gperf libsdl1.2-dev \
libesd-java libwxgtk3.0-dev squashfs-tools build-essential zip curl \
libncurses5-dev zlib1g-dev pngcrush schedtool libxml2 libxml2-utils \
xsltproc lzop libc6-dev schedtool g++-multilib lib32z1-dev lib32ncurses5-dev \
lib32readline-dev gcc-multilib libswitch-perl libssl-dev unzip zip device-tree-compiler \
liblz4-tool python-pyelftools python3-pyelftools -y
./yy3588-build.sh
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu bionic stable"
sudo apt update
apt-cache policy docker-ce
sudo apt install docker-ce
sudo groupadd docker
sudo usermod -aG docker $USER
sudo reboot
sudo systemctl status docker
./docker/docker-start.sh
./yy3588-build.sh
本源码使用Overlayfs文件系统,将Ubuntu固件的根文件系统分为三部分rootfs、oem、userdata,分别存放在rootfs、oem和userdata对应分区上。其中rootfs和oem为厂家维护,用户勿动。用户只需要在userdata对应位置修改即可。系统启动后会将三个分区的内容合并挂载到userdata分区,同路径下的同名文件会覆盖,同路径下的不同文件会进行合并到同一个目录下。
本Ubuntu源码的Overlayfs的目录结构介绍
oem对应的路径为 device/rockchip/common/extra-parts/oem/normal 如下图:

userdata对应的路径 device/rockchip/common/extra-parts/userdata/normal/upper 和 device/rockchip/common/extra-parts/userdata/normal/lower 如下图:

rootfs对应的路径为 rockdev/rootfs.img
覆盖关系如下:
device/rockchip/common/extra-parts/userdata/normal/upper 同路径下的同名文件会覆盖 device/rockchip/common/extra-parts/userdata/normal/lower 下的文件,同路径下的不同文件会进行合并到同一个目录下。其中upper和lower文件夹区别是,Ubuntu系统启动后,在系统中修改的文件是直接修改userdata分区下upper目录里面对应文件。还有是如果Ubuntu系统进行恢复出厂设置,userdata分区下upper目录会清空。而userdata分区下的lower则不会。
device/rockchip/common/extra-parts/userdata/normal/lower 同路径下的同名文件会覆盖 device/rockchip/common/extra-parts/oem/normal 下的文件,同路径下的不同文件会进行合并到同一个目录下。
device/rockchip/common/extra-parts/oem/normal 同路径下的同名文件会覆盖rockdev/rootfs.img下的文件,同路径下的不同文件会进行合并到同一个目录下。
复制一份要修改的文件到device/rockchip/common/extra-parts/userdata/normal/lower目录下的对应位置,然后修改
例如:修改media/retroarch.cfg文件
cp device/rockchip/common/extra-parts/oem/normal/media/retroarch.cfg device/rockchip/common/extra-parts/userdata/normal/lower/media/retroarch.cfg
# 修改retroarch.cfg内容
vim device/rockchip/common/extra-parts/userdata/normal/lower/media/retroarch.cfg
# 编译源码
rm -fr output
./yy3588-build.sh
烧录固件,系统起来后,查看/media/retroarch.cfg内容是否改变。
# 如果device/rockchip/common/extra-parts/userdata/normal/lower下目录不存在就创建对应目录
mkdir -p device/rockchip/common/extra-parts/userdata/normal/lower/usr/bin
# 创建对应文件
echo 'echo "hello world!!!"' > device/rockchip/common/extra-parts/userdata/normal/lower/usr/bin/hello.sh
# 添加可执行权限
chmod +x device/rockchip/common/extra-parts/userdata/normal/lower/usr/bin/hello.sh
# 编译源码
rm -fr output
./yy3588-build.sh
烧录固件,系统起来后可以看到/bin/hello.sh文件,执行/bin/hello.sh查看效果。
Overlayfs 删除文件是创建一个whiteout文件,用于屏蔽底层的同名文件,同时该文件在Overlayfs merge层是不可见的,所以用户就看不到被删除的文件或目录了。whiteout文件并非普通文件,而是主次设备号都为0的字符设备。
mknod <文件名> c 0 0
例如:我们要删除oem分区里面的media/game_test.gba,不建议直接删除,而是通过在userdata分区里面的lower目录里面创建一个名字为game_test.gba 的whiteout文件。
# 挂载userdata.img
mkdir rockdev/tmp
sudo mount rockdev/userdata.img rockdev/tmp
# 创建一个名字为game_test.gba 的whiteout文件。
sudo mknod rockdev/tmp/media/game_test.gba c 0 0
sudo umount rockdev/tmp
# 编译源码
./yy3588-build.sh
烧录固件,系统起来后,查看/media/game_test.gba是否还存在。