引言
在嵌入式系統(tǒng)開(kāi)發(fā)領(lǐng)域,構(gòu)建工具的穩(wěn)定性與可維護(hù)性對(duì)項(xiàng)目長(zhǎng)期發(fā)展至關(guān)重要。嵌入式項(xiàng)目通常需要針對(duì)不同硬件平臺(tái)進(jìn)行交叉編譯,每個(gè)平臺(tái)都需要依賴(lài)特定的構(gòu)建工具鏈,環(huán)境搭建復(fù)雜。隨著LLVM工具鏈的普及,在嵌入式領(lǐng)域采用現(xiàn)代化構(gòu)建工具鏈已成為提升開(kāi)發(fā)效率的趨勢(shì)。
LLVM在嵌入式領(lǐng)域有兩類(lèi)應(yīng)用方案:一是由芯片廠商提供的平臺(tái)專(zhuān)用集成工具鏈(如armclang、LLVMforARM等),但此類(lèi)方案存在廠商依賴(lài)性;二是采用Zig語(yǔ)言作為編譯前端,其原生的跨平臺(tái)編譯能力使其成為嵌入式領(lǐng)域理想的交叉編譯工具鏈選擇。
本文提出一種面向通用嵌入式系統(tǒng)開(kāi)發(fā)的解決方案:將xmake作為主構(gòu)建工具,Zig作為交叉編譯工具鏈?zhǔn)褂谩_@種組合既規(guī)避了單一工具鏈的局限性,又保留了Zig編譯器的強(qiáng)大功能和xmake的靈活構(gòu)建能力。通過(guò)在實(shí)際復(fù)雜系統(tǒng)RT-Thread上驗(yàn)證,我們成功實(shí)現(xiàn)了基于xmake+zig的嵌入式系統(tǒng)開(kāi)發(fā)流程優(yōu)化。

編譯生成的系統(tǒng)固件可正常運(yùn)行:

實(shí)施方案詳解
本方案通過(guò)xmake與Zig的協(xié)同工作,為嵌入式系統(tǒng)開(kāi)發(fā)提供更穩(wěn)定、更靈活的構(gòu)建流程。以下是詳細(xì)實(shí)施步驟:
1.1 配置嵌入式平臺(tái)C庫(kù)支持
由于Zig采用LLVM的Clang前端進(jìn)行編譯,其對(duì)裸機(jī)平臺(tái)缺乏內(nèi)置libc支持。為解決這一問(wèn)題,我們選擇使用輕量級(jí)C標(biāo)準(zhǔn)庫(kù)實(shí)現(xiàn)(如本例中的mlibc)。在RT-Thread上具體配置步驟如下:
執(zhí)行menuconfig配置工具,啟用mlibc軟件包
運(yùn)行pkgs --update命令下載依賴(lài)包

完成配置后,首先通過(guò)原生構(gòu)建工具scons驗(yàn)證基礎(chǔ)編譯功能正常:

1.2 制作xmake構(gòu)建文件
RT-Thread提供了便捷的構(gòu)建文件生成功能,執(zhí)行以下命令導(dǎo)出xmake配置:
scons--target=xmake

生成的xmake.lua文件需進(jìn)行調(diào)整:移除工具鏈相關(guān)配置,以便后續(xù)手動(dòng)指定Zig作為編譯器:

對(duì)于簡(jiǎn)單的c項(xiàng)目,xmake可以自動(dòng)識(shí)別并生成構(gòu)建文件,無(wú)需手動(dòng)配置。
1.3 配置并執(zhí)行xmake構(gòu)建
使用以下命令配置xmake以使用Zig作為交叉編譯工具鏈:
xmake f-pcross--cross=thumb-freestanding-eabi --toolchain=zig
該命令通過(guò)-p cross參數(shù)指定交叉編譯模式,--cross=thumb-freestanding-eabi定義目標(biāo)平臺(tái)的架構(gòu)-系統(tǒng)-ABI三元組,--toolchain=zig聲明使用Zig作為編譯工具鏈。

配置完成后,執(zhí)行xmake命令啟動(dòng)編譯過(guò)程:

在構(gòu)建過(guò)程中,由于目標(biāo)平臺(tái)的多樣性和工具鏈的差異,可能遇到多種編譯和鏈接錯(cuò)誤。以下是常見(jiàn)的問(wèn)題及其解決方案。
常見(jiàn)構(gòu)建問(wèn)題分析與解決方案
在嵌入式系統(tǒng)構(gòu)建過(guò)程中,可能遇到多種錯(cuò)誤類(lèi)型。以下根據(jù)錯(cuò)誤性質(zhì)進(jìn)行分類(lèi)說(shuō)明與解決:
2.1 編譯錯(cuò)誤處理
2.1.1 未知CPU錯(cuò)誤
錯(cuò)誤表現(xiàn):編譯過(guò)程中出現(xiàn)error: unknown CPU錯(cuò)誤
原因分析:Zig編譯器與GCC在CPU型號(hào)命名規(guī)范上存在差異,Zig使用下劃線作為分隔符,而GCC使用連字符
解決方案:將CPU型號(hào)中的連字符替換為下劃線,如將cortex-m4修改為cortex_m4


2.1.2 未定義函數(shù)引用
錯(cuò)誤表現(xiàn):鏈接過(guò)程中出現(xiàn)函數(shù)未定義錯(cuò)誤


原因分析:Clang編譯器對(duì)符號(hào)未定義的檢測(cè)機(jī)制較GCC更為嚴(yán)格
解決方案:添加編譯參數(shù)臨時(shí)屏蔽特定錯(cuò)誤

2.1.3 內(nèi)置宏定義錯(cuò)誤
錯(cuò)誤表現(xiàn):使用__DATE__、__TIME__等內(nèi)置宏時(shí)出現(xiàn)編譯錯(cuò)誤

解決方案:添加編譯參數(shù)臨時(shí)屏蔽相關(guān)錯(cuò)誤

2.2 鏈接錯(cuò)誤處理
2.2.1 不支持的鏈接參數(shù)
錯(cuò)誤表現(xiàn):鏈接過(guò)程中出現(xiàn)-Map參數(shù)不兼容錯(cuò)誤

解決方案:移除鏈接命令中不兼容的-Map選項(xiàng)


2.2.2 ARM異常表段沖突
錯(cuò)誤表現(xiàn):出現(xiàn).data段與.ARM.extab.text段地址重疊錯(cuò)誤
PS F:\workspace\rt-thread\bsp\stm32\stm32f407-rt-spark> xmake[93%]: linking.release rtthread.elferror: ld.lld: error: section .data load addressrangeoverlapswith.ARM.extab.text.list_thread>>>.datarangeis[0x8056C8C,0x806FBBF]>>>.ARM.extab.text.list_threadrangeis[0x8056C8C,0x8056C97]
解決方案:修改鏈接腳本,在.ARM.exidx段之前顯式定義.ARM.extab段
.ARM.extab :{ *(.ARM.extab* .gnu.linkonce.armextab.*)} > CODE
/* .ARM.exidx is sorted, so has to go in its own output section. */__exidx_start = .;.ARM.exidx :{ *(.ARM.exidx* .gnu.linkonce.armexidx.*)
/* This is used by the startup in order to initialize the .data secion */ _sidata = .;} >CODE__exidx_end=.;
2.2.3 固件大小超限
錯(cuò)誤表現(xiàn):出現(xiàn)section overflowed錯(cuò)誤,表明編譯生成的固件超出目標(biāo)平臺(tái)內(nèi)存段限制

解決方案:提升編譯優(yōu)化級(jí)別(從O0調(diào)整至O2)以減小生成代碼體積

總結(jié)與展望
本文介紹了一種面向通用嵌入式系統(tǒng)開(kāi)發(fā)的xmake+zig構(gòu)建方案,解決了傳統(tǒng)構(gòu)建工具鏈的局限性問(wèn)題。通過(guò)將xmake作為主構(gòu)建工具,Zig僅作為交叉編譯工具鏈?zhǔn)褂茫覀兂晒?shí)現(xiàn)了嵌入式系統(tǒng)的穩(wěn)定編譯與運(yùn)行。
該方案具有以下優(yōu)勢(shì):
降低了對(duì)單一工具鏈的依賴(lài),增強(qiáng)了構(gòu)建系統(tǒng)的穩(wěn)定性和可移植性
保留了Zig編譯器的性能優(yōu)勢(shì)和現(xiàn)代化特性
通過(guò)xmake強(qiáng)大的構(gòu)建能力,提供了更靈活的項(xiàng)目配置選項(xiàng),同時(shí)避免了zig語(yǔ)法變動(dòng)導(dǎo)致的build.zig構(gòu)建錯(cuò)誤
未來(lái),隨著Zig語(yǔ)言的進(jìn)一步成熟和嵌入式開(kāi)發(fā)工具鏈的持續(xù)演進(jìn),我們可以探索更多優(yōu)化可能性,如進(jìn)一步整合Zig的內(nèi)存安全特性,提升嵌入式系統(tǒng)的可靠性與安全性,為更廣泛的嵌入式應(yīng)用場(chǎng)景提供高效開(kāi)發(fā)方案。
-
嵌入式系統(tǒng)
+關(guān)注
關(guān)注
41文章
3719瀏覽量
133226 -
硬件
+關(guān)注
關(guān)注
11文章
3559瀏覽量
68833 -
Zig
+關(guān)注
關(guān)注
0文章
8瀏覽量
8311
發(fā)布評(píng)論請(qǐng)先 登錄
嵌入式系統(tǒng)開(kāi)發(fā)的基礎(chǔ)知識(shí)
嵌入式系統(tǒng)開(kāi)發(fā)
嵌入式系統(tǒng)開(kāi)發(fā)圣經(jīng)
ARM嵌入式系統(tǒng)開(kāi)發(fā)-軟件設(shè)計(jì)與優(yōu)化
嵌入式系統(tǒng)開(kāi)發(fā)面臨的問(wèn)題總結(jié)
ARM嵌入式系統(tǒng)開(kāi)發(fā)_Android應(yīng)用開(kāi)發(fā)入門(mén)(基礎(chǔ)版)
嵌入式系統(tǒng)設(shè)計(jì)--課堂總結(jié)(嵌入式Linux系統(tǒng)開(kāi)發(fā))
嵌入式系統(tǒng)開(kāi)發(fā)設(shè)計(jì)
嵌入式系統(tǒng)開(kāi)發(fā)概述
嵌入式系統(tǒng)開(kāi)發(fā)三大核心技術(shù)
嵌入式系統(tǒng)開(kāi)發(fā)資料分享

使用xmake+zig更優(yōu)雅的進(jìn)行嵌入式系統(tǒng)開(kāi)發(fā)
評(píng)論