當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式軟件
[導(dǎo)讀]1.引言在嵌入式開發(fā)中其中不可避免的一環(huán)就是bootloader的設(shè)計(jì)[1],它統(tǒng)籌軟硬件資源,使得資源最優(yōu)配置,嵌入式系統(tǒng)對(duì)功耗,性能,以及成本要求很苛刻,它要求在達(dá)到用戶要

1.引言

在嵌入式開發(fā)中其中不可避免的一環(huán)就是bootloader的設(shè)計(jì)[1],它統(tǒng)籌軟硬件資源,使得資源最優(yōu)配置,嵌入式系統(tǒng)對(duì)功耗,性能,以及成本要求很苛刻,它要求在達(dá)到用戶要求的前提下把成本和資源利用降為最低,Booloader不是驅(qū)動(dòng)開發(fā)的一部分,但一個(gè)好的booloader可以決定該產(chǎn)品在市場(chǎng)上的成敗[2]。

采用Samsung公司的ARM920T[3]處理器與Linux2.4.18嵌入式操作系統(tǒng),根據(jù)處理速度和效率的不同采用分階段實(shí)現(xiàn)的方法,在具體實(shí)現(xiàn)時(shí)不拘泥于該處理器和操作系統(tǒng)版本,使之更有普遍性和通用性。

2.bootloader概述

引導(dǎo)加載程序bootloader是系統(tǒng)加電后運(yùn)行的第一段代碼[4],功能類似pc機(jī)的BIOS,在ARM中一般都是位于地址0x00000000,這段代碼可以實(shí)現(xiàn)初始化硬件設(shè)備,建立內(nèi)存空間映射圖,從而將系統(tǒng)的軟硬件帶到一個(gè)合適的狀態(tài),以便最終為調(diào)用操作系統(tǒng)內(nèi)核和用戶應(yīng)用程序準(zhǔn)備好正確的環(huán)境。

Bootloader的啟動(dòng)可以單階段也可以多階段,為了方便移植和增加系統(tǒng)的執(zhí)行效率一般分為兩個(gè)階段stage1用匯編編寫和stage2用C 語(yǔ)言編寫,stage1主要進(jìn)行與CPU與存儲(chǔ)設(shè)備相關(guān)的工作進(jìn)行必要的初始化工作,是一些依賴于體系結(jié)構(gòu)的代碼,例如初始化CPU運(yùn)行的時(shí)鐘頻率,初始化Flash和內(nèi)存的數(shù)據(jù)寬度、讀/寫訪問周期和刷新周期,初始化中斷系統(tǒng),初始化系統(tǒng)中各種片內(nèi)片外設(shè)備和I/O口,初始化系統(tǒng)各種運(yùn)行模式下的寄存器和堆棧。stage2是用C語(yǔ)言實(shí)現(xiàn)一般的流程以及對(duì)板級(jí)驅(qū)動(dòng)的支持,包括初始化要用到用到的內(nèi)核映像和文件系統(tǒng)映像,并將PC指針指向操作系統(tǒng)內(nèi)核的入口處,為操作系統(tǒng)的運(yùn)行作好準(zhǔn)備。這樣設(shè)計(jì)代碼具有很好的移植性和可讀性,對(duì)于相同的CPU只需修改stage2,對(duì)于不同的CPU只需修改 stage1。

3.stage1設(shè)計(jì)

3.1.建立二級(jí)中斷向量表

每當(dāng)有中斷或者異常發(fā)生時(shí),ARM處理器便強(qiáng)制把PC指針指向向量表中對(duì)應(yīng)中斷類型的地址值。為了加快中斷響應(yīng),在Flash的0x0地址存放能跳轉(zhuǎn)到0x33ffff00地址處中斷向量的跳轉(zhuǎn)指令,即在RAM中建立一個(gè)二級(jí)中斷向量表,起始地址為0x33ffff00,除復(fù)位外,其它異常入口地址由Flash跳轉(zhuǎn)得到,部分實(shí)現(xiàn)代碼如下

#define _ISR_STARTADDRESS (SDRAM_END-0x100) //0x33ffff00

definepISR_RESET (*(unsigned *)(_ISR_STARTADDRESS+0x0))// x33ffff00

#define pISR_UNDEF (*(unsigned *)(_ISR_STARTADDRESS+0x4))// x33ffff04

如表1所示:

Flash異常向量表

0x001c

0x0018

0x0014

0c0010

0x000c

0x0008

0x0004

0x0000 FIQ

IRQ

Reserved

Data abort

Prefetch abort

SWI

Undef

Reset

SDRAM異常向量表

0x33ffff00 b HandleResethandler for Reset

0x33ffff04 b HandleUndefhandler for Undefined

0x33ffff08 b HandleSWIHander for SWI

0x33ffff0c b HandlePabortHander for Pabort

0x33ffff10B handleDabortHander for Dabort

0x33ffff14 b HandleReservedHander for Reserved

0x33ffff18 b HandleIRQhandler for IRQ

0x33ffff1c b HandleFIQ,Hander for FIQ

表1.二級(jí)中斷向量表

3.2 拷貝Stage2至RAM

習(xí)慣上把stage2拷貝到RAM地址的最頂部1MB開始的空間,RAM的起始地址為0x30000000。實(shí)現(xiàn)代碼如下所示:

/*計(jì)算stage2在flash中的位置,假設(shè)該映像不超過(guò)64K,自行可修改該值*/

Adr r0,_start

Add r2,r0,#(64*1024)

Add r0,ro,#0x1000

Ldr r1 ,BLOB_START

/*開始復(fù)制stage2到RAM,R0=源起始地址,R1=目的地址,r2源結(jié)束地址*/

copy_loop:

ldmia r0!,{r3-r10}

stmia r1!, {r3-r10}

cmp r0,r2

ble copy_loop

ldr r0,BLOB_START //復(fù)制完跳轉(zhuǎn)到RAM執(zhí)行由此入口進(jìn)入stage2

3.3.設(shè)置堆棧指針

系統(tǒng)堆棧初始化取決于用戶使用了哪些中斷,以及系統(tǒng)需要處理哪些錯(cuò)誤類型。一般情況下,管理者堆棧必須設(shè)置,如果使用了IRQ中斷,則IRQ堆棧也必須設(shè)置,下面以IRQ堆棧為例進(jìn)行設(shè)置。

IRQMode 堆棧

orr r1,r0,#IRQMODE|NOINT

msr cpsr_cxsf,r1; IRQMode

ldr sp,IRQStack

4. stage2設(shè)計(jì)

4.1.可執(zhí)行映像stage2的入口

由于在編譯和鏈接Bootloader這樣的c程序時(shí)不能使用glibc庫(kù)支持的函數(shù),所以直接把main()函數(shù)的起始地址作為第二階段的入口點(diǎn)是最直接的想法??梢杂脜R編編寫一段trampoline(彈簧床)小程序用CPU跳轉(zhuǎn)指令跳到main()函數(shù)去執(zhí)行,當(dāng)mian()函數(shù)返回時(shí)會(huì)再次回到trampoline程序,具體匯編代碼如下:

@get read to call c functions

ldr sp DW_STACK_START @ setup stack pointer

mov fp ,#0 @ no previous frame,so fp=0

mov a2, #0 @set argv to NULL

bl main @call main

mov pc,#FLASH_BASE @otherwise,reboot

如果正常不出錯(cuò)就不會(huì)再回到trampoline程序,否則就會(huì)回到最后一條語(yǔ)句重起系統(tǒng)。

4.2 內(nèi)存影射

一般s3c2410上配置的SDRSAM大小為64M,該SDRAM的物理地址范圍是0x3000 0000~0x33FF FFFF(屬于Bank 6),由于1個(gè)Section的大小是1M,所以該物理空間可以被分成64個(gè)物理段(頁(yè)框)。

由于bootloader沒有對(duì)MMU的管理代碼,處理器在運(yùn)行時(shí)直接訪問物理地址。同時(shí),因?yàn)锳RM體系結(jié)構(gòu)中數(shù)據(jù)緩沖(Dcache)必須通過(guò) MMU開啟,所以bootloader效率比較低,可通過(guò)平板映射(flat,既虛擬地址和物理地址相同)方式開啟MMU,從而使用內(nèi)存空間的 Dcache,提高bootloader的運(yùn)行速度。

如圖1所示:

 


1圖1虛擬地址到物理地址映射

映射關(guān)系代碼如下:

void mem_mapping_linear(void)[!--empirenews.page--]

{ unsigned long descriptor_index, section_base, sdram_base, sdram_size;

sdram_base=0x30000000;

sdram_size=0x 4000000;

for(section_base=sdram_base,descriptor_index=section_base>>

20;Ssection_base

{*(mmu_tlb_base+(descriptor_index))=(section_base>>20)| MMU_OTHER_SECDESC;}

}

4.3.裝載內(nèi)核映像和根文件系統(tǒng)映像

像ARM這樣的嵌入式CPU通常都是在統(tǒng)一的內(nèi)存地址空間中尋址 Flash 等固態(tài)存儲(chǔ)設(shè)備的,因此從Flash上讀取數(shù)據(jù)與從 RAM單元中讀取數(shù)據(jù)用一個(gè)簡(jiǎn)單的循環(huán)就可以完成從Flash 設(shè)備上拷貝映像的工作:

其中count為根文件系統(tǒng)映像的大小或內(nèi)核映像的大小。

While(count){

*dest++=*src++;//src為fash中的地址,dest為RAM中的地址

count-=4;}

4.4.置內(nèi)核的啟動(dòng)參數(shù)

內(nèi)核啟動(dòng)可以從Nand Flash或Nor Flash中啟動(dòng)運(yùn)行l(wèi)inux,需要修改啟動(dòng)命令如下:

#ifdef CONFIG_S3C2410_NAND_BOOT

Char Linux_cmd[]=“noinit root=/dev/bon/2 init =/Linuxrc console=tty0 console=ttys0”;

#else

CharLinux_cmd[]=“CharLinux_cmd[]=”noinit root=/dev/bon/3 init =/Linuxrc console=tty0 console=ttys0”;

其中noinitrd不使用ramdisk。

root根文件系統(tǒng)所在MTD分區(qū)。

Init內(nèi)核運(yùn)行入口命令文件。

console 內(nèi)核信息控制臺(tái),ttyS0表示串行口0。

ttys0表示虛擬終端LCD啟動(dòng)參數(shù)一般都包括root、init和console。

5.結(jié)論

設(shè)計(jì)bootloader是一項(xiàng)很復(fù)雜的工作,需要對(duì)硬件資源和所用的操作系統(tǒng)有很深的理解,在實(shí)際開發(fā)中可以根據(jù)需要簡(jiǎn)化設(shè)計(jì),去除不必要的系統(tǒng)功能,這樣可以大大提高程序執(zhí)行的效率和穩(wěn)定性。

本文作者創(chuàng)新點(diǎn):bootloader隨硬件不同設(shè)計(jì)也盡相同,但本質(zhì)的原理是一樣的,本文給出了一種層次分明設(shè)計(jì)簡(jiǎn)練較之通用的設(shè)計(jì)方法,使嵌入式工作者可以快速的了解bootloader的實(shí)現(xiàn)從而寫出符合需要的啟動(dòng)程序。

參考文獻(xiàn)

[1] 萬(wàn)永波 張根寶 田澤 楊峰,基于ARM的嵌入式系統(tǒng)Bootloader啟動(dòng)流程分析, 微計(jì)算機(jī)信息, 2005年,第21卷11-2期,90頁(yè).

[2] 嵌入式linux設(shè)計(jì)與應(yīng)用.鄒思軼. 北京:清華大學(xué)出版社 2002.

[3] SUMSUANG ELECTRONICS. S3C2410X User’s Manual[Z].Republic of Korea: Sumsang,2003.

[4] 馬學(xué)文, 朱明日, 程小輝.嵌入式系統(tǒng)中 Bootloader的設(shè)計(jì)與實(shí)現(xiàn).計(jì)算機(jī)工程,2005年,第31卷7期,96頁(yè).

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

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

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

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

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

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

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

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

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

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

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

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

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

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

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉