3、RK3399J Linux编译Ubuntu(GPT)固件

1、下载SDK

为了方便用户的使用与开发,官方提供了 Linux 开发的整套 SDK,本章详细的说明 SDK 的具体用法。
下载 Firefly_Linux_SDK地址:http://www.t-firefly.com/doc/download/page/id/31.html#other_186
在这里插入图片描述
下载完成后先验证一下 MD5 码:


```go
$ md5sum firefly-sdk-20200629.7z
d8c52272725ff8a2216fc2be7a92ffc4  firefly-sdk-20200629.7z

确认无误后,就可以解压:

```go
7z x firefly-sdk-20200629.7z
cd firefly-sdk
git reset --hard

2、更新

注意:解压后务必要先更新下远程仓库。以下为从 github 处更新的方法:

#1. 进入SDK根目录
cd firefly-sdk

#2. 下载远程bundle仓库
git clone https://github.com/FireflyTeam/bundle.git -b rk3399-linux-bundle

#3. 更新SDK,并且后续更新不需要再次拉取远程仓库,直接执行以下命令即可
./bundle/update rk3399-linux-bundle

#4. 按照提示已经更新内容到 FETCH_HEAD,同步FETCH_HEAD到firefly分支
git rebase FETCH_HEAD

#5 更新共用仓库
./bundle/update common-linux-bundle
git rebase FETCH_HEAD

3、Linux_SDK 目录介绍
目录:

├── linux_sdk
│ ├── app
│ ├── buildroot buildroot 根文件系统的编译目录
│ ├── build.sh -> device/rockchip/common/build.sh 全自动编译脚本
│ ├── device 编译相关配置文件
│ ├── distro debian 根文件系统生成目录
│ ├── docs 文档
│ ├── envsetup.sh -> buildroot/build/envsetup.sh
│ ├── external
│ ├── kernel 内核
│ ├── Makefile -> buildroot/build/Makefile
│ ├── mkfirmware.sh -> device/rockchip/common/mkfirmware.sh rockdev链接更新脚本
│ ├── prebuilts
│ ├── rkbin
│ ├── rkflash.sh -> device/rockchip/common/rkflash.sh 烧写脚本
│ ├── rootfs debian根文件系统编译目录
│ ├── tools 烧写、打包工具
│ └── u-boot

3、搭建 SDK 编译环境

Ubuntu 固件:(根文件系统请使用官方提供的根文件系统镜像)

sudo apt-get install repo git-core gitk git-gui gcc-arm-linux-gnueabihf u-boot-tools device-tree-compiler \
gcc-aarch64-linux-gnu mtools parted libudev-dev libusb-1.0-0-dev python-linaro-image-tools \
linaro-image-tools gcc-4.8-multilib-arm-linux-gnueabihf gcc-arm-linux-gnueabihf libssl-dev \
gcc-aarch64-linux-gnu g+conf autotools-dev libsigsegv2 m4 intltool libdrm-dev curl sed make \
binutils build-essential gcc g++ bash patch gzip bzip2 perl tar cpio python unzip rsync file bc wget \
libncurses5 libqt4-dev libglib2.0-dev libgtk2.0-dev libglade2-dev cvs git mercurial rsync openssh-client \
subversion asciidoc w3m dblatex graphviz python-matplotlib libc6:i386 libssl-dev texinfo \
liblz4-tool genext2fs lib32stdc++6

注意: Ubuntu17.04 或者更高的系统还需要如下依赖包:

sudo apt-get install lib32gcc-7-dev g++-7 libstdc++-7-dev

4、编译 SDK

(1)、编译前配置
配置文件 aio-3399j-ubuntu.mk:

./build.sh aio-3399j-ubuntu.mk
#文件路径在 `device/rockchip/rk3399/aio-3399j-ubuntu.mk`

如果配置文件生效会连接到 device/rockchip/.BoardConfig.mk ,检查该文件可以验证是否配置成功

注意: device/rockchip/rk3399/firefly-rk3399-ubuntu.m为编译生成 Buildroot
固件的配置文件。同时用户也可以通过参考该配置生成新的配置文件来适配自己所需要的固件。
export RK_UBOOT_DEFCONFIG=firefly-rk3399 编译uboot配置文件

# kernel defconfig
export LINUX_KERNEL_DEFCONFI=firefly_linux_defconfig   编译kernel配置文件

# kernel dts
export RK_KERNEL_DTS=rk3399-firefly-aio                         编译kernel用到的dts

# parameter for GPT table
export RK_PARAMETER=parameter-ubuntu.txt             分区信息(十分重要)

# packagefile for make update image
export RK_PACKAGE_FILE=rk3399-ubuntu-package-file    打包配置文件

# rootfs image path
//这里要用带桌面的DESKTOP的根文件系统
export RK_ROOTFS_IMG=xxxx/xxxx.img                   根文件系统镜像路径
注意,十分重要!!

默认配置编译 Buildroot 固件,如果想编译其他固件(如 Ubuntu 固件)请执行一下操作:
下载地址:http://www.t-firefly.com/doc/download/page/id/31.html
在这里插入图片描述

  • 前往下载页面 下载对应的Ubuntu 根文件系统镜像
  • 把得到的镜像放到 SDK 的指定目录:
#解压
tar -xvf rk3399_ubuntu18.04_LXDE.img.tgz

#sdk根目录下
mkdir ubunturootfs
mv rk3399_ubuntu18.04_LXDE.img ubunturootfs/

#修改aio-3399j-ubuntu.mk文件
vim device/rockchip/RK3399/aio-3399j-ubuntu.mk

#把RK_ROOTFS_IMG属性改成ubuntu文件系统镜像得路径(也就是rk3399_ubuntu18.04_LXDE.img)
RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img

注意: Ubuntu 根文件系统镜像存放路径不能错。

5、全自动编译

./build.sh
全自动编译的固件默认会编译一遍 buildroot 根文件系统。生成固件目录 rockdev/ ,同时会在 IMAGE 中备份。

6、部分编译

(1)、kernel

./build.sh kernel

(2)、u-boot

./build.sh uboot

(3)、recovery

recovery分区可省略,若有需要,编译recovery:
./build.sh recovery

(4)、rootfs

buildroot:
./build.sh rootfs
  • Ubuntu18.04文件系统

把得到的镜像放到 SDK 的根目录处:

#解压

tar -xvf rk3399_ubuntu18.04_LXDE.img.tgz

#sdk根目录下

mkdir ubunturootfs
mv rk3399_ubuntu18.04_LXDE.img ubunturootfs/

#修改aio-3399j-ubuntu.mk文件
vim device/rockchip/RK3399/aio-3399j-ubuntu.mk

#把RK_ROOTFS_IMG属性改成ubuntu文件系统镜像得路径(也就是rk3399_ubuntu18.04_LXDE.img)
RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img

注意: Ubuntu 根文件系统镜像存放路径不能错。

运行 ./mkfirmware.sh 会自动更新 rockdev/rootfs.img 的链接。

7、固件打包

同步更新各部分镜像
每次打包固件前先确保 rockdev/ 目录下文件链接是否正确:

ls -l

├── boot.img -> ~/project/linux_sdk/kernel/boot.img
├── idbloader.img -> ~/project/linux_sdk/u-boot/idbloader.img
├── linaro-rootfs.img
├── MiniLoaderAll.bin -> ~/project/linux_sdk/u-boot/rk3399_loader_v1.14.115.bin
├── misc.img -> ~/project/linux_sdk/device/rockchip/rockimg/wipe_all-misc.img
├── oem.img
├── parameter.txt -> ~/project/linux_sdk/device/rockchip/RK3399/parameter-ubuntu.txt
├── recovery.img -> ~/project/linux_sdk/buildroot/output/rockchip_rk3399_recovery/images/recovery.img
├── rootfs.img -> ~/project/linux_sdk/ubunturootfs/rk3399_ubuntu18.04_LXDE.img
├── trust.img -> ~/project/linux_sdk/u-boot/trust.img
├── uboot.img -> ~/project/linux_sdk/u-boot/uboot.img
└── userdata.img

可以运行 ./mkfirmware.sh 更新链接

./mkfirmware.sh

提示:若不是编译全部的分区镜像,在运行 ./mkfirmware 时,会遇到如下类似情况:

error: /home/ljh/proj/linux-sdk/buildroot/output/rockchip_rk3399_recovery/images/recovery.img not found!
表示recovery分区没有编译出镜像,其他的情况类似,如oem.img、userdata.img
上文提到,这些属于可省略分区镜像,可以不用理会。

8、统一打包固件
打包统一固件
注意: 打包前请确认 tools/linux/Linux_Pack_Firmware/rockdev/package-file 是否正确。打包会根据此文件进行分区打包。此文件链接会在 ./build.sh aio-3399j-ubuntu.mk 命令时更新,如果配置不对请返回编译前配置一节重新配置一次。

整合统一固件:

./build.sh updateimg

8、分区介绍

分区介绍
parameter
parameter.txt 包含了固件的分区信息十分重要,你可以在 device/rockchip/rk3399 目录下找到一些 parameter.txt 文件,下面以 parameter-debian.txt 为例子做介绍:

FIRMWARE_VER: 8.1
MACHINE_MODEL: RK3399
MACHINE_ID: 007
MANUFACTURER: RK3399
MAGIC: 0x5041524B
ATAG: 0x00200800
MACHINE: 3399
CHECK_MASK: 0x80
PWR_HLD: 0,0,A,0,1
TYPE: GPT
CMDLINE: mtdparts=rk29xxnand:0x00002000@0x00004000(uboot),0x00002000@0x00006000(trust),0x00002000@0x00008000(misc),0x00010000@0x0000a000(boot),0x00010000@0x0001a000(recovery),0x00010000@0x0002a000(backup),0x00020000@0x0003a000(oem),0x00700000@0x0005a000(rootfs),-@0x0075a000(userdata:grow)
uuid:rootfs=614e0000-0000-4b53-8000-1d28000054a9

CMDLINE 属性是我们关注的地方。以 Uboot 为例 0x00002000@0x00004000(uboot) 中 0x00004000 为 Uboot 分区的起始位置 0x00002000 为分区的大小。后面的分区规则相同。用户可以根据自己需要增减或者修改分区信息,但是请最少保留 uboot, trust, boot, rootfs 分区,这是机器能正常启动的前提条件。parameter-ubuntu.txt 中使用的就是这样的最简分区方案。

CMDLINE 属性是我们关注的地方。以 Uboot 为例 0x00002000@0x00004000(uboot) 中
0x00004000 为 Uboot 分区的起始位置 0x00002000
为分区的大小。后面的分区规则相同。用户可以根据自己需要增减或者修改分区信息,但是请最少保留 uboot, trust, boot,
rootfs 分区,这是机器能正常启动的前提条件。parameter-ubuntu.txt 中使用的就是这样的最简分区方案。

9、打包分区介绍

此文件应当与 parameter 保持一致,用于固件打包。可以在 tools/linux/Linux_Pack_Firmware/rockdev 下找到相关文件。以 rk3399-ubuntu-package-file 为例介绍:

# NAME          Relative path
#
#HWDEF          HWDEF
package-file    package-file
bootloader      Image/MiniLoaderAll.bin
parameter       Image/parameter.txt
trust           Image/trust.img
uboot           Image/uboot.img
boot            Image/boot.img
rootfs:grow     Image/rootfs.img
backup          RESERVED

以上是 SDK 编译后生成的镜像文件。根据 parameter.txt 只打包自己用到的 img 文件。

10、界面

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_18077275/article/details/108886634