導(dǎo)讀:嵌入式Linux系統(tǒng)搭建,bootloader是必不可少的一環(huán),而U-Boot已成嵌入式Linux事實標(biāo)準(zhǔn)。所以較為深入的分析U-Boot的設(shè)計,對于更好的理解U-Boot的工作原理有著重要意義。
1. U-Boot簡介
Das U-Boot 是一個主要用于嵌入式系統(tǒng)的引導(dǎo)加載程序,可以支持多種不同的計算機系統(tǒng)結(jié)構(gòu),包括PPC、ARM、AVR32、MIPS、x86、68k、Nios與MicroBlaze。這也是一套在GNU通用公共許可證之下發(fā)布的自由軟件。《百度百科》
見http://www.denx.de/wiki/U-Boot
如其官網(wǎng)上所述,具有十大黃金法則:小巧、快速、簡單、可移植、可配置、可調(diào)試、易用、可維護、優(yōu)雅、開源。
?。?. Keep it Small,2. Keep it Fast,3. Keep it Simple,4. Keep it Portable;5. Keep it Configurable;6. Keep it Debuggable;7. Keep it Usable;8. Keep it Maintainable;9. Keep it Beautiful;10. Keep it Open)
所以本文試圖從其設(shè)計的角度進行分析這些黃金法則,以期自己在軟件工程思想的角度能有所獲,同時也將自己筆記分享(Keep it open),方便與人交流,以期獲得更為深入的理解與體悟。
廢話說了蠻多,Let‘s go:
2. U-Boot文件夾拓?fù)浣Y(jié)構(gòu)
基于u-boot-u-boot-2016.09.y的文件夾結(jié)構(gòu)如下:
arch 體系架構(gòu)依賴
api 機器架構(gòu)獨立API,外部調(diào)用接口
實現(xiàn)I/O,如標(biāo)準(zhǔn)化輸入輸出,顯示,網(wǎng)絡(luò)API、存儲API等,為cmd提供支持
board 板級依賴實現(xiàn)。
cmd shell命令實現(xiàn)
common 與架構(gòu)無關(guān)的雜項獨立功能
configs 板級配置文件
disk 磁盤分區(qū)實現(xiàn)
doc 文檔
drivers 通用設(shè)備驅(qū)動程序
examples 應(yīng)用示例代碼
fs 文件系統(tǒng)實現(xiàn)(cramfs,ext2,jffs等)
include 頭文件
lib 通用庫
license
net 網(wǎng)絡(luò)通訊實現(xiàn)
post 上電自檢是實現(xiàn)
scripts 構(gòu)建腳本以及Makefile
tests 各種單元測試
tools 生成S-Record或U-Boot映像的工具等。
3. 項目管理
U-Boot采用Kconfig進行項目管理,實現(xiàn)可裁剪可配置,新版U-Boot已支持make menuconfig功能,實現(xiàn)了易用的設(shè)計目標(biāo)。其配置界面與內(nèi)核一樣。
4. 模塊層次架構(gòu)分析
arch 實現(xiàn)了不同體系結(jié)構(gòu)的CPU,指令集、設(shè)備樹底層抽象,利用鏈接綁定實現(xiàn)了符號入口相對位置保持不變,故才能實現(xiàn)將內(nèi)核鏡像拷貝到內(nèi)存然后進行引導(dǎo)的功能。lib實現(xiàn)了初始化C運行時環(huán)境(棧/堆指針等的初始化),dts實現(xiàn)了設(shè)備樹的底層體系架構(gòu)依賴的具體抽象剝離。
machine ,由于同樣的內(nèi)核相同,各家芯片外設(shè)都不盡相同,所以將各自個性實現(xiàn)剝離實現(xiàn)于此,這主要體系在ARM體系的芯片,由于ARM公司售賣IP,各家芯片廠商在內(nèi)核的基礎(chǔ)上延伸出各自不同的芯片,所以需要將差異性剝離實現(xiàn)。
board, 實現(xiàn)了產(chǎn)業(yè)鏈下游,設(shè)備廠商的差異性,對于產(chǎn)品設(shè)計而言,需要將各自在boot階段需要嚴(yán)格初始化的實現(xiàn)放在這里,比如IO口的初始化,產(chǎn)品中大部分IO口必須顯式設(shè)置其初始狀態(tài)。
driver 這里實現(xiàn)了boot階段必要的設(shè)備驅(qū)動,如網(wǎng)口、顯示等。
dts 實現(xiàn)了設(shè)備樹
api 實現(xiàn)了基本的IO,如標(biāo)準(zhǔn)化輸入輸出,顯示,網(wǎng)絡(luò)API、存儲API等,為cmd提供支持。
disk 實現(xiàn)了輕量級磁盤管理
fs 文件系統(tǒng)實現(xiàn)(cramfs,ext2,jffs等)
lib 通用庫,比如CRC算法,加密算法,壓縮算法,字符串操作等
cmd 實現(xiàn)了U-Boot命令集。
net 實現(xiàn)網(wǎng)絡(luò)協(xié)議層
cmd shell命令集,調(diào)用下層實現(xiàn)用戶接口功能,如下載,引導(dǎo),存儲環(huán)境變量,打印信息等。
common 是U-Boot 主體,如系統(tǒng)停留在U-Boot階段,CPU始終在執(zhí)行一個死循環(huán),run_main_loop()。
5.基于armv8無SPL的啟動流程分析
5.1 匯編程序執(zhí)行階段
5.2 C執(zhí)行階段
board_init_r的調(diào)用,進入C執(zhí)行階段,如下:
至此,粗淺的將U-Boot的架構(gòu)設(shè)計分析了一下。還有很多設(shè)計細(xì)節(jié)有待深挖。文中僅代表個人理解觀點,錯誤在所難免,歡迎交流。