Buildroot開發
Buildroot開發基礎
Buildroot版本
當前Buildroot版本為Buildroot-2018.02
Buildroot 配置選擇及編譯
按照以下步驟配置完后,執行 make 即可。
source buildroot/build/envsetup.sh You're building on
Linux Lunch menu...
pick a combo: 1. firefly_rk3308_release 2. firefly_rk3308_recovery 3. firefly_rk3308_
pcba Which would you like? [1] 1 ===========================================
如選擇 firefly_rk3308_release,輸入對應序號 1
完成編譯后執行 SDK 根目錄下的 mkfirmware.sh 腳本生成固件
make 編譯執行過程
執行過程:
-
下載源碼;
-
配置、編譯、安裝交叉工具鏈;
-
配置、編譯、安裝選擇的包;
-
按選擇的格式生成根文件系統;
Buildroot 輸出結果保存在output目錄,具體目錄由配置文件決定。 例如,編譯配置firefly_rk3308_release,輸出結果保存在buildroot/output/firefly_rk3308_release目錄。
后續編譯可以在buildroot/output/firefly_rk3308_release目錄或是工程根目錄下執行(make menuconfig也可以在工程根目錄下執行),這個目錄底下包括幾個子目錄:
-
image/:包含壓縮好的根文件系統鏡像文件。
-
build/: 包含所有的源文件,包括 Buildroot 所需主機工具和選擇的包,這個目錄包含所有模塊源碼。
-
staging/:這個目錄類似根文件系統的目錄結構,包含編譯生成的所有頭文件和庫,以及其他開發文件,不過他們沒有裁剪,比較龐大,不適用于目標文件系統。
模塊配置
整個Buildroot是由Makefile腳本和Kconfig配置文件構成的。你可以和編譯Linux內核一樣。
配置界面如下:
在Target packages里面添加和裁剪一些工具,按需求定制系統功能,常用到的libdrm、ssh、vsftpd、wpa_supplicant、pppd等都可在里面配置。
執行以下命令,將會保存當前配置,并自動修改 buildroot/configs/ 目錄下的默認配置文件:
需要注意的是:
-
進行編譯時,buildroot根據配置,會自動從網絡獲取相關的軟件包,包括一些第三方庫,插件,實用工具等,放在dl/目錄。
-
軟件包會解壓在output/build/目錄下,然后進行編譯。
-
如果要修改軟件包的源碼,可以通過打補丁的方式進行修改,補丁集中放在package/目錄,buildroot會在解壓軟件包時為其打上相應的補丁。
Busybox 配置修改
配置命令:
修改完成后,通過命令保存配置:
make busybox-update-config
交叉編譯工具
Buildroot 編譯完成后,會在指定的輸出目錄 host 目錄下生成交叉編譯工具,我們可以用來編譯目標程序。默認配置生成的交叉編譯工具目錄為:
cdbuildroot/output/firefly_rk3308_release/host/usr/bin/
我們可以直接用交叉編譯工具編譯程序,例如:
./buildroot/output/firefly_rk3308_release/host/usr/bin/aarch64-
rockchip-linux-gnu-gcc main.c -otest
浮點支持(以下配置打開 neon 支持),RK3308 支持 crc/crypto/fp/simd 這幾個 feature,配置如下:
CFLAGS+=-mcpu=cortex-a35+crc+crypto
編譯
在開發過程中,針對output/build/某個模塊源碼進行了修改,需要單獨重新編譯該模塊軟件包。
Buildroot在編譯某個包的時候,會將編譯的過程,通過一些標志文件記錄下來,保存在對應的軟件包源碼的目錄里,這些標志文件分別有:
.stamp_configured .stamp_downlo
aded .stamp_extr
acted .stamp_patched .stamp_staging_installed .stamp_target_installed
這些標識文件主要控制這個軟件包的下載,解壓,打包,配置,編譯,安裝等。具體詳細說明可參考:
docs/manual/rebuilding-packages.txt
也可以直接看mk文件,了解原理:
要想重新執行哪一個步驟,相應的就要刪掉其對應的標志文件。假如你想重新編譯某軟件包源碼,只需刪掉該目錄下的.stamp_built和.stamp_target_installed,然后再編譯整個Buildroot就可以了。
Buildroot有更快捷的實現方法。
同時我們還可以通過make-,對軟件包單獨調用構建中的某一步驟,如下:
Package-specific:
-Buildandinstallandallitsdependencies-source-Onlydownloadthesourcefilesfor-extract-Extractsources-patch-Applypatchesto-depends-Build's dependencies-configure-Builduptotheconfigurestep-build-Builduptothebuildstep-graph-depends-Generateagraphof's dependencies-dirclean-Removebuilddirectory-reconfigure-Restartthebuildfromtheconfigurestep-rebuild-Restartthebuildfromthebuildstep
因此,如果我們想重新編譯xxx模塊軟件包,執行makexxx-rebuild即可。
關于make的更多用法,可通過makehelp獲得。
新增本地源碼包
以上介紹都是在 Buildroot 已有源碼包的情況下,我們去選擇打開編譯即可,如果 Buildroot沒有或者我們自己寫的應用該如何集成到 Buildroot ?
Buildroot 支持多種模塊編譯方式,包括 generic-package、cmake-package、autotools-package 等,我們以 generic-package 舉例說明。
例子:buildroot/package/rockchip/fireflydemo
buildroot/package/rockchip/fireflydemo/
config BR2_PACKAGE_FIREFLYDEMO bool"Simple Firefly Demo"
################################################################ fireflydemo###############################################################ifeq ($(BR2_PACKAGE_FIREFLYDEMO), y)FIREFLYDEMO_VERSION:=1.0.0FIREFLYDEMO_SITE=$(TOPDIR)/../external/fireflydemo/srcFIREFLYDEMO_SITE_METHOD=localdefine FIREFLYDEMO_BUILD_CMDS$(TARGET_MAKE_ENV)$(MAKE)CC=$(TARGET_CC)CXX=$(TARGET_CXX)-C$(@D)endefdefine FIREFLYDEMO_CLEAN_CMDS$(TARGET_MAKE_ENV)$(MAKE)-C$(@D)cleanendefdefine FIREFLYDEMO_INSTALL_TARGET_CMDS$(TARGET_MAKE_ENV)$(MAKE)-C$(@D)installendefdefine FIREFLYDEMO_UNINSTALL_TARGET_CMDS$(TARGET_MAKE_ENV)$(MAKE)-C$(@D)uninstallendef$(eval$(generic-package))endif
external/fireflydemo/src/
#include#includeintmain(intargc,char*argv[]){printf("hello world\n");return0;}
DEPS=OBJ=demo.oCFLAGS=%.o:%.c$(DEPS)$(CC)-c -o$@$<$(CFLAGS)demo:$(OBJ)$(CXX)-o$@$^$(CFLAGS).PHONY:cleanclean:rm -f *.o *~ demo.PHONY:installinstall:cp -f demo$(TARGET_DIR)/usr/bin/.PHONY:uninstalluninstall:rm -f$(TARGET_DIR)/usr/bin/demo
source"package/rockchip/fireflydemo/Config.in"
fs-overlay
默認編譯出來根文件系統,有些配置文件可能不能滿足客制化需求,這時候 fs-overlay 就能排上用場,fs-overlay 目錄會在編譯的最后階段替換到文件系統目錄,打包進根文件系統。 fs-overlay路徑由默認配置文件指定:
BR2_ROOTFS_OVERLAY="board/rockchip/rk3308/fs-overlay"
Rootfs 切換為 ext2
Rootfs 可配置為可讀寫 ext2 文件系統,方便系統調試使用。
diff --git a/kernel/arch/
arm64/boot/dts/rockchip/rk3308-firefly.dtsi b/kernel/arch/arm64/boot/dts/rockchip/rk3308-firefly.dtsi index acd0dab..939db3c 100644 --- a/kernel/arch/arm64/boot/dts/rockchip/rk3308-firefly.dtsi +++ b/kernel/arch/arm64/boot/dts/rockchip/rk3308-firefly.dtsi @@ -11,7 +11,7 @@ compa
tible = "firefly,rk3308-firefly", "firefly,rk3308"; chosen { - bootargs = "earlycon=
uart8250,mmio32,0xff0c0000 swiotlb=1 console=ttyFIQ0 root=PARTUUID=614e0000-0000 rootfstype=squashfs rootw
ait"; + bootargs = "earlycon=uart8250,mmio32,0xff0c0000 swiotlb=1 console=ttyFIQ0 root=PARTUUID=614e0000-0000 rootfstype=ext2 rootwait"; };
adc-keys {
diff --git a/device/rockchip/rk3308/BoardConfig.mk b/device/rockchip/rk3308/BoardConfig.mk index abb9e96..97662b3 100755 --- a/device/rockchip/rk3308/BoardConfig.mk +++ b/device/rockchip/rk3308/BoardConfig.mk @@ -28,7 +28,7 @@ TARGET_PRODUCT=rk3308 # Set rootfs type, see buildroot. # ext4 squashfs -ROOTFS_TYPE=squashfs +ROOTFS_TYPE=ext2 # Set data partition type. # ext2 squashfs
buildroot/output/firefly_rk3308_release/images/rootfs.ext2
外部存儲設備
TF卡設備掛載目錄:/sdcard
U盤設備掛載目錄:/udisk
支持文件系統格式:ext2,vfat,ntfs等。
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
Linux
-
嵌入式主板
-
Firefly
-
RK3308
-
Buildroot
相關推薦
應用程序,而無需下載編譯 SDK 代碼。在SDK中編譯QT工具鏈準備工作:Ubuntu系統RK3308 Linux SDKQt Creator開發板:ROC-RK3308B-CC 或者
發表于 08-16 16:58
Docker鏡像內配置好了編譯SDK所需的依賴環境,無需在本地配置編譯環境,進入對應的docker容器內進行SDK編譯即可。目前暫時只支持ROC-RK3308-CC Buildroot SDK的編譯。安裝
發表于 08-22 17:19
ROC-RK3308-CC 四核64位AIOT主板
發表于 11-03 11:08
?5037次閱讀
Docker鏡像內配置好了編譯SDK所需的依賴環境,無需在本地配置編譯環境,進入對應的docker容器內進行SDK編譯即可。 目前暫時只支持ROC-RK3308B-CC Buildroot SDK
發表于 12-20 09:30
?2000次閱讀
ROC-RK3308B-CC 有著非常靈活的啟動方式。一般情況下,除非硬件損壞,ROC-RK3308B-CC 主板是不會變磚的。
發表于 12-20 09:20
?2989次閱讀
確認主板配件連接無誤后,通過 USB Type-C 線給 ROC-RK3308B-CC 供電。
發表于 12-20 09:32
?2414次閱讀
ROC-RK3308-CC 有著非常靈活的啟動方式。一般情況下,除非硬件損壞,ROC-RK3308-CC 主板是不會變磚的。
發表于 12-23 15:47
?2630次閱讀
確認主板配件連接無誤后,通過 USB Type-C 線給 ROC-RK3308-CC 供電。
發表于 12-23 15:50
?2402次閱讀
電子發燒友網站提供《Core 3308Y固件ROC RK3308B CC PLUS Buildroot NoUI.txt》資料免費下載
發表于 09-13 10:01
?1次下載
電子發燒友網站提供《Core 3308Y固件ROC RK3308B CC PLUS Buildroot MiniGUI.txt》資料免費下載
發表于 09-13 10:00
?3次下載
電子發燒友網站提供《ROC RK3308B CC PLUS Buildroot QT Desktop固件.txt》資料免費下載
發表于 09-13 10:08
?0次下載
電子發燒友網站提供《Core 3308Y固件ROC RK3308B CC Buildroot NoUI固件.txt》資料免費下載
發表于 09-13 09:51
?0次下載
電子發燒友網站提供《ROC RK3308B CC Buildroot Qt Desktop固件.txt》資料免費下載
發表于 09-13 09:49
?0次下載
電子發燒友網站提供《IoT四核64位開源主板ROC RK3308B CC規格書.pdf》資料免費下載
發表于 09-13 09:35
?2次下載
電子發燒友網站提供《四核64位開源主板ROC RK3308B CC Plus規格書.pdf》資料免費下載
發表于 09-13 09:33
?0次下載
評論