在嵌入式Linux系統(tǒng)中,這些工作由Bootloacler(引導(dǎo)加載程序)完成,它是在嵌入式系統(tǒng)CPU加電復(fù)位和進(jìn)入操作系統(tǒng)之前運(yùn)行的代碼,主要用于完成由硬件啟動(dòng)到操作系統(tǒng)啟動(dòng)的過(guò)渡,為操作系統(tǒng)提供基本的運(yùn)行環(huán)境,如初始化CPU、堆棧、存儲(chǔ)器系統(tǒng)等,其數(shù)值必須要符合用戶的硬件配置,并且按特定順序?qū)懭搿G度胧絃inux系統(tǒng)的引導(dǎo)、配置甚至應(yīng)用程序的運(yùn)行都與Bootloader有關(guān)。
Bootloader源代碼與CPU的內(nèi)核結(jié)構(gòu)和嵌入式設(shè)備的板級(jí)配置有關(guān),必須根據(jù)具體的系統(tǒng)設(shè)計(jì)要求進(jìn)行移植。目前,開(kāi)源社團(tuán)已經(jīng)發(fā)展了多種引導(dǎo)Linux內(nèi)核的bootloader,比如PowerPC體系的U-Boot、miniBoot,ARM體系的blob,Intel x32體系的gurb、openBIOS等。
以MPC8265微處理器和嵌入式Linux為背景,針對(duì)性地提出U-Boot的移植方法并進(jìn)行分析研究,此方法可廣泛用于基于MPC282xx系列處理器的嵌入式Linux系統(tǒng)應(yīng)用開(kāi)發(fā)中。
1 U-Boot引導(dǎo)加載程序
1.1 U-Boot簡(jiǎn)介
U-Boot(Universal Boot Loader)是遵循GPL條款的開(kāi)放源碼項(xiàng)目。它支持多種嵌入式處理器,如ARM、PowerPC、MIPS等,也支持Linux、VxWorks、QNX、RTEMS、ARTOS、LynxOS等多種嵌入式操作系統(tǒng)。這2個(gè)特點(diǎn)正是U-Boot項(xiàng)目的開(kāi)發(fā)目標(biāo),即支持盡可能多的嵌入式處理器和嵌入式操作系統(tǒng)。
U-Boot支持的主要功能如下:1)系統(tǒng)引導(dǎo):支持NFS掛載、從Flash中引導(dǎo)(壓縮或非壓縮)系統(tǒng)內(nèi)核;RAMDISK(壓縮或非壓縮)形式的根文件系統(tǒng);2)強(qiáng)大的操作系統(tǒng)接口功能,可靈活設(shè)置、傳遞多個(gè)關(guān)鍵參數(shù)給操作系統(tǒng),適合系統(tǒng)在不同開(kāi)發(fā)階段的調(diào)試要求與產(chǎn)品發(fā)布:3)支持目標(biāo)板環(huán)境參數(shù)多種存儲(chǔ)方式(如Flash、NVRAM、EEPROM);4)CRC32校驗(yàn),可校驗(yàn)Flash中內(nèi)核、RAMDISK鏡像文件是否完好;5)設(shè)備驅(qū)動(dòng):串口、SDRAM、Flash、以太網(wǎng)、LCD、NVRAM、EEP-ROM、鍵盤(pán)、USB、PCMCIA、PCI、RTC等驅(qū)動(dòng)支持;6)上電自檢功能:SDRAM、Flash自動(dòng)檢測(cè),SDRAM故障檢測(cè),CPU型號(hào)。
1.2 U-Boot主要目錄結(jié)構(gòu)
U-Boot源代碼采用高度模塊化的編程方式,便于在不同的硬件平臺(tái)上移植。U-Boot源代碼包含多個(gè)目錄,其中與移植相關(guān)的主要有:1)board:目標(biāo)板相關(guān)文件,存放U-Boot支持的所有目標(biāo)板的子目錄。目標(biāo)板上大部分資源的初始化代碼就在這個(gè)文件夾中,如SDRAM、Flash驅(qū)動(dòng);2)common:獨(dú)立于處理器體系結(jié)構(gòu)的通用代碼,實(shí)現(xiàn)U-Boot各種公共命令的C文件;3)cpu:存放U-Boot支持的各類型CPU的相關(guān)文件,主要是初始化執(zhí)行環(huán)境,比如mpc8260子目錄包含串口、網(wǎng)口、LCD驅(qū)動(dòng)及中斷初始化等文件;4)drivers:通用設(shè)備的驅(qū)動(dòng)程序,如CFI flash驅(qū)動(dòng);5)fs:U-Boot支持的文件系統(tǒng),如ext2、cramfs、fat、fdos、jffs2和registeRFs等;6)net:與網(wǎng)絡(luò)功能有關(guān)的文件,如B00TP、TFTP、RARP和NFS相關(guān)代碼;7)include:存放頭文件。子目錄include/configs下與目標(biāo)板相關(guān)的配置頭文件是移植過(guò)程中經(jīng)常要修改的文件,可配置目標(biāo)板的各項(xiàng)參數(shù)(如波特率、引導(dǎo)啟動(dòng)參數(shù)等)。還有對(duì)各種硬件平臺(tái)支持的匯編文件、系統(tǒng)的配置文件和對(duì)文件系統(tǒng)支持的文件。U-Boot源代碼可以從DENX的網(wǎng)站(http://www.denx.de)下載,本文使用的版本是U-Boot-1.2.0。
2 U-Boot的運(yùn)行流程
U-Boot的運(yùn)行流程如圖1所示,目標(biāo)板上電,啟動(dòng)MPC8265存儲(chǔ)控制器CS0有效,選中Flash,CPU地址線上輸出硬件復(fù)位中斷向量對(duì)應(yīng)的地址,此時(shí)執(zhí)行第1條指令,對(duì)應(yīng)\cpu\mpc8260\start.S中的_start:開(kāi)始執(zhí)行。完成CPU本身基本的初始化后,初始化CPU內(nèi)部寄存器,設(shè)置IMMR、ICTRL等。然后跳轉(zhuǎn)到\cpu\mpc8260\cpu_init.c的函數(shù)cpu_init_f處,進(jìn)行CPU的底層初始化,主要設(shè)置watchdog、SIUMCR寄存器、PIT、鎖相環(huán)、系統(tǒng)定時(shí)器、存儲(chǔ)控制器和CPM等。從start.S中跳轉(zhuǎn)到\lib_ppe\board.c的函數(shù)board_init_f處,實(shí)現(xiàn)目標(biāo)板上的第1次初始化,完成SMC初始化和一些硬件測(cè)試,尤其是RAM初始化,并分配內(nèi)存空間,保存板級(jí)信息,準(zhǔn)備在RAM中重定向U-Boot代碼。完成后,跳轉(zhuǎn)到start.S中的函數(shù)relocate_code()處,重定向代碼,將U-Boot代碼搬至SDRAM工作,開(kāi)始在RAM中運(yùn)行。然后跳轉(zhuǎn)到board.c文件的函數(shù)board_init_r()處,執(zhí)行板上的第2次初始化,主要完成一些數(shù)據(jù)結(jié)構(gòu)、高端模塊及系統(tǒng)設(shè)備的相關(guān)初始化。最后,U-Boot執(zhí)行board_init_r()中的函數(shù)main_loop(),根據(jù)用戶從控制臺(tái)的輸入,完成預(yù)先設(shè)定的工作。
3 U-Boot的移植
U-Boot在設(shè)計(jì)時(shí)已考慮到支持使用不同CPU處理器的開(kāi)發(fā)板,根據(jù)具體板級(jí)硬件配置的設(shè)計(jì)要求,修改與其相關(guān)的源代碼,將U-Boot移植到新的開(kāi)發(fā)板上。這里開(kāi)發(fā)板TDS8265外圍接口主要有100 M網(wǎng)口、RS232串口和JTAG調(diào)試接口等。
3.1 修改U-Boot源代碼
為了簡(jiǎn)化移植工作,可在U-Boot源碼中選擇一個(gè)與開(kāi)發(fā)板接近的參考平臺(tái),然后從移植U-Boot的要求和開(kāi)發(fā)板能正常啟動(dòng)的角度出發(fā)進(jìn)行修改。
這里以在U-Boot/board目錄下為T(mén)DS8265開(kāi)發(fā)板新建文件夾TDS8265為例進(jìn)行說(shuō)明。
1)修改頭文件TDS8265.h路徑是U-Boot/include/configs/TDS8265.h,是開(kāi)發(fā)板的主要配置元件,配置CPU、系統(tǒng)時(shí)鐘、SDRAM、Flash以及其他開(kāi)發(fā)板相關(guān)信息。設(shè)置CPU寄存器參數(shù),需仔細(xì)對(duì)照處理器datasheet中各寄存器的定義、參考設(shè)置、目標(biāo)板實(shí)際情況等做出選擇并測(cè)試。MPC82xx系列處理器較為關(guān)鍵的寄存器有SIUMCR、PS-DMR、SCCR、BRx、ORx等。設(shè)置CPU寄存器基地址IMMR時(shí),注意與硬件配置相對(duì)應(yīng)。如:
設(shè)置與Flash控制相關(guān)的寄存器BR0、OR0時(shí),根據(jù)目標(biāo)板所用Flash的數(shù)據(jù)手冊(cè)與BR0和OR0的相關(guān)位含義合理設(shè)置,這不僅關(guān)系到Flash能否正常工作,而且與串口調(diào)試直接相關(guān)。設(shè)置Flash、SDRAM,包括基址、大小、環(huán)境變量的偏移,內(nèi)存刷新周期。設(shè)置環(huán)境變量,網(wǎng)絡(luò)接口,IP地址,MAC地址,用于網(wǎng)絡(luò)下載和啟動(dòng);設(shè)置Linux內(nèi)核啟動(dòng)參數(shù)init=/sbin/init。
2)編寫(xiě)tds8265.c文件 路徑是U-Boot/board/tds8265/tds8265.c。tds8265.c是目標(biāo)板的SDRAM的驅(qū)動(dòng)程序,涉及I/0端口表、相關(guān)寄存器的設(shè)置及SDRAM上電初始化過(guò)程3個(gè)主要部分。任何一部分有問(wèn)題,都會(huì)影響U-Boot、嵌入式操作系統(tǒng)甚至應(yīng)用程序的運(yùn)行,所以SDRAM的驅(qū)動(dòng)不僅關(guān)系到U-Boot本身能否正常運(yùn)行,而且還與后續(xù)部分相關(guān)。根據(jù)MPC8265處理器datasheet和開(kāi)發(fā)板的硬件電路圖,配置8265的I/0端口表;設(shè)置寄存器PSDMR和BRl、0R1;向SDRAM中寫(xiě)入8次以初始化SDRAM等。SDRAM的初始化是由/lib_ppc/board.c中的board_init_f()調(diào)用的,入口為tds8265.c的函數(shù)initdram。
3)修改config.mk文件 路徑是U-Boot/board/tds8265/config.mk。修改中,對(duì)該文件中的TEXT_BASE賦值應(yīng)與TDS8265.h中對(duì)CF-G_FLASH_BASE的賦值保持一致。
4)編寫(xiě)flash.c文件 路徑是U-Boot/board/tds8265/flash.c。flash.c是Flash的驅(qū)動(dòng)程序,是U-Boot讀/寫(xiě)、刪除Flash的源代碼文件,其中包括多個(gè)函數(shù),以實(shí)現(xiàn)不同的操作。如:
編寫(xiě)flash.c文件時(shí)需參考Flash的數(shù)據(jù)手冊(cè),嚴(yán)格按照其中的說(shuō)明實(shí)現(xiàn)Flash的各種操作。
5)創(chuàng)建U-boot.lds,U-boot.lds.debug,makefile文件 這些文件均在目錄U-Boot/board/tds8265之下。設(shè)置U-boot中各個(gè)目標(biāo)文件的連接地址。
6)修改MAKEALL文件 路徑是U-Boot/MAKEALL。因?yàn)槭褂玫氖荕PC8265,屬于82xx系列,所以在“LIST_82xx”下加入目標(biāo)板名稱“TDS8265”。
7)修改Makefile文件 路徑是U-Boot/Makefile。在Makefile文件中增加TDS8265開(kāi)發(fā)板的配置行,指定交叉編譯器的完整路徑名。
3.2 編譯U-Boot和移植鏡像文件
在源代碼修改完成后,即可進(jìn)行編譯。編譯U-Boot需要在Linux主機(jī)上建立交叉編譯環(huán)境,本文使用Montavista公司的Montavista Linux Pro 4.0。在Linux主機(jī)上安裝Montavista交叉編譯工具后,設(shè)置環(huán)境變量,將Montavista工具鏈路徑導(dǎo)入到主機(jī)系統(tǒng)的環(huán)境變量中。如:#gedit./.bash_profile,打開(kāi)文件.bash_profile,增加PATH=$PATH:/opt/montavista/pro/devrocket/ppc/82xx/bin,然后刪除之前可能錯(cuò)誤創(chuàng)建的所有目標(biāo)文件,并針對(duì)目標(biāo)板編譯。如下所示:
編譯完成后,得到3個(gè)文件:1)u-boot:ELF格式的文件,可被多數(shù)Debug程序識(shí)別;2)u-boot.bin:二進(jìn)制bin文件,U-boot的二進(jìn)制執(zhí)行代碼,可通過(guò)JTAG接口下載到開(kāi)發(fā)板;3)u-boot.srec: Motorola的S-Record格式文件,可通過(guò)BDM接口下載到開(kāi)發(fā)板。
不同開(kāi)發(fā)板對(duì)U-Boot鏡像文件在Flash中的存放地址要求不同,這是由處理器中斷復(fù)位向量決定的,與開(kāi)發(fā)板硬件相關(guān),源代碼中U-Boot起始地址必須與硬件復(fù)位向量相符合。
使用MPC82xx系列處理器的主板是由硬件配置字(HRCW)決定的,如RPXlite板的中斷復(fù)位向量設(shè)置為Ox00000100,因此U-B00t鏡像文件必須燒寫(xiě)到Flash的起始位置。多數(shù)的PPC系列的處理器中斷復(fù)位向量是Ox00000100和Oxfff00100,即高位啟動(dòng)和低位啟動(dòng)的Bootloader所在位置。U-boot鏡像文件在Flash中的存放地址可通過(guò)設(shè)置U-Boot源碼的<目標(biāo)板>.h頭文件中CFG_MONITOR_BASE以及board/<目標(biāo)板>/confi-g.mk中的TEXT_BASE來(lái)與硬件配置相對(duì)應(yīng)。
U-Boot鏡像文件在Flash中燒錄完成后,將目標(biāo)板和主機(jī)的串口連接起來(lái),目標(biāo)板上電復(fù)位,即可在主機(jī)終端窗口看到串口回顯的開(kāi)發(fā)板上U-Boot的啟動(dòng)引導(dǎo)信息,如圖2所示。
在終端窗口中輸入help,可以列出U-Boot所有命令列表。然后測(cè)試網(wǎng)口和Flash讀寫(xiě),工作正常,則可以認(rèn)為U-Boot移植工作基本完成,接下來(lái)可以添加一些其他功能,并進(jìn)行Linux內(nèi)核的引導(dǎo)和文件系統(tǒng)的移植。
4 結(jié)束語(yǔ)
Bootloader在嵌入式開(kāi)發(fā)中是操作系統(tǒng)和硬件的樞紐。在U-Boot移植過(guò)程中,不僅要掌握U-Boot的結(jié)構(gòu)和工作流程外還需要對(duì)硬件有一定了解。本文移植的U-Boot已穩(wěn)定運(yùn)行在開(kāi)發(fā)板上,而且可以通過(guò)FIash和網(wǎng)絡(luò)加載Linux內(nèi)核和NFS文件系統(tǒng),為后續(xù)開(kāi)發(fā)奠定了良好的基礎(chǔ)。對(duì)于不同的CPU和開(kāi)發(fā)板,基本方法和步驟是相同的,本文的工作對(duì)于基于MPC82xx系列處理器的硬件平臺(tái)的U-Boot移植具有借鑒意義,并對(duì)嵌入式Linux系統(tǒng)的開(kāi)發(fā)提供了有益的技術(shù)參考。?
評(píng)論
查看更多