為了方便用戶的使用與開發,官方提供了Linux開發的整套sdk,本章詳細的說明SDK的具體用法。
下載repo工具:
mkdir linux cd linux git clone https://github.com/FireflyTeam/repo.git
下載完整 SDK
-
方法一
初始化repo倉庫:
mkdir linux-sdk cd linux-sdk ../repo/repo init --repo-url https://github.com/FireflyTeam/repo.git -u https://github.com/FireflyTeam/manifests.git -b linux-sdk -m rk3399/rk3399_linux_release.xml
同步源碼:
../repo/repo sync -c
同步過程中,網絡波動會導致下載速度過低中斷同步,可以使用下面腳本同步代碼:
../repo/repo sync -c while [ $? -ne 0 ] ; do ../repo/repo sync -c; done
-
方法二(國內用戶推薦使用)
因為國內用戶可能git拉代碼會比較慢,所以官方提供了基礎得源碼包Linux_SDK.7z
下載Linux_SDK.7z
1.把壓縮包放在上一步下載repo工具的目錄下 7z x Linux_SDK.7z 2.更新代碼 repo sync -c
下載裁剪版 SDK
初始化repo倉庫:
mkdir linux-sdk cd linux-sdk ../repo/repo init --repo-url https://github.com/FireflyTeam/repo.git -u https://github.com/FireflyTeam/manifests.git -b linux-sdk -m rk3399/rk3399_linux_ubuntu_release.xml
同步源碼:
../repo/repo sync -c
注意: 裁剪版 SDK 主要刪掉了編譯 Buildroot 和 Debian 的源碼,方便不需要編譯根文件系統的用戶獲取。
目錄:
├── 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
編譯buildroot固件:
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 autoconf 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
編譯debian固件:
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
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
配置文件 aio-3399c.mk:
./build.sh aio-3399c.mk #文件路徑在`device/rockchip/rk3399/aio-3399c.mk`
配置文件生效會連接到device/rockchip/.BoardConfig.mk
,檢查該文件可以驗證是否配置成功。
注意:aio-3399c.mk
為編譯生成buildroot固件的配置文件.同時用戶也可以通過參考該配置生成新的配置文件來適配自己所需要的固件。
重要配置介紹:(如果需要diy固件,可能需要修改下列配置信息)
# Uboot defconfig export RK_UBOOT_DEFCONFIG=firefly-rk3399 編譯uboot配置文件 # Kernel defconfig export RK_KERNEL_DEFCONFIG=firefly_linux_defconfig 編譯kernel配置文件 # Kernel dts export RK_KERNEL_DTS=rk3399-firefly-aioc 編譯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 export RK_ROOTFS_IMG=xxxx/xxxx.img 根文件系統鏡像路徑
注意,十分重要!!
默認配置編譯buildroot固件,如果想編譯其他固件(如ubuntu固件)請執行一下操作:
-
下載ubuntu根文件系統鏡像https://pan.baidu.com/s/1DuCzTGARDi7APxyKs9Nl1A#list/path=%2F
-
把得到的鏡像放到sdk的指定目錄:
#解壓 tar -xvf rk3399_ubuntu18.04_LXDE.img.tgz #sdk根目錄下 mkdir ubunturootfs mv rk3399_ubuntu18.04_LXDE.img ubunturootfs/ #修改aio-3399c.mk文件 vim device/rockchip/rk3399/aio-3399c.mk #把RK_ROOTFS_IMG屬性改成ubuntu文件系統鏡像得路徑(也就是rk3399_ubuntu18.04_LXDE.img) RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img
注意:ubuntu根文件系統鏡像存放路徑不能錯
在配置和搭建環境的工作都做好的前提下:
./build.sh
全自動編譯的固件默認編譯buildroot
固件。生成固件目錄rockdev/
,同時會在IMAGE中備份。
kernel
./build.sh kernel
u-boot
./build.sh uboot
recovery
recovery分區可省略,若有需要: 編譯recovery:
./build.sh recovery
rootfs
-
buildroot
./build.sh rootfs
-
debian:
cd rootfs/ 1: #Building base debian system by ubuntu-build-service from linaro sudo apt-get install binfmt-support qemu-user-static live-build sudo dpkg -i ubuntu-build-service/packages/* sudo apt-get install -f 2: #編譯 32 位的 debian: RELEASE=stretch TARGET=desktop ARCH=armhf ./mk-base-debian.sh #或編譯 64 位的 debian: RELEASE=stretch TARGET=desktop ARCH=arm64 ./mk-base-debian.sh #上面編譯如果遇到如下問題情況: noexec or nodev issue /usr/share/debootstrap/functions: line 1450: ..../rootfs/ubuntu-build- service/stretch-desktop-armhf/chroot/test-dev-null: Permission denied E: Cannot install into target '/home/foxluo/work3/rockchip/rk_linux/rk3399_linux/rootfs/ubuntu-build-service/stretch- desktop-armhf/chroot' mounted with noexec or nodev # 解決辦法: mount -o remount,exec,dev xxx (xxx is the mount place), then rebuild it. 3: # 編譯 32 位的 debian: VERSION=debug ARCH=armhf ./mk-rootfs-stretch.sh # 開發階段推薦使用后面帶 debug # 編譯 64 位的 debian: VERSION=debug ARCH=arm64 ./mk-rootfs-stretch-arm64.sh 4: ./mk-image.sh mv linaro-rootfs.img ../distro/ 5: #修改aio-3399c.mk文件 vim device/rockchip/rk3399/aio-3399c.mk #把RK_ROOTFS_IMG屬性改成ubuntu文件系統鏡像得路徑(也就是linaro-rootfs.img) RK_ROOTFS_IMG=distro/linaro-rootfs.img
-
ubuntu18.04,可以通過云盤下載:
下載鏈接https://pan.baidu.com/s/1DuCzTGARDi7APxyKs9Nl1A#list/path=%2F
把得到的鏡像放到sdk的根目錄處:
#解壓 tar -xvf rk3399_ubuntu18.04_LXDE.img.tgz #sdk根目錄下 mkdir ubunturootfs mv rk3399_ubuntu18.04_LXDE.img ubunturootfs/ #修改aio-3399c.mk文件 vim device/rockchip/rk3399/aio-3399c.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
的鏈接
每次打包固件前先確保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 上文提到,這些屬于可省略分區鏡像,可以不用理會。
注意:打包前請確認tools/linux/Linux_Pack_Firmware/rockdev/package-file
是否正確。打包會根據此文件進行分區打包。此文件鏈接會在./build.sh aio-rk3399c.mk
命令時更新,如果配置不對請返回配置這一節重新配置一次。
整合統一固件
./build.sh updateimg
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中使用的就是這樣的最簡分區方案。
分區介紹:
uboot 分區: 燒寫 uboot 編譯出來的 uboot.img. trust 分區: 燒寫 uboot 編譯出來的 trust.img misc 分區: 燒寫 misc.img。開機檢測進入recovery模式.(可省略) boot 分區: 燒寫 kernel 編譯出來的 boot.img.包含kernel和設備樹信息 recovery 分區: 燒寫 recovery.img.(可省略) backup 分區: 預留,暫時沒有用。后續跟 android 一樣作為 recovery 的 backup 使用.(可省略) oem 分區: 給廠家使用,存放廠家的 app 或數據。只讀。代替原來音箱的 data 分區。掛載在/oem 目錄.(可省略) rootfs 分區: 存放 buildroot 或者 debian 編出來的 rootfs.img,只讀. userdata 分 區 : 存 放 app 臨 時 生 成 的 文 件 或 者 是 給 最 終 用 戶 使 用 。 可 讀 寫 , 掛 載 在 /userdata 目錄下.(可省略)
此文件應當與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文件。
-
嵌入式主板
+關注
關注
7文章
6085瀏覽量
35225 -
安卓
+關注
關注
5文章
2122瀏覽量
57039 -
Firefly
+關注
關注
2文章
538瀏覽量
6992
發布評論請先 登錄
相關推薦
評論