編譯 Ubuntu 固件( GPT )
為了方便用戶的使用與開發(fā),官方提供了Linux開發(fā)的整套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
同步過程中,網(wǎng)絡波動會導致下載速度過低中斷同步,可以使用下面腳本同步代碼:
../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 的源碼,方便不需要編譯根文件系統(tǒng)的用戶獲取。
Linux_SDK 目錄介紹
目錄:
├── linux_sdk │ ├── app │ ├── buildroot buildroot 根文件系統(tǒng)的編譯目錄 │ ├── build.sh -> device/rockchip/common/build.sh 全自動編譯腳本 │ ├── device 編譯相關配置文件 │ ├── distro debian 根文件系統(tǒng)生成目錄 │ ├── 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根文件系統(tǒng)編譯目錄 │ ├── tools 燒寫、打包工具 │ └── u-boot
搭建 SDK 編譯環(huán)境
編譯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 / 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
Ubuntu 根文件系統(tǒng)請使用官方提供的根文件系統(tǒng)鏡像。
編譯SDK
編譯前配置
配置文件 roc-rk3399-pc.mk:
./build.sh roc-rk3399-pc.mk #文件路徑在`device/rockchip/rk3399/roc-rk3399-pc.mk`
如果配置文件生效會連接到device/rockchip/.BoardConfig.mk,檢查該文件可以驗證是否配置成功
注意:roc-rk3399-pc.mk為編譯生成buildroot固件的配置文件.同時用戶也可以通過參考該配置生成新的配置文件來適配自己所需要的固件。
重要配置介紹:(如果需要diy固件,可能需要修改下列配置信息)
# Uboot defconfig export RK_UBOOT_DEFCONFIG=roc-rk3399-pc 編譯uboot配置文件 # Kernel defconfig export RK_KERNEL_DEFCONFIG=firefly_linux_defconfig 編譯kernel配置文件 # Kernel dts export RK_KERNEL_DTS=rk3399-roc-pc 編譯kernel用到的dts # parameter for GPT table export RK_PARAMETER=parameter-ubuntu.txt 分區(qū)信息(十分重要) # packagefile for make update image export RK_PACKAGE_FILE=rk3399-ubuntu-package-file 打包配置文件 # rootfs image path export RK_ROOTFS_IMG=xxxx/xxxx.img 根文件系統(tǒng)鏡像路徑
注意,十分重要?。?/p>
默認配置編譯buildroot固件,如果想編譯其他固件(如ubuntu固件)請執(zhí)行一下操作:
下載ubuntu根文件系統(tǒng)鏡像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/ #修改roc-rk3399-pc.mk文件 vim device/rockchip/rk3399/roc-rk3399-pc.mk #把RK_ROOTFS_IMG屬性改成ubuntu文件系統(tǒng)鏡像得路徑(也就是rk3399_ubuntu18.04_LXDE.img) RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img
注意:ubuntu根文件系統(tǒng)鏡像存放路徑不能錯
全自動編譯
在配置和搭建環(huán)境的工作都做好的前提下:
./build.sh
全自動編譯的固件默認會編譯一遍buildroot根文件系統(tǒng)。生成固件目錄rockdev/,同時會在IMAGE中備份。
部分編譯
kernel
./build.sh kernel
u-boot
./build.sh uboot
recovery
recovery分區(qū)可省略,若有需要: 編譯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 # 開發(fā)階段推薦使用后面帶 debug # 編譯 64 位的 debian: VERSION=debug ARCH=arm64 ./mk-rootfs-stretch-arm64.sh 4: ./mk-image.sh mv linaro-rootfs.img ../distro/ 5: #修改roc-rk3399-pc.mk文件 vim device/rockchip/rk3399/roc-rk3399-pc.mk #把RK_ROOTFS_IMG屬性改成ubuntu文件系統(tǒng)鏡像得路徑(也就是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/ #修改roc-rk3399-pc.mk文件 vim device/rockchip/rk3399/roc-rk3399-pc.mk #把RK_ROOTFS_IMG屬性改成ubuntu文件系統(tǒng)鏡像得路徑(也就是rk3399_ubuntu18.04_LXDE.img) RK_ROOTFS_IMG=ubunturootfs/rk3399_ubuntu18.04_LXDE.img
注意:ubuntu根文件系統(tǒng)鏡像存放路徑不能錯
運行./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
提示:若不是編譯全部的分區(qū)鏡像,在運行./mkfirmware時,會遇到如下類似情況:
error: /home/ljh/proj/linux-sdk/buildroot/output/rockchip_rk3399_recovery/images/recovery.img not found! 表示recovery分區(qū)沒有編譯出鏡像,其他的情況類似,如oem.img、userdata.img 上文提到,這些屬于可省略分區(qū)鏡像,可以不用理會。
打包統(tǒng)一固件
注意:打包前請確認tools/linux/Linux_Pack_Firmware/rockdev/package-file是否正確。打包會根據(jù)此文件進行分區(qū)打包。此文件鏈接會在./build.sh roc-rk3399-pc.mk 命令時更新,如果配置不對請返回[配置]一節(jié)重新配置一次。
整合統(tǒng)一固件:
./build.sh updateimg
分區(qū)介紹
parameter
parameter.txt包含了固件的分區(qū)信息十分重要,你可以在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分區(qū)的起始位置0x00002000為分區(qū)的大小。后面的分區(qū)規(guī)則相同。用戶可以根據(jù)自己需要增減或者修改分區(qū)信息,但是請最少保留uboot,trust,boot,rootfs分區(qū),這是機器能正常啟動的前提條件。parameter-ubuntu.txt中使用的就是這樣的最簡分區(qū)方案。
分區(qū)介紹:
uboot 分區(qū): 燒寫 uboot 編譯出來的 uboot.img. trust 分區(qū): 燒寫 uboot 編譯出來的 trust.img misc 分區(qū): 燒寫 misc.img。開機檢測進入recovery模式.(可省略) boot 分區(qū): 燒寫 kernel 編譯出來的 boot.img.包含kernel和設備樹信息 recovery 分區(qū): 燒寫 recovery.img.(可省略) backup 分區(qū): 預留,暫時沒有用。后續(xù)跟 android 一樣作為 recovery 的 backup 使用.(可省略) oem 分區(qū): 給廠家使用,存放廠家的 app 或數(shù)據(jù)。只讀。代替原來音箱的 data 分區(qū)。掛載在/oem 目錄.(可省略) rootfs 分區(qū): 存放 buildroot 或者 debian 編出來的 rootfs.img,只讀. userdata 分 區(qū) : 存 放 app 臨 時 生 成 的 文 件 或 者 是 給 最 終 用 戶 使 用 。 可 讀 寫 , 掛 載 在 /userdata 目錄下.(可省略)
package-file
此文件應當與parameter保持一致,用于固件打包??梢栽趖ools/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編譯后生成的鏡像文件。根據(jù)parameter.txt只打包自己用到的img文件。
-
嵌入式主板
+關注
關注
7文章
6086瀏覽量
35522 -
安卓
+關注
關注
5文章
2136瀏覽量
57450 -
可制造性設計
+關注
關注
10文章
2065瀏覽量
15666 -
Firefly
+關注
關注
2文章
538瀏覽量
7081 -
華秋DFM
+關注
關注
20文章
3494瀏覽量
4678
發(fā)布評論請先 登錄
相關推薦
評論