《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > BLOB啟動流程分析及引導程序可移植性研究

BLOB啟動流程分析及引導程序可移植性研究

2008-07-02
作者:周永冠1,林喜榮1,2,周 斌

? 摘 要: 在基于PXA255處理器的系統上對一種廣泛應用的Bootloader——BLOB(Boot Loader Object)的啟動流程進行分析,并以此為根據就一般引導程序" title="引導程序">引導程序的可移植性" title="可移植性">可移植性進行了研究。
? 關鍵詞: 引導程序? BLOB? 可移植性

?

?? ?在嵌入式系統應用中,通過引導程序(Bootloader)可以初始化硬件設備、建立內存空間的映射圖、加載內核,從而將系統的軟硬件環境帶到一個合適的狀態,以便為最終調用操作系統內核準備好正確的環境[1]。Bootloader依賴于實際的硬件和應用環境,對于不同的硬件架構以及相同架構的不同電路板,都需要不同的Bootloader。由于單獨開發Bootloader的工作量較大,因此開發人員一般針對固定體系構架開發一種可移植性的Bootloader,使之能夠在少量修改后應用于同一體系構架的其他電路板。BLOB就是一種針對ARM體系定制的可移植性良好的嵌入式Linux引導程序。BLOB支持多種CPU,包括SA1100、SA1110、PXA255、PXA270等,用戶可以根據目標板" title="目標板">目標板的特性進行定制。它能實現以下功能:
? ?(1)引導嵌入式Linux,它可以把Linux、Kernel等從Flash加載到RAM中執行;
? ?(2)命令行下在線更新BLOB、Kernel和ramdisk;
? ?(3)命令行下可以直接對物理尋址空間進行查看和修改。
? ?可見BLOB除了引導系統這個基本功能外,還具備板級支持包(BSP)開發的功能。
1 啟動流程分析
??? 系統的啟動通常有兩種方式,一種是可以直接Flash 啟動,另一種是可以將壓縮的內存映像文件從Flash中復制、解壓到RAM,再從RAM啟動。系統上電時,BLOB采用后者,啟動過程分兩個階段進行,其中第一階段在Flash中運行,第二階段在RAM中運行。圖1為BLOB啟動流程圖。

??????????????????????? ?
1.1 第一階段
?? ?第一階段為從系統上電后在0x00000000 地址開始執行的部分。這部分代碼運行在Flash中,其目的是為第二階段(stage 2)的執行以及隨后的Kernel的執行準備好基本的硬件環境[2]
?? (1)屏蔽所有的中斷
?? 為中斷提供服務通常是OS設備驅動程序的責任,因此在Bootloader的執行全過程中不必響應任何中斷。中斷屏蔽可以通過寫CPU的中斷屏蔽寄存器或狀態寄存器(如ARM的CPSR寄存器)來完成。
?? (2)設置CPU的速度和時鐘頻率
?? (3)RAM初始化
? ?包括正確地設置系統內存控制器的功能寄存器以及各內存庫控制寄存器等。
?? (4)LED初始化
? ?通過GPIO來驅動LED,其目的是表明系統的狀態是否正常。如果板子上沒有LED,則可以通過初始化UART向串口打印 Bootloader的Logo字符信息來完成。
1.2 第二階段
?? ?第二階段是C語言執行代碼,具體說明如下。
?? (1)UART設置及初始化
??? 至少初始化一個串口,以便與終端用戶進行 I/O 輸出信息,初始化計時器等。設備初始化完成后,可以輸出一些打印信息、程序名字字符串、版本號等。
??? (2)設置系統的內存映射" title="內存映射">內存映射
?? ?內存映射是指在整個物理地址空間中有哪些地址被分配用來尋址系統的RAM單元。具體的嵌入式系統往往只把CPU預留的全部RAM地址空間中的一部分映射到RAM單元上,而讓剩下的部分預留RAM地址空間處于未使用狀態。因此Bootloader的 stage 2必須在使用它之前檢測整個系統的內存映射情況。在用上述算法檢測完系統的內存映射情況后,BLOB將內存映射的詳細信息打印到串口。
??? (3)加載內核映像和根文件" title="根文件">根文件系統映像
??? 在規劃內存占用的布局時,應包括兩個方面:內核映像所占用的內存范圍;根文件系統所占用的內存范圍。在規劃內存占用布局時,主要考慮基地址和映像的大小兩個方面。
對于內核映像,一般將其拷貝到從(MEM_START+0x8000)這個基地址開始的大約1MB大小的內存范圍內(嵌入式Linux的內核一般都不超過1MB)。
??? 而對于根文件系統映像,則一般將其拷貝到 MEM_START+0x0010,0000開始的地方。如果用Ramdisk作為根文件系統映像,則其解壓后的大小一般是1MB。
?? (4)設置Linux內核的啟動參數。
? ?(5)可以選擇直接調用內核或者進入下載模式。
?? 在下載模式下,BLOB將通過串口從主機(Host)下載文件,例如下載內核映像和根文件系統映像等。
2 Bootloader的可移植性研究
? ?大部分Bootloader的總體結構與BLOB類似,一般分為兩個階段運行。其中第一階段與CPU架構相關,不同架構CPU往往要求不同的Bootloader與之對應[3],只有少數Bootloader能夠適用于多種架構的CPU,如表1。

????????????????
2.1 相同構架下Bootloader移植
?? ?對于相同的CPU構架,Bootloader移植工作大體上可以分為三部分。
???(1)目標板驅動部分,針對特定CPU、Flash、SDRAM等對驅動程序進行定制。完成處理器各個I/O口的初始化、Flash描述(包括區塊大小及數量)和Flash初始化等。一個必要的工作是Flash分區表的配置,Flash的典型空間分配結構如圖2所示。

??????????????????

?? (2)目標板相關的頭文件,文件中包含了目標板配置的宏定義,主要有系統工作頻率、GPIO定義、Flash 各分塊起始地址及容量、Flash 讀/寫命令字、SDRAM寄存器配置、SDRAM起始地址及容量、內核裝載地址等。其中大部分GPIO設置的目的是在Bootloader下做板載開發,這項功能不是必需的。而CPU頻率及Flash的設置則直接影響到系統能否啟動。對于采用Ramdisk技術的系統開發,SDRAM的配置也直接關系到Kernel的加載。因此,各頭文件的代碼修改是移植過程的重點。
??? (3)Bootloader總體配置文件修改,包括目標板聲明、指定目標板頭文件、定制文件關聯關系等。
?? ?圖3以BLOB在PXA255[4]的目標板上移植為例表現了需要增、改的關鍵文件之間的內在聯系。
? ????????????????????

? ?圖3中:
?? (1)src/blob/PXA255.c:筆者編寫的針對PXA255目標板驅動文件,這里是采用默認設置的最簡情況,必要時還需對文件如Flash.c等進行修改。
? ?(2)include/blob/arch/PXA255.h:目標板頭文件,它必須通過arch.h及config.h進行指定,最終反映在configure.in中。
? ?(3)configure.in:添加目標板聲明,如果已有目標板類型,則無需修改該文件;如果沒有,則需要根據情況添加目標板名稱、CPU型號、必需的.o文件,如:
PXA255)
? AC_MSG_RESULT(Ipaq PXA255)
? AC_DEFINE(PXA255)
? AC_DEFINE(USE_SERIAL3)
? BLOB_PLATFORM_OBJ=″PXA255.o″
? BLOB_FLASH_OBJS=″nullflash.o″
? use_cpu=″PXA255″
? use_lcd=″no″
? ?(4)Makefile.am:由于添加了PXA255.c和PXA255.h,所以要在它們所在目錄的Makefile.am中進行登記,保證configure.in和Makefile.am在進行./configure處理時能夠生成正確的Makefile文件,最終在執行Make命令后生成BLOB的可執行文件。
? ?需要注意的是Linux內核必須根據目標板硬件情況作相應的設置[5],這里不展開論述。
2.2 不同構架下Bootloader移植
?? ?根據Bootloader的啟動流程可知,對于不同架構的CPU,盡管處理流程相似,但是實現方法不同,主要體現在啟動的第一階段對CPU的設置上。所以這部分的硬件相關代碼基本上要重新編寫。
? ?多數Bootloader在stage1的代碼不易由C語言實現,因而大多采用匯編語言實現。以U-boot為例,stage1代碼主要位于start.S、IO.S、Cache.S中,其中最重要的是start.S。該代碼主要針對特定處理器,對其內部各個寄存器進行設置并初始化CPU。主要完成設置處理器工作模式、初始化緩沖區、設置堆棧、設置中斷向量、內存控制器初始化[6]。
? ?完成stage1代碼編寫之后,還需要按照相同構架下Bootloader移植的方法對相關代碼進行編寫。
2.3 提高可移植性的方案設計
??? 目前影響Bootloader可移植性的因素主要有:CPU不同架構,同一架構不同CPU型號,目標板硬件不同結構。針對以上問題提出了幾點提高可移植性的方案設計。
?? ?(1)對于遵從GPL協議的開源Bootloader,可以根據不同架構和不同硬件定制相應的驅動文件,如各種.c和.h文件。考慮到目前嵌入式硬件種類非常多,需要大量開源軟件開發者的支持,盡管不能覆蓋所有硬件,但在一定范圍內可以大大減少嵌入式系統開發的工作量。
?? ?(2)在上一步的基礎上,采用類似Linux內核配置的方法(如make menuconfig或make xconfig),用終端式的配置菜單對具體硬件進行設置,減少移植過程中代碼級的修改。
??? 本文以BLOB為例分析了Bootloader的啟動流程,并根據該過程對Bootloader的可移植性進行了討論,并對移植過程的關鍵技術進行了深入研究,最后還提出了提高可移植性的方案設計。在實驗過程中實現了BLOB在PXA255目標板及SA1110目標板的移植。此項研究已經應用在清華大學精密測試技術與儀器國家重點實驗室的嵌入式生物特征識別平臺上,可以實現BLOB、內核鏡像、文件系統鏡像的下載及內核的引導。
參考文獻
[1] YAGBMUOR K.Building embedded linux systems.O′Reilly Media Inc,2004.
[2] LOMBARDO J.Embedded linux[M].New Riders Publishing,2001.
[3] 胡修林,余凱軍.基于arms3c44b0x處理器的Bootloader設計和實現.計算機應用,2006,(7).
[4] 周余,都思丹,王自強,等.應用處理器PXA255上的嵌入式Linux系統開發.計算機應用,2004,(3).
[5] Intel Corp.PXA255 Applications processors design Guide.Intel Corp,2003.
[6] 錢峰,劉曄,范靜輝,等.U-Boot在S3C44B0上的移植.微計算機信息,2006,(26).

?

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲二区在线视频| 亚洲愉拍自拍另类高清精品| 99ri日韩精品视频| 亚洲电影免费观看高清完整版在线| 国产三级欧美三级| 国产精品另类一区| 国产精品久久久久久户外露出| 欧美精品久久久久久久久久| 欧美成人精品在线播放| 另类av一区二区| 久久亚洲电影| 蜜臀av一级做a爰片久久| 美乳少妇欧美精品| 欧美国产精品劲爆| 欧美精品久久久久久久久久| 欧美精品成人| 欧美日韩黄色一区二区| 欧美日韩国内| 国产精品swag| 国产精品人人爽人人做我的可爱| 欧美视频一区二区三区…| 欧美三级电影一区| 国产精品毛片高清在线完整版| 国产精品高潮粉嫩av| 国产精品久久久久久影院8一贰佰| 欧美视频一区在线观看| 国产精品国产福利国产秒拍| 国产精品色一区二区三区| 国产精品欧美日韩一区| 国产精品亚洲一区| 国产自产v一区二区三区c| 永久久久久久| 亚洲日本va午夜在线电影| 9人人澡人人爽人人精品| 亚洲视频福利| 欧美一区二区三区免费视频| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲成人在线观看视频| 亚洲国产精品一区二区www在线| 亚洲欧洲精品一区二区三区 | 欧美色欧美亚洲另类二区| 国产精品久久久久7777婷婷| 国产日韩精品久久| 亚洲第一在线视频| 99视频一区| 欧美一级视频免费在线观看| 亚洲高清视频在线观看| 亚洲视频在线免费观看| 午夜精品短视频| 久久夜色精品国产亚洲aⅴ| 欧美女同视频| 国产精品亚洲综合久久| 狠狠色丁香婷婷综合久久片| 亚洲精品免费网站| 亚洲欧美中文字幕| 亚洲另类自拍| 欧美一区二区高清| 欧美激情精品久久久久久免费印度 | 欧美在线中文字幕| 一区二区免费看| 久久久精品999| 欧美日韩一区二区三区免费| 国产一区二区三区av电影| 亚洲国产美女| 午夜精品理论片| 99精品99| 久久久亚洲一区| 欧美午夜一区二区| 亚洲电影自拍| 亚洲女人天堂av| 一区二区日韩免费看| 久久午夜视频| 国产精品久久久久免费a∨大胸| 韩日欧美一区二区| 中文国产一区| 亚洲另类一区二区| 久久久久久久久综合| 欧美午夜精品理论片a级大开眼界| 黄色成人小视频| 亚洲影音先锋| 宅男精品视频| 美女视频一区免费观看| 国产精品入口麻豆原神| 亚洲青色在线| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美乱妇高清无乱码| 国产一区二区三区在线观看精品 | 一区二区精品在线| 亚洲欧洲偷拍精品| 久久精品欧美日韩精品| 国产精品成人aaaaa网站| 亚洲人成人一区二区三区| 久久www成人_看片免费不卡| 午夜日韩电影| 欧美日韩调教| 亚洲欧洲在线免费| 最近中文字幕日韩精品 | 一区二区冒白浆视频| 免费不卡在线观看av| 国产欧美另类| 亚洲四色影视在线观看| 亚洲美女免费精品视频在线观看| 久久久久久网站| 国产日韩欧美一区| 亚洲一区成人| 亚洲一区二区三区四区五区黄| 欧美精品一区二区视频| 亚洲国产你懂的| 亚洲国产精品欧美一二99| 久久嫩草精品久久久精品一| 国产一区99| 久久成人羞羞网站| 久久动漫亚洲| 国产在线观看91精品一区| 欧美一区二区精美| 久久er精品视频| 国产欧美一区在线| 午夜精品福利一区二区蜜股av| 亚洲欧美国产77777| 欧美午夜视频在线| 日韩一级精品视频在线观看| 在线视频你懂得一区二区三区| 欧美承认网站| 亚洲欧洲一区二区在线播放 | 久久久久久久久久久成人| 国产亚洲一区在线| 午夜视频在线观看一区二区三区| 欧美亚洲一区二区三区| 国产精品免费久久久久久| 国产精品99久久久久久久久| 亚洲自拍电影| 国产欧美va欧美不卡在线| 午夜精品久久久久久久99樱桃 | 欧美在线视频一区二区三区| 国产精品户外野外| 亚洲电影免费观看高清完整版在线| 亚洲国产专区| 欧美高清视频www夜色资源网| 亚洲高清一区二区三区| 亚洲精品永久免费精品| 欧美日韩国语| 亚洲一二三四久久| 久久精品夜色噜噜亚洲a∨ | 亚洲一区二区免费看| 久久福利视频导航| 一区二区三区在线视频观看| 亚洲美女中文字幕| 欧美久久久久久蜜桃| 欧美日韩中文另类| 欧美日韩国产区一| 亚洲国产精品电影在线观看| 久久久免费精品视频| 一区二区三区自拍| 99成人免费视频| 国产精品久久久久久av福利软件| 亚洲综合视频在线| 久久综合色播五月| 亚洲狼人综合| 先锋影音国产精品| 国产一区自拍视频| 日韩视频精品在线| 国产精品欧美在线| 亚洲第一福利在线观看| 欧美激情一区二区久久久| 亚洲一区精品在线| 久久久综合激的五月天| 亚洲精品久久久久久久久久久| 亚洲免费一级电影| 国产综合久久| 在线视频精品| 国产午夜精品理论片a级大结局 | 午夜久久资源| 欧美黄污视频| 午夜国产一区| 欧美精品一区二区三区一线天视频| 亚洲视频中文字幕| 蜜桃精品久久久久久久免费影院| 日韩视频在线一区| 久久久999成人| 亚洲毛片一区二区| 久久精品人人做人人综合| 亚洲精品久久久久久久久久久| 亚洲欧美国产制服动漫| 亚洲国产精品t66y| 欧美一区二区三区四区高清| 最新日韩在线视频| 久久精品国产91精品亚洲| 亚洲精品一区二区三区在线观看| 久久激情五月丁香伊人| 亚洲精品久久久一区二区三区| 久久成人免费电影| 亚洲日本欧美在线| 久久久久久国产精品mv| aa级大片欧美三级| 麻豆国产精品777777在线| 亚洲一级黄色| 欧美日本视频在线| 亚洲国产高清自拍| 国产亚洲一级| 亚洲欧美日韩直播|