當前位置:首頁 > 嵌入式 > 嵌入式軟件
[導讀]基于Intel PXA272的Bootloader的設計與實現(xiàn)

摘要:在嵌入式系統(tǒng)中,Bootloader在完成引導加載系統(tǒng)鏡像的同時,擴展和增加了具體硬件模塊上的功能支持,以方便開發(fā)人員進行開發(fā)和調試。這篇文章在基于Intel PXA 272嵌入式處理器的一個硬件平臺上,設計并實現(xiàn)了一個支持從SD卡加載系統(tǒng)鏡像并啟動系統(tǒng)的bootloader,并對其加載性能進行測試和分析。
關鍵詞:Bootloader,嵌入式處理器,WinCE操作系統(tǒng),SD卡

1  前言

    PC機中的引導程序一般由BIOS和位于MBR的OS  Bootloader(例如LILO或者GRUB)一起組成。然而在嵌入式系統(tǒng)中通常沒有像BIOS那樣的固件程序(有的嵌入式CPU有),因此整個系統(tǒng)的加載啟動任務就完全由Bootloader來完成。但是隨著嵌入式系統(tǒng)的發(fā)展,Bootloader已經逐漸在基本功能的基礎上進行了擴展,Bootloader可以更多地增加對具體系統(tǒng)的板級支持,即增加一些硬件模塊功能上的使用支持,以方便開發(fā)人員進行開發(fā)和調試。編寫B(tài)ootLoader是開發(fā)WinCE系統(tǒng)第一步,也是關鍵的一步。只有得到一個穩(wěn)定工作的Loader程序,才能夠更進一步開發(fā)WinCE的BSP,直至最后整個系統(tǒng)的成功?!?】

2  硬件平臺結構

    我們的硬件平臺采用PXA 272 作為處理器,工作頻率為512M HZ,內部集成了64 M bytes NOR Flash。Intel PXA27X處理器是Intel公司推出的32位,基于Xscale架構的高性能的嵌入式芯片?!?】硬件平臺結構中主要還包括了如下的主要器件:128 M SDRAM、AC97 codec、 LCD 控制器、IrDa芯片、藍牙UART、USB控制器。另外還集成了3.5吋、240×320 QVGA的TFT-LCD 觸摸屏、PCMCIA、SD/MMC等外設接口,WLAN模塊。

    Intel的PXA 27X內部支持SD Host的控制模塊,有SD Host控制寄存器和可以用于SD Host控制器的IO引腳,可用編程的方法對其功能進行選擇;但對于SD卡的檢測,寫保護和插槽的電源使能

    等功能沒有專門的引腳。在本文實現(xiàn)中,對于卡檢測、電源引腳,通過GPIO擴展來實現(xiàn)。和SD卡硬件相關的部分引腳定義如表1所示:【3】【4】

                 表1 PXA 272部分GPIO引腳功能定義

信號

方向

Intel 272功能引腳

說明

SD_nPWREN

輸入

SDPWEN/GPB2

SD插槽電源使能信號線

SD_DATA3

輸入/輸出

SDDATA0/GPF5

4bit模式:DATA3

SD_DATA2

輸入/輸出

SDDATA0/GPF4

4bit模式:DATA2

SD_DATA1

輸入/輸出

SDDATA0/GPE5

4bit模式:DATA1

SD_DATA0

輸入/輸出

SDDATA0/GPG2

4bit模式:DATA0

SD_CMD

輸入/輸出

SDCMD/GPG1

SD命令線

SD_CLK

輸入

SDCLK/GPF3

SDIO/SD卡時鐘線

SD_nCD

輸出

EINT23/GPF1

SD卡檢測引腳

SD_WP

輸出

GPC3

SD卡寫保護引腳

3  Bootloader的設計和實現(xiàn)

    一個嵌入式WinCE系統(tǒng)從軟件的角度看通常可以分為兩部分:Bootloader 和 Wince嵌入式系統(tǒng)。從Bootloader和Wince嵌入式系統(tǒng)的關系看,Bootloader包含兩種不同的操作模式:“本地啟動”模式和“下載啟動”模式?!?】在本地啟動模式下Bootloader從Flash上將Wince操作系統(tǒng)加載到RAM中運行。在下載啟動模式下,目標機上的Bootloader將通過串口或者網絡連接或者USB等從主機下載操作系統(tǒng)文件,也可以直接從SD/MMC卡、CF卡上加載操作系統(tǒng)鏡像文件。在下載啟動模式下,Bootloader通過串口給用戶提供簡單的命令行接口。

3.1 Bootloader的流程

    當系統(tǒng)上電后,ARM CPU會從物理地址零處開始執(zhí)行第一條指令的執(zhí)行,通常會在該地址處放置一條跳轉指令。在我們的硬件平臺中物理地址零是64M Flash的物理起始地址。這里值得需要說明的是64M Flash 是固化在Intel PXA 272中的。所以我們的Bootloader燒入也必須從Flash的物理地址零開始。Bootloader二進制文件的最前面的4個字節(jié)就是一條跳轉指令。

圖1  Bootloader 流程圖

    接著系統(tǒng)會跳轉到一段用ARM匯編編寫的代碼中去執(zhí)行。其作用是完成系統(tǒng)啟動所必須的最小配置,例如配置cpu 的工作頻率,配置GPIO,配置時鐘等。然后為我們處理器的工作模式設置棧指針。

    接著把Bootloader 從Flash搬運到SDRAM中,配置MMU,創(chuàng)建頁表,使能MMU,然后把自己后半部重定位到SDRAM中去執(zhí)行。在后半部的執(zhí)行中會根據用戶做的動作(是否按住一個按鈕)來判斷是要本地啟動還是下載啟動。具體的流程圖如圖1所示。

    當用戶選擇特定下載啟動方式后,就進入具體的下載流程。首先需要對用戶選定的介質的硬件進行必要的初始化。之前做的一些硬件的初始化是不夠的,因為沒必要在前面進行全面的硬件初始化,現(xiàn)在要具體使用了就需要進行具體的配置。

3.2 軟件實現(xiàn)的關鍵

    Bootloader是依賴于硬件而實現(xiàn)的,特別是在嵌入式系統(tǒng)中。不同的體系結構需求的Bootloader是不同的;除了體系結構,Bootloader還依賴于具體的嵌入式板級設備的配置。所以根據不同的板級配置需要修改相應的Bootloader?!?】我們使用的bootloader是Microsoft提供的和Wince配套的Eboot。下面幾點是在我們的硬件平臺上修改Eboot的關鍵。

3.2.1  配置內存映射表

    WinCE嵌入式系統(tǒng)通過定義OEMAddressTable來定義虛擬內存到物理內存的映射表.這個表在我們的實現(xiàn)中是bootloader和WinCE系統(tǒng)公用的?!?】當然這不是強制性的.我們需要根據硬件平臺的不同定制自己的映射表。在我們的設計中,這個表把4GB的物理空間映射到512M的內核虛擬空間。

    表中的每一項由虛擬地址,物理地址,和映射的M數組成。其格式如下所示

OEMAddressTable

DCD SDRAM_BASE_C_VIRTUAL,      SDRAM_BASE_PHYSICAL,       64

DCD SDRAM1_BASE_C_VIRTUAL,     SDRAM1_BASE_PHYSICAL,      64   

DCD IM_STORAGE_BASE_C_VIRTUAL, IM_STORAGE_BASE_PHYSICAL,  1

.....

DCD 0x00000000,                     0x00000000,           0 

    第一項和第二項分別使64M的虛擬地址映射到64M物理地址,因為我們采用兩條64M的SDRAM。第二項使1M的內部內存的虛擬地址映射到物理地址,因為我們使用1M大小的內部存儲。最后一項必須是零,因為建立頁表的時候程序通過它來判斷是否結束映射過程。在配置MMU的時候會使用這個表來完成虛擬地址到物理地址的映射的頁表的建立。

3.2.2    為中斷模式設置分配堆棧

    我們知道ARM的堆棧是分模式的,在程序中要為每種要用到的模式分配堆棧。如果沒有為某種模式分配堆棧,那么在進入這種模式之后系統(tǒng)不能繼續(xù)運行了。系統(tǒng)首先運行在SVC模式。在下載模式中,我們要通過USB ,網絡,SD/MMC和CF接口等下載文件,而這些都要用到中斷。所以我們要為中斷模式分配堆棧,其代碼片段如下:

ldr      r2, =(Mode_IRQ :OR: NoIntsMask)                  ;中斷模式

msr      cpsr_c,r2

ldr sp,=(EBOOT_IRQ_STACK_TOP+SDRAM_VIR_C_EBOOT_PARTITION) ;分配堆棧

    在為中斷模式分配堆棧之后,還要進行堆棧切換,使程序重新回到SVC模式運行。

3.2.3    通過SD卡加載系統(tǒng)鏡像的實現(xiàn)

    當用戶選取SD卡作為下載系統(tǒng)鏡像的目標后,bootloader就進入對SD處理的流程。首先通過SD卡檢測引腳判斷是否有SD卡插在插槽。如果有就要對SD控制的硬件進行初始化,例如SD插槽電源使能,設置時鐘,設置功能GPIO等。

    其中需要說明的是Intel PXA 272的時鐘管理比較復雜,它有兩個鎖相環(huán)路PLL:外圍設備鎖相環(huán)路,核心鎖相環(huán)路。其中外圍設備鎖相環(huán)路為外圍總線和USBC,I2S接口,SD接口等外圍設備提供時鐘。在時鐘控管理寄存器里,寄存器CKEN用來控制如USB,UART,SD等接口模塊的時鐘使能?!?】

    接著是對SD卡協(xié)議棧的軟件實現(xiàn).為了減少Bootloader中SD Host驅動的復雜性,能夠易于調試,實現(xiàn)了總線驅動模塊,客戶端驅動模塊和FAT16文件系統(tǒng)模塊。所以在我們的實現(xiàn)中對SD卡上的文件系統(tǒng)要有一定的限制,必須是格式化成FAT16的文件系統(tǒng)才能被我們的bootloader識別。當然在具體的實現(xiàn)中我們還可以使用另外的文件系統(tǒng)格式。其協(xié)議棧結構如圖2所示:

圖2 SD卡協(xié)議棧結構

3.3  實驗結果

    我們使用一個22.7M的WinCE鏡像,在Bootloader中分別用USB,SD卡,TFTP,本地四種方式使用進行加載啟動測試,分別測試了50次。因為在Bootloader中SD Host的實現(xiàn)沒有使用DMA方式,為了進行性能比較,我們又調用WinCE系統(tǒng)下使用DMA的SD Host驅動加載同樣大小的文件進行了50次測試。表2是我們測試的結果。表中數據為平均值。
                           表2  測試結果

 

SD卡

USB

TFTP

使用DMA的SD

本地啟動

加載時間(秒)

51

96

53

28

3

    從表中數據可知,本地啟動是最快的,這是不容置疑的。其次是通過SD卡啟動。另外值得說明的是,通過USB和TFTP下載啟動在都需要的在通信的另一端軟件的支持和用戶的介入操作。而SD卡的數據通信傳輸完全由硬件實現(xiàn),這也是SD卡加載相對比較快的主要原因。而且使用TFTP下載還需要進行相對復雜的配置。而在使用SD的加載中Bootloader會自動去搜尋系統(tǒng)鏡像,自動下載。這對用戶的使用來說是方便快捷的。

    另外從使用DMA的SD 驅動下載文件和Bootloader中的實現(xiàn)做比較,可以看出使用DMA后大大提高了使用SD下載的性能。當然我們也可以在Bootloader中使用DMA方式來實現(xiàn)以提高性能。但這樣一來會大大增加Bootloader的復雜性。我們在Bootloader中實現(xiàn)使用SD做加載啟動的主要目的是方便開發(fā)和調試SD硬件模塊,而且實際使用中絕大部分會是本地啟動。我們的實現(xiàn)中目的已經達到,所以可以不考慮這些。

4  結束語

     Bootloader是操作系統(tǒng)和硬件的樞紐,相對于操作系統(tǒng)內核來說它是一個硬件抽象層。嵌入式領域中操作系統(tǒng)的移植關鍵在于Bootloader的移植和操作系統(tǒng)內核硬件相關部分移植。所設計并實現(xiàn)的基于Intel PXA 272嵌入式處理器的從SD卡加載并啟動WinCE系統(tǒng)的Bootloader能提高WinCE操作系統(tǒng)移植的穩(wěn)定性并加快WinCE操作系統(tǒng)移植的周期。

     本文作者創(chuàng)新點: 在基于Intel PXA 272 處理器的bootloader中實現(xiàn)了SD卡的協(xié)議棧,并實現(xiàn)了從SD卡加載并啟動WinCE嵌入式系統(tǒng)鏡像的功能.

參考文獻:
【1】杜春雷.ARM體系結構與編程.北京:清華大學出版社 ,2004-12
【2】Intel PXA 27X Processor Family Developer's Manual[M]. Intel, 2004-04
【3】Jörg Henkel, Xiaobo Sharon Hu, Shuvra S. Bhattacharyya. Taking on the Embedded System Design Challenge[J], IEEE Computer (4): 35-37 (2003)【4】SD-Memory Card Specifications /Part1 Physical Layer Specification Version 1.01[M]. SD Group, 2001
【5】陳向群王雷 馬洪兵.Windows.CE.NET 系統(tǒng)分析及實驗教程.北京:機械工業(yè)出版社,2003
【6】萬永波 張根寶 田澤 楊峰. 基于ARM的嵌入式系統(tǒng)Bootloader啟動流程分析.微計算機信息. 2005年第11-2期.第一頁

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉