From 2ff22fb6d0d602092a83e11d12648febdfe4acdf Mon Sep 17 00:00:00 2001 From: guowenxue <guowenxue@gmail.com> Date: Sat, 22 Mar 2025 00:38:00 +0800 Subject: [PATCH] update RK3568 Linux SDK doc --- RK3568_Linux_SDK开发文档/RK3568_Linux_SDK开发文档.md | 702 +++++++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 540 insertions(+), 162 deletions(-) diff --git "a/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243.md" "b/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243.md" index e5df926..27fb90e 100644 --- "a/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243.md" +++ "b/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243/RK3568_Linux_SDK\345\274\200\345\217\221\346\226\207\346\241\243.md" @@ -8,7 +8,7 @@ * CPU 8核+、内存32GB+ 以上; * 硬盘空间 1TB+; -推荐在凌云实验室的编译服务器上编译,IGKBoard-RK3568开发板请选择使用 ***sdkv1.3.0_linux4.19*** 版本。 +推荐在凌云实验室的物理编译服务器上编译,IGKBoard-RK3568开发板请选择使用 ***sdkv1.4.0_linux5.10*** 版本。 @@ -27,24 +27,24 @@ - 如果是 ***sdkv1.3.0_linux4.19*** 则需要将 python 的版本设置为 **python2**, 而 ***sdkv1.4.0_linux5.10*** 则需要选择 **python3**。 +***sdkv1.4.0_linux5.10*** 编译所需要的 Python版本依赖 **python3**。 ``` -guowenxue@ubuntu22:~$ sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 1 -guowenxue@ubuntu22:~$ sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 2 +guowenxue@ubuntu22:~$ sudo update-alternatives --install /usr/bin/python python /usr/bin/python3 1 +guowenxue@ubuntu22:~$ sudo update-alternatives --install /usr/bin/python python /usr/bin/python2 2 guowenxue@ubuntu22:~$ sudo update-alternatives --config python There are 2 choices for the alternative python (providing /usr/bin/python). Selection Path Priority Status ------------------------------------------------------------ * 0 /usr/bin/python3 2 auto mode - 1 /usr/bin/python2 1 manual mode - 2 /usr/bin/python3 2 manual mode + 1 /usr/bin/python3 1 manual mode + 2 /usr/bin/python2 2 manual mode Press <enter> to keep the current choice[*], or type selection number: 1 -guowenxue@ubuntu22:~$ python --version -Python 2.7.18 +guowenxue@ubuntu22:~/rk3568$ python --version +Python 3.10.12 ``` @@ -56,35 +56,15 @@ 首先创建 RK3568 开发板的项目工作路径。 ``` -guowenxue@ubuntu20:~$ mkdir rk3568 && cd rk3568 +guowenxue@ubuntu22:~$ mkdir -p rk3568/sdkv1.4.0_linux5.10 && cd rk3568/sdkv1.4.0_linux5.10 ``` -如果选择 ***sdkv1.3.0_linux4.19*** 版本SDK,则可以使用下面命令从凌云实验室文件服务器上下载并解压缩。 +RK3568 的 ***sdkv1.4.0_linux5.10*** 压缩包就存放在物理主机服务器下, 我们直接在工作路径下解压缩即可。 ``` -guowenxue@ubuntu22:~/rk3568$ mkdir sdkv1.3.0_linux4.19 && cd sdkv1.3.0_linux4.19 - -guowenxue@ubuntu22:~/rk3568/sdkv1.3.0_linux4.19$ wget http://192.168.0.2:2211/rockchip/bsp/rk3568_linuxSDK/sdkV1.3.0_linux4.19/rk356x_linux_release_v1.3.0_20220925.tgz - -guowenxue@ubuntu22:~/rk3568/sdkv1.3.0_linux4.19$ tar -xzf rk356x_linux_release_v1.3.0_20220925.tgz - -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ rm -f *.tgz -``` - - - -如果选择 ***sdkv1.4.0_linux5.10*** 版本SDK,则可以使用下面命令从凌云实验室文件服务器上下载并解压缩。 - -```bash -guowenxue@ubuntu22:~/rk3568$ mkdir sdkv1.4.0_linux5.10 && cd sdkv1.4.0_linux5.10 - -guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ wget http://192.168.0.2:2211/rockchip/bsp/rk3568_linuxSDK/sdkV1.4.0_linux5.10/rk356x_linux5.10_release_v1.4.0_20231220.tgz - -guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ tar -xzf rk356x_linux5.10_release_v1.4.0_20231220.tgz - -guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ rm -f *.tgz +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ tar -xjf /srv/ftp/rockchip/bsp/rk3568_linuxsdk/sdkv1.4.0_linux5.10/rk356x_linux5.10_release_v1.4.0_20231220.tar.bz2 ``` @@ -92,36 +72,71 @@ 解压缩出来的源码都在隐藏的 ***.repo*** 文件夹下,接下来我们使用 **repo** 命令将源码 checkout 出来。 ``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ls -a +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls -a . .. .repo -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ls .repo/ +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ du -sh .repo/ +18G .repo/ + +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls .repo/ manifests manifests.git manifest.xml project.list project-objects projects repo -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ .repo/repo/repo sync -l -Updating files: 100% (17139/17139), done./app/rkaiq_tool_serverUpdating files: 51% (8839/17139) -Updating files: 100% (779/779), done.inux/buildrootUpdating files: 41% (322/779) -Updating files: 100% (1171/1171), done.ux/debianUpdating files: 72% (844/1171) -Updating files: 100% (248/248), done.inux/device/rockchipUpdating files: 10% (25/248) -Updating files: 100% (247/247), done.inux/bsp/docsUpdating files: 45% (112/247) -Updating files: 100% (1493/1493), done.ux/bsp/external/broadcom_bsaUpdating files: 41% (622/1493) -Updating files: 100% (127/127), done.inux/external/libglCompositorUpdating files: 44% (56/127) -Updating files: 100% (118/118), done.inux/external/rkfacialUpdating files: 29% (35/118) -Updating files: 100% (921/921), done.k/rknn-toolkit2Updating files: 5% (52/921) -Updating files: 100% (368/368), done.inux/external/rkupdateUpdating files: 22% (84/368) -Updating files: 100% (186/186), done.inux/external/rkwifibtUpdating files: 59% (110/186) -Updating files: 100% (2109/2109), done.ux/security/binUpdating files: 15% (332/2109) -Updating files: 100% (33/33), done. android/rk/platform/system/rk_tee_userUpdating files: 93% (31/33) -Updating files: 100% (72280/72280), done./external/uvc_appUpdating files: 3% (2631/72280) -Updating files: 100% (17900/17900), done.rnelUpdating files: 34% (6102/17900) -Updating files: 100% (7165/7165), done.prebuilts/gcc-buildroot-9.3.0-2020.03-x86_64_aarch64-rockchip-linux-gnuUpdating files: 13% (949/7165) -Updating files: 100% (236/236), done.k/rkbinUpdating files: 46% (109/236) -Updating files: 100% (13576/13576), done./toolsUpdating files: 88% (12076/13576) -Checking out projects: 100% (65/65), done. +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls .repo/repo/repo +.repo/repo/repo +test@ubuntu22:/work/test/sdkv1.4.0_linux5.10$ .repo/repo/repo sync -l +Traceback (most recent call last): + File "/work/test/sdkv1.4.0_linux5.10/.repo/repo/main.py", line 56, in <module> + from subcmds.version import Version + File "/work/test/sdkv1.4.0_linux5.10/.repo/repo/subcmds/__init__.py", line 35, in <module> + mod = __import__(__name__, + File "/work/test/sdkv1.4.0_linux5.10/.repo/repo/subcmds/help.py", line 20, in <module> + from formatter import AbstractFormatter, DumbWriter +ModuleNotFoundError: No module named 'formatter' +``` + + + +出现上面这个问题是因为 **Python3** 已经移除了 `formatter` 的支持,这时候我们可以先将 Python 版本切换为 **Python2** ,等 `repo` sync成功之后,再切回到 Python3 上去。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ sudo update-alternatives --config python +There are 2 choices for the alternative python (providing /usr/bin/python). + + Selection Path Priority Status +------------------------------------------------------------ +* 0 /usr/bin/python3 2 auto mode + 1 /usr/bin/python3 1 manual mode + 2 /usr/bin/python2 2 manual mode + +Press <enter> to keep the current choice[*], or type selection number: 2 + +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ python --version +Python 2.7.18 + +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ .repo/repo/repo sync -l +Updating files: 100% (13563/13563), done. +Updating files: 100% (737/737), done.nux/buildrootUpdating files: 26% (197/737) +Updating files: 100% (778/778), done.nux/debianUpdating files: 20% (160/778) +Updating files: 100% (228/228), done.nux/bsp/docsUpdating files: 27% (62/228) +Updating files: 100% (2195/2195), done.ux/external/alsa-configUpdating files: 8% (197/2195) +Updating files: 100% (227/227), done.inux/external/camera_engine_rkaiqUpdating files: 1% (4/227) +Updating files: 100% (152/152), done.inux/external/chromiumUpdating files: 48% (74/152) +Updating files: 100% (166/166), done.inux/gstreamer-rockchipUpdating files: 35% (59/166) +Updating files: 100% (237/237), done.inux/external/rk_pcba_testUpdating files: 40% (97/237) +Updating files: 100% (1203/1203), done.rknn-toolkit2Updating files: 11% (135/1203) +Updating files: 100% (5531/5531), done.ux/external/rkupdateUpdating files: 98% (5430/5531) +Updating files: 100% (81714/81714), done./xserverUpdating files: 8% (6747/81714) +Updating files: 100% (5939/5939), done.kernelUpdating files: 18% (1082/5939) +Updating files: 100% (5722/5722), done.prebuilts/gcc-arm-10.3-2021.07-x86_64-aarch64-none-linux-gnuUpdating files: 16% (950/5722) +Updating files: 100% (248/248), done.k/rkbinUpdating files: 49% (122/248) +Updating files: 100% (13755/13755), done./toolsUpdating files: 23% (3237/13755) +Updating files: 100% (166/166), done.inux/pokyUpdating files: 8% (14/166) +Updating files: 100% (6157/6157), done.ux/pokyUpdating files: 30% (1893/6157) +Checking out projects: 100% (50/50), done. repo sync has finished successfully. -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ls -app buildroot build.sh debian device docs envsetup.sh external kernel Makefile mkfirmware.sh prebuilts rkbin rkflash.sh tools u-boot yocto +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls +app buildroot build.sh debian device docs envsetup.sh external kernel Makefile prebuilts rkbin rkflash.sh tools u-boot yocto ``` @@ -129,150 +144,284 @@ SDK 相关文档都存放 **docs** 文件夹下。 ``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ls docs/ -Common docs_list.txt Linux Others RK356X RK_Linux_SDK_Supported_System_Kernel_Version_and_ISP_Version_List.png Rockchip_Developer_Guide_Linux_Software_CN.pdf +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls docs/ +cn en licenses Patches readme_en.pdf readme_zh.pdf ``` -如果选择 ***sdkv1.3.0_linux4.19*** 版本SDK,还需要从凌云实验室文件服务器上下载buildroot源码并解压缩。 +完成之后,再将 Python 版本切换为 Python3。 ```bash -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ cd buildroot/ -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19/buildroot$ wget http://192.168.0.2:2211/rockchip/bsp/rk3568_linuxSDK/sdkV1.3.0_linux4.19/buildroot_DL/dl.zip -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19/buildroot$ unzip dl.zip && rm -f dl.zip -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19/buildroot$ cd .. +guowenxue@ubuntu22:~$ sudo update-alternatives --config python +There are 2 choices for the alternative python (providing /usr/bin/python). + + Selection Path Priority Status +------------------------------------------------------------ +* 0 /usr/bin/python3 2 auto mode + 1 /usr/bin/python3 1 manual mode + 2 /usr/bin/python2 2 manual mode + +Press <enter> to keep the current choice[*], or type selection number: 1 + +guowenxue@ubuntu22:~/rk3568$ python --version +Python 3.10.12 ``` -## 1.3 Buildroot 配置 +接下来我们首先需要制作嵌入式Linux根文件系统,它的制作通常有如下三种方式: -常见的文件系统制作就这几个: -1, Buildroot; -2, Yocto; -3, 直接用第三方的,如 debian、ubuntu 等 +1. Buildroot; +2. Yocto; +3. Debian、Ubuntu、Armbian 等; -Rockchip提供的Linux 的SDK里面默认使用的Buildroot来构建根文件系统,那如果需要想让根文件系统添加一些别的命令支持则需要对Buildroot进行配置 -此处以添加Python3为例说明 -首先我们需要配置编译需要的配置 +Rockchip的Linux SDK提供了 **Buildroot** 和 **Debian** 两种方式制作根文件系统,其中我们使用默认的Buildroot来构建。 -1.进入~/rk3568/sdkv1.3.0_linux4.19 -输入`source envsetup.sh` -选择67.rockchip_rk3568 表示使用rk3568的相关配置 +## 1.3 Buildroot 文件系统制作 + + + +在开始制作之前,我们首先需要使用 `source envsetup.sh` 命令对Buildroot进行配置,这里选择 `55. rockchip_rk3568` ,表示使用基于该开发板的默认配置。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ source envsetup.sh +... ... 弹出下图选项框 +Merging /work/guowenxue/sdkv1.4.0_linux5.10/buildroot/configs/rockchip_rk3568_defconfig +# +# merged configuration written to /work/guowenxue/sdkv1.4.0_linux5.10/buildroot/output/rockchip_rk3568/.config.in (needs make) +# +... ... +defconfig=/work/guowenxue/sdkv1.4.0_linux5.10/buildroot/output/rockchip_rk3568/.config.in Config.in +# +# configuration written to /work/guowenxue/sdkv1.4.0_linux5.10/buildroot/output/rockchip_rk3568/.config +# +make: Leaving directory '/work/guowenxue/sdkv1.4.0_linux5.10/buildroot' +``` + +  - - -此时可以看到配置中显示了目标板子,编译输出目录和使用的defconfig文件是哪个 -2.进入~/rk3568/sdkv1.3.0_linux4.19/buildroot -输入`make menuconfig` 找到python3,位置在Target packages ->Interpreter languages and scripting->python3选中。 +基于 Buildroot 的方式构建根文件系统,我们可以定制开发,这里以添加 **Python** 的支持为例讲解该过程。首先进入到 `buildroot` 文件夹下,然后执行 `make menuconfig` 命令。 - +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ cd buildroot/ +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10/buildroot$ export TERM=vt100 +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10/buildroot$ make menuconfig +``` -选中python3后保存退出。 -输入`make savedefconfig` 此时系统会把你所改变的config信息直接同步到rockchip_rk3568_defconfig -3.编译buildroot +在弹出的菜单栏对话框,选中 `Target packages ->Interpreter languages and scripting->python3` 并退出保存即可。 -返回~/rk3568/sdkv1.3.0_linux4.19/ + -输入`./build.sh buildroot`编译buildroot -4.烧录编译出来的buildroot镜像到开发板中,输入`Python3` - +完成配置后再输入下面命令,系统会把你所改变的config信息直接同步到rockchip_rk3568_defconfig 文件中去。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10/buildroot$ make savedefconfig +``` + + + +接下来返回项目顶层,执行 `build.sh` 脚本开始编译buildroot。我们的开发板采用的是 DDR4 内存,在弹出的选项中选择 `5. rockchip_rk3568_evb1_ddr4_v10_defconfig`。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10/buildroot$ cd .. +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ./build.sh buildroot +``` + + + + + +编译完成后的成功输出如下: + + + + + +编译生成的 Buildroot 文件系统将会存放在 ***output/buildroot/images*** 路径下。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls output/buildroot/images +rootfs.cpio rootfs.cpio.gz rootfs.ext2 rootfs.ext4 rootfs.squashfs rootfs.tar +``` + + + +需要注意的是这里只编译制作了根文件系统,还没有编译 Linux 内核和系统镜像,我们稍后将会完成这些操作。 ## 1.4 Debian构建根文件系统 -瑞芯微的SDK中已经提供的Debian的源码,路径是~/rk3568/sdkv1.3.0_linux4.19/debian -在编译和构建Debian_rootfs之前需要在系统里安装相关工具和依赖 -``` -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 unzip device-tree-compiler ncurses-dev +瑞芯微的SDK中同样也提供制作Debian根文件系统的脚本,它们存放在 ***debian*** 文件夹下。这样我们可以很轻松地制作出基于 **Debian** 的根文件系统。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls +app build.sh debian docs kernel output README.md rkflash.sh u-boot +buildroot common device external Makefile prebuilts rkbin tools yocto + +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls debian/ +mk-base-debian.sh mk-rootfs-bullseye.sh overlay-debug packages-patches scripts +mk-image.sh mk-rootfs.sh overlay-firmware post-build.sh +ubuntu-build-service mk-iso-debian.sh overlay packages readme.md ``` -``` -sudo dpkg -i debian/ubuntu-build-service/packages/* -sudo apt-get install -f + + +在编译和构建 Debian 根文件系统之前,需要安装如下相关系统工具和依赖。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ sudo apt-get update +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ sudo apt-get install git \ + 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 python2 ssh make gcc libssl-dev + +guowenxue@ubuntu22:~$ sudo dpkg -i debian/ubuntu-build-service/packages/* +guowenxue@ubuntu22:~$ sudo apt-get install -f ``` -说明: -其中最为核心的东西是debootstrap和qemu-user-static -这里的debootstrap就是在packages里面 +其中最为核心的东西是 **debootstrap** 和 **qemu-user-static**: - +* 其中 debootstrap 用于构建debian基本文件子系统的工具,这里的debootstrap就是在packages里面。 -debootstrap 构建debian基本文件子系统的工具。 + ```bash + guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls debian/ubuntu-build-service/packages/ + debootstrap_1.0.123_all.deb live-build_20210902_all.deb qemu_5.2+dfsg-11_amd64.deb + ``` -qemu-user-static 在PC端非arm架构的ubuntu系统上,需要借助于qemu-arm-static工具来模拟arm环境安才可以安装arm架构下所需要的软件。 + -安装好这些必要工具后,就可以开始编译Debian了 +* qemu-user-static 在PC端非arm架构的ubuntu系统上,需要借助于qemu-arm-static工具来模拟arm环境安才可以安装arm架构下所需要的软件。 -返回到~/rk3568/sdkv1.3.0_linux4.19/目录 -输入`./build.sh debian`开始编译,编译后的镜像文件放在了~/rk3568/sdkv1.3.0_linux4.19/debian - +安装好这些必要工具后,就可以开始编译Debian文件系统了。 -我们需要将这个镜像文件烧录到开发板中 +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ./build.sh debian +... ... +mke2fs 1.46.5 (30-Dec-2021) +Creating regular file linaro-rootfs.img +Creating filesystem with 825088 4k blocks and 206336 inodes +Filesystem UUID: 9c7ffd7d-1315-4be2-9bb1-153c751dfe45 +Superblock backups stored on blocks: + 32768, 98304, 163840, 229376, 294912, 819200 + +Allocating group tables: done +Writing inode tables: done +Creating journal (16384 blocks): done +Copying files into the device: done +Writing superblocks and filesystem accounting information: done + +Rootfs Image: linaro-rootfs.img +Running 30-rootfs.sh - build_debian /work/guowenxue/sdkv1.4.0_linux5.10/output/debian/images succeeded. +Running 30-rootfs.sh - build_rootfs debian succeeded. +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ +``` + + + +在运行 `./build.sh debian` 可能会出现如下错误: + + + + + +我们只需要依据提示更新一些工具即可。 + +``` +sudo update-binfmts --unimport qemu-aarch64 2>/dev/null +sudo update-binfmts --disable qemu-aarch64 2>/dev/null +sudo rm -f /usr/bin/qemu-aarch64-static +sudo cp ~/rk3568/sdkv1.4.0_linux5.10/device/rockchip/common/data/qemu-aarch64-static /usr/bin/ +sudo update-binfmts --enable qemu-aarch64 2>/dev/null +sudo update-binfmts --import qemu-aarch64 2>/dev/null +``` + + + +编译后的Debian文件系统镜像将存放在 ***debian*** 文件夹下。 + +```bash +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls debian/ +binary mk-image.sh overlay-debug readme.md +linaro-bullseye-alip-20250321-1.tar.gz mk-iso-debian.sh overlay-firmware scripts +linaro-bullseye-arm64.tar.gz mk-rootfs-bullseye.sh packages ubuntu-build-service +linaro-rootfs.img mk-rootfs.sh packages-patches +mk-base-debian.sh overlay post-build.sh + +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ du -sh debian/linaro-rootfs.img +3.0G debian/linaro-rootfs.img +``` + + + +后面在烧录系统镜像时,只需将烧录的rootfs文件替换成这里编译生成的 `linaro-rootfs.img` 文件即可,该系统的默认用户名和密码均为 `linaro`。  -我们将烧录的rootfs文件替换成linaro-rootfs.img即可 -烧录完成后启动开发板,会提示输入用户名和密码,这里的用户名和密码在编译脚本里写好了的均为linaro - -登录后切换su用户`sudo su`,进入根目录下展示的就是Debian的根文件系统 - - ## 1.5 Linux SDK源码编译 - - - -首先使用下面命令选择要编译的目标开发板,SDK版本不一样,该选项的名字不一样。 - -``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ./build.sh lunch - -5. BoardConfig-rk3568-evb1-ddr4-v10.mk # sdkv1.3.0_linux4.19 选择该选项 -5. rockchip_rk3568_evb1_ddr4_v10_defconfig # sdkv1.4.0_linux5.10 选择该选项 -Which would you like? [0]: 5 -``` 如果需要,可以使用下面命令来彻底清除之前的编译。 ``` -guowenxue@ubuntu22:~/rk3568/sdk$ ./build.sh cleanall +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ./build.sh cleanall ``` - ***sdkv1.3.0_linux4.19*** 和 ***sdkv1.4.0_linux5.10*** 版本SDK 都需要修改 IO Domain 电压如下。 +首先使用下面命令选择要编译的目标开发板,这里选择 `5. rockchip_rk3568_evb1_ddr4_v10_defconfig`。 ``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ vim kernel/arch/arm64/boot/dts/rockchip/rk3568-evb.dtsi +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ./build.sh lunch + +1. rockchip_defconfig +2. rockchip_rk3566_evb2_lp4x_v10_32bit_defconfig +3. rockchip_rk3566_evb2_lp4x_v10_defconfig +4. rockchip_rk3568_evb1_ddr4_v10_32bit_defconfig +5. rockchip_rk3568_evb1_ddr4_v10_defconfig +6. rockchip_rk3568_evb8_lp4_v10_32bit_defconfig +7. rockchip_rk3568_evb8_lp4_v10_defconfig +8. rockchip_rk3568_pcie_ep_lp4x_v10_defconfig +9. rockchip_rk3568_uvc_evb1_ddr4_v10_defconfig +Which would you like? [1]: 5 +Switching to defconfig: /work/guowenxue/sdkv1.4.0_linux5.10/device/rockchip/.chip/rockchip_rk3568_evb1_ddr4_v10_defconfig +# +# configuration written to /work/guowenxue/sdkv1.4.0_linux5.10/output/.config +# +``` + + + +接下来需要修改Linux内核 DTS文件中的 `IO Domain` 电压如下。 + +``` +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ vim kernel/arch/arm64/boot/dts/rockchip/rk3568-evb.dtsi ... ... ... &pmu_io_domains { @@ -280,9 +429,9 @@ pmuio2-supply = <&vcc3v3_pmu>; vccio1-supply = <&vccio_acodec>; vccio3-supply = <&vccio_sd>; - vccio4-supply = <&vcc_1v8>; + vccio4-supply = <&vcc_1v8>; //Modify from 3v3 to 1v8 vccio5-supply = <&vcc_3v3>; - vccio6-supply = <&vcc_1v8>; + vccio6-supply = <&vcc_1v8>; //Modify from 3v3 to 1v8 vccio7-supply = <&vcc_3v3>; }; ``` @@ -292,7 +441,12 @@ 接下来运行 build.sh 脚本开始编译SDK,默认是 Buildroot 系统镜像。 ``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ./build.sh +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ./build.sh +... ... ++ tar -uf /work/guowenxue/sdkv1.4.0_linux5.10/output/firmware/linux-headers.tar scripts tools ++ cd /work/guowenxue/sdkv1.4.0_linux5.10 +Running 99-all.sh - build_all succeeded. +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ``` @@ -300,23 +454,7 @@ 也可以通过设置坏境变量 **RK_ROOTFS_SYSTEM** 指定不同 rootfs。 **RK_ROOTFS_SYSTEM** ⽬前可设定三种系统:***buildroot、debian、 yocto***。 ```bash -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ RK_ROOTFS_SYSTEM=yocto ./build.sh -``` - - - -如果是 ***sdkv1.3.0_linux4.19*** 在编译 Linux内核时需要做如下选择。 - -``` -编译内核过程弹窗的电压选择如下: - 3300000 PMUIO2 Supply Power Voltage(uV) - 3300000 VCCIO1 Supply Power Voltage(uV) - 3300000 VCCIO3 Supply Power Voltage(uV) - 1800000 VCCIO4 Supply Power Voltage(uV) - 3300000 VCCIO5 Supply Power Voltage(uV) - 1800000 VCCIO6 Supply Power Voltage(uV) - 3300000 VCCIO7 Supply Power Voltage(uV) -... ... ... +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ RK_ROOTFS_SYSTEM=yocto ./build.sh ``` @@ -324,8 +462,10 @@ 编译生成的文件将放在 **rockdev** 文件夹下。 ``` -guowenxue@ubuntu22:/build/rk3568/sdkv1.3.0_linux4.19$ ls rockdev/ -boot.img linux-headers.tar MiniLoaderAll.bin misc.img oem.img parameter.txt recovery.img rootfs.img uboot.img update.img userdata.img +guowenxue@ubuntu22:~/rk3568/sdkv1.4.0_linux5.10$ ls rockdev +boot.img misc.img recovery.img update.img +linux-headers.tar oem.img rootfs.img userdata.img +MiniLoaderAll.bin parameter.txt uboot.img ``` @@ -366,10 +506,10 @@ 从凌云实验室文件服务器上下载并安装下面烧录软件。 -* [CP210x_VCP_Windows.zip](http://studio.iot-yun.club:2211/rockchip/tools/CP210x_VCP_Windows.zip) 解压缩并安装开发板的Console调试串口驱动; -* [DriverAssitant_v5.1.1.zip](http://studio.iot-yun.club:2211/rockchip/tools/DriverAssitant_v5.1.1.zip) , 解压缩安装RK3568开发板驱动; +* [CP210x_VCP_Windows.zip](http://studio.weike-iot.com:2211/rockchip/tools/CP210x_VCP_Windows.zip) 解压缩并安装开发板的Console调试串口驱动; +* [DriverAssitant_v5.1.1.zip](http://studio.weike-iot.com:2211/rockchip/tools/DriverAssitant_v5.1.1.zip) , 解压缩安装RK3568开发板驱动; -* [RKDevTool_Release_v2.86.zip](http://studio.iot-yun.club:2211/rockchip/tools/RKDevTool_Release_v2.86.zip) ,直接解压缩即可运行的 RK3568开发板烧录软件; +* [RKDevTool_Release_v2.86.zip](http://studio.weike-iot.com:2211/rockchip/tools/RKDevTool_Release_v2.86.zip) ,直接解压缩即可运行的 RK3568开发板烧录软件; @@ -628,9 +768,15 @@ ## 3.4 RS232和RS485 +### 3.4.1 硬件原理图说明 + -### 3.4.1 内核修改支持 + + + + +### 3.4.2 内核修改支持 RS232 DTS文件修改 @@ -668,9 +814,9 @@ }; ``` -因为RS485是半双工的,所以要么先测接收功能要么测发送功能,从原理图上可以看到,接受与发送功能的切换是GPIO4_D2来控制的,默认情况是接收功能,我们可以利用gpioset命令拉高该gpio让其工作在发送模式 +因为RS485是半双工的,所以要么先测接收功能要么测发送功能,从原理图上可以看到,接受与发送功能的切换是GPIO4_D2来控制的,默认情况是发送功能,我们可以利用gpioset命令拉高该gpio让其工作在接受模式 -### 3.4.2 应用程序测试 +### 3.4.3 应用程序测试 RS232测试 @@ -726,8 +872,6 @@ - - ## 3.5 CAN总线 @@ -737,6 +881,8 @@ DTS文件修改 ```c +#Linux 4.19 + &can0 { compatible = "rockchip,can-1.0"; assigned-clocks = <&cru CLK_CAN0>; @@ -754,6 +900,26 @@ pinctrl-0 = <&can1m1_pins>; status = "okay"; }; + +#Linux 5.10 +&can0 { + compatible = "rockchip,rk3568-can-2.0"; + assigned-clocks = <&cru CLK_CAN0>; + assigned-clock-rates = <150000000>; + pinctrl-names = "default"; + pinctrl-0 = <&can0m1_pins>; + status = "okay"; +}; + +&can1 { + compatible = "rockchip,rk3568-can-2.0"; + assigned-clocks = <&cru CLK_CAN1>; + assigned-clock-rates = <150000000>; + pinctrl-names = "default"; + pinctrl-0 = <&can1m1_pins>; + status = "okay"; +}; + ``` @@ -764,7 +930,9 @@ Networking support -> CAN bus subsystem support -> CAN Device Drivers -> - Platform CAN drivers with Netlink support -> + <*>Platform CAN drivers with Netlink support + <*>Rockchip CAN controller + <*>Rockchip CANFD controller ``` ### 3.5.2 应用程序测试 @@ -810,6 +978,29 @@  + +**CAN单板回环测试** + +将板子的CAN0_H和CAN1_H连接 CAN0_L和CAN1_L连接 + +依次输入以下命令 + +``` +ip link set can0 down +ip link set can0 type can bitrate 500000 +ip link set can0 up + +ip link set can1 down +ip link set can1 type can bitrate 500000 +ip link set can1 up + +candump can0 & +cansend can1 123#01020304050607 +``` + +通过CAN1发送后,CAN0会打印收到的信息 + + ## 3.6 声卡Codec @@ -858,10 +1049,22 @@ 使用amixer设置声卡 +通过`amixer -c 0 contents`可以查看音频硬件的当前状态和可能的设置 + + + +这里的 1 和 2 对应于 `Main Mic` 和 `SPK` 在各自列表中的索引。根据需要调整命令中的索引以设置所需的选项。 + +可以使用如下命令切换至SPK输出 + ``` -amixer cset name='Master Playback Volume' 'on','on' -amixer cset name='Master Playback Volume' '30','30' +amixer -c 0 cset numid=2 2 + +//linux5.10 +amixer -c 0 cset numid=12 3 //HP输出 ``` + + 使用aplay播放WAV格式音乐 @@ -1238,7 +1441,7 @@ ppp拨号方式需要编写三个脚本文件存放在/etc/ppp/peers下 -默认是没有这些文件夹的,所以需要去创建ppp和peer文件夹,创建好后在peers下创建如下三个脚本文件 +默认是没有这些文件夹的,所以需要去创建ppp和peers文件夹,创建好后在peers下创建如下三个脚本文件 **rasppp.sh** @@ -1384,6 +1587,26 @@  + + +**如果使用Linux5.10内核版本,默认内核是没有开启cdc_ether模块即ECM模式,所以要配置内核驱动ECM模式** + +`cdc_ether`是Linux操作系统中的一个内核模块,用于支持USB CDC(Communications Device Class)以太网设备。这个模块允许系统将某些USB设备(例如4G/5G调制解调器、智能手机、USB以太网适配器)识别和配置为网络接口,使其能够像传统的以太网设备一样进行网络通信。 + +当切换到ECM模式后,cdc_ether模块会自动加载,加载`cdc_ether`模块后,系统会创建一个新的网络接口(例如`usb0`),用户可以通过该接口进行网络配置和通信。 + +内核配置如下 + +``` +Device Drivers -> + [*] Network device support -> + <*> USB Network Adapters ---> + <*> Multi-purpose USB Networking Framework ----> + -*- CDC Ethernet support (smart devices such as cable modems) +``` + + + ## 3.11 RK3568自带的NPU ### 3.11.1 应用程序测试 @@ -1469,3 +1692,158 @@ 输入`gpioset 0 4=0` `gpioget 3 3`,显示Din-0的电平应为0 输入`gpioset 0 4=1` `gpioget 3 3`,显示Din-0的电平应为1 + + + +## 3.13 AIN 电流电压测试 + +### 3.13.1 硬件原理图说明 + + + + + +### 3.13.2 AIN 电流测试 + +首先我们需要将ADC采样程序烧录到开发板上的单片机中 + +连接J6000 TTL下载调试串口 Debug_RXD_CN连接串口的TXD Debug_TXD_CN连接串口的RXD GND相连 + + + + + + + +**打开FlyMcu.exe烧录工具,选择准备好的.hex 的单片机程序** + + + + + +**点击开始编程后就开始烧录程序,烧录成功如下图,并且可以看到单片机的LED灯在闪烁绿光** + + + + + +单片机程序烧录好后,我们需要使能RK3568的UART6,根据原理图可以看到,RK3568和MCU通信串口为UART6,所以需要在设备树中设置UART6设备节点 + +打开`~/rk3568/sdkv1.4.0_linux5.10/kernel/arch/arm64/boot/dts/rockchip/rk3568-evb1-ddr4-v10-linux.dts` + +加入URAT6节点 + +``` +&uart6{ + dma-names = "tx", "rx"; + pinctrl-names = "default"; + pinctrl-0 = <&uart6m1_xfer>; + status = "okay"; +}; +``` + + + +重新编译设备树后烧录到开发板中启动开发板,在/dev下看看是否有ttyS6 + + + + + + + + + +按照上图连接电路后,用XCOM软件打开单片机的调试串口,配置如下图所示 + + + + + +在RK3568上运行comport程序,此程序可以配置串口的波特率,停止位,数据位,奇偶校验以及指定使用哪个串口设备 + +源代码在[framwork.git - Gitblit (iot-yun.club)](http://main.iot-yun.club:8088/tree/framwork.git/master/booster) + +但是这个代码需要做一定的修改,因为这个程序只能让串口输出字符串数据,但是我们在测试中需要发送十六进制数据给单片机。 + + + +此时就需要了解ADC串口协议,RK3568发送读指令给MCU,MCU会响应RK3568返回ADC采样数据 + + + +示例如下: + +示例: + +1、读第0通道电压: + +AA 55 02 00 30 8C //CRC:0x8C30 + +AA 55 02 00 EE 0D 99 C0 //0D EE -> 3566mv, CRC:0x0C99 + +2、读第1路通道电压: + +AA 55 02 01 F1 4C + +AA 55 02 01 06 00 47 C5 //00 06 -> 6mv + +3、读第2路通道电压: + +AA 55 02 02 B1 4D + +AA 55 02 02 06 00 B7 C5 //6mv + +4、读第3路通道电压: + +AA 55 02 03 70 8D + +AA 55 02 03 06 00 E6 05 //6mv + +5、读第0路电流 + +AA 55 01 00 30 7C + +AA 55 01 00 95 01 BB 71 //01 95 -> 405 单位0.01mA,即4.05mA, CRC:0x71BB + +6、读第1路电流 + +AA 55 01 01 F1 BC + +AA 55 01 01 95 01 EA B1 + +7、读第2路电流 + +AA 55 01 02 B1 BD + +AA 55 01 02 95 01 1A B1 + +8、读第3路电流 + +AA 55 01 03 70 7D + +AA 55 01 03 95 01 4B 71 + + + +以下AIN电流测试以测试第0路电流为例 + +在RK3568上输入`./comport -d /dev/ttyS6 -b 115200 -s 8N1N -x` + +在XCOM上可以看到MCU的调试信息,旋转电位器旋钮至最左或最右分别测量最小电流和最大电流,量程约为1.22mA~22.79mA(测试其他三路电流时最小电流约为0.006mA) + + + + + +### 3.12.3 AIN 电压测试 + +准备工作和AIN电流测试一样,不再赘述 + + + +运行comport程序让rk3568输出读取电压的指令给mcu + +同样在XCOM上也能看到MCU的采样调试信息,旋转电位器旋钮至最左或最右分别测量最小电流和最大电流,量程约为0.017V~5.882V + + -- Gitblit v1.9.1