ARM處理器啟動(dòng)代碼的分析與設(shè)計(jì)
出處:liudewei 發(fā)布于:2007-06-02 14:41:09
目前,ARM系列的通用32位RISC微處理器有ARM7、ARM9、ARM9E、ARM10等多個(gè)產(chǎn)品,這些處理器可以工作于7種模式下。除User模式以外的其它模式都叫做特權(quán)模式,除User和System以外的其它5種模式叫做異常模式。大部分應(yīng)用程序都在User模式下運(yùn)行,當(dāng)處理器處于User模式下時(shí),執(zhí)行的程序無(wú)法訪(fǎng)問(wèn)一些被保護(hù)的系統(tǒng)資源,以利于操作系統(tǒng)控制系統(tǒng)資源的使用,也不能改變模式,否則就會(huì)導(dǎo)致異常。對(duì)于System模式,任何異常都不會(huì)導(dǎo)致進(jìn)入這一模式,而且它使用的寄存器和User模式下基本相同,主要是用于有訪(fǎng)問(wèn)系統(tǒng)資源請(qǐng)求而又避免使用額外的寄存器的操作系統(tǒng)任務(wù)。在特權(quán)模式下,它們可以完全訪(fǎng)問(wèn)系統(tǒng)資源,可以自由地改變模式。在處理特定的異常時(shí),系統(tǒng)進(jìn)入對(duì)應(yīng)的異常模式下。這5種異常模式都有各自額外的寄存器,用于避免在發(fā)生異常的時(shí)候與用戶(hù)模式下的程序發(fā)生沖突。
&n
|
|
啟動(dòng)代碼的設(shè)計(jì)
啟動(dòng)代碼類(lèi)似于電腦中的BIOS,它從系統(tǒng)上電開(kāi)始接管CPU,依次需要負(fù)責(zé)初始化 CPU在各種模式下的堆棧空間、設(shè)定CPU的內(nèi)存映射、對(duì)系統(tǒng)的各種控制寄存器做初始化、對(duì)CPU的外部存儲(chǔ)器進(jìn)行初始化、設(shè)定各外圍設(shè)備的基地址、創(chuàng)建正確的中斷向量表、為C代碼執(zhí)行創(chuàng)建ZI(零創(chuàng)建)區(qū),然后進(jìn)入到C代碼。 在C代碼中繼續(xù)對(duì)時(shí)鐘、RS232端口進(jìn)行初始化,然后打開(kāi)系統(tǒng)中斷允許位。進(jìn)入到應(yīng)用代碼中執(zhí)行,執(zhí)行期間響應(yīng)各種不同的中斷信號(hào)并調(diào)用預(yù)先設(shè)置好的中斷服務(wù)程序處理這些中斷。整個(gè)過(guò)程的流程圖如圖1所示。

圖1 啟動(dòng)代碼流程圖
堆棧初始化
堆棧的初始化要處理的事情是為處理器的7個(gè)處理器模式分配堆棧空間。以下以FIQ模式下的堆棧設(shè)置為例說(shuō)明:
ORR r1, r0, #LOCKOUT | FIQ_MODE;把模式放在r1中,LOCKOUT用來(lái)屏蔽中斷位;
MSR cpsr, r1 ;改變CPU的CPSR寄存器,進(jìn)入到指定的FIQ模式;
MSR spsr, r2 ;保存前一模式;
LDR sp, =FIQ_STACK ;把FIQ模式下的堆棧起始值賦給當(dāng)前的SP,F(xiàn)IQ_STACK是分配給FIQ模式堆棧空間(比如說(shuō)1K字節(jié))的起始地址。按這種方式設(shè)置其它模式下的堆棧。
DRAM的初始化根據(jù)系統(tǒng)配置信息來(lái)決定,因?yàn)橄到y(tǒng)不一定會(huì)用到DRAM,但是一定要做SDRAM的初始化。主要的處理內(nèi)容是ROM和RAM基址的設(shè)定、數(shù)據(jù)總線(xiàn)的寬度、SDRAM的刷新時(shí)間等等,這些可以參照S3C4510B芯片的用戶(hù)手冊(cè)。特殊寄存器的設(shè)置主要是針對(duì)I/O口,比方說(shuō)設(shè)定幾個(gè)I/O位用做系統(tǒng)狀態(tài)指示燈LED。寄存器的設(shè)定主要根據(jù)硬件的配置情況而定,值得注意的是由于這段啟動(dòng)代碼是燒錄到ROM中的,而中斷向量必須位于零地址,所以在存儲(chǔ)單元沒(méi)有重新映射之前ROM基址的設(shè)定應(yīng)該為零地址。
拷貝(image)主要是為了提高運(yùn)行速度,編譯生成的映像文件代碼從ROM內(nèi)拷貝到RAM中去,而程序的執(zhí)行也就在RAM中。當(dāng)然,啟動(dòng)代碼對(duì)運(yùn)行速度的要求不是很?chē)?yán)格,所以這個(gè)拷貝動(dòng)作可以不用做,讓代碼存放在ROM中,代碼的執(zhí)行也在ROM中,而運(yùn)行中所需要的數(shù)據(jù)在RAM中。
內(nèi)存的初始化是為C代碼的運(yùn)行開(kāi)辟內(nèi)存區(qū),代碼編譯后會(huì)分為三個(gè)區(qū):只讀區(qū)、可讀可寫(xiě)區(qū),
|
|
中斷向量表是用于處理異常情況的,當(dāng)發(fā)生異常時(shí),首先要保存當(dāng)前程序的返回地址和CPSR寄存器的值,然后進(jìn)入到相應(yīng)的異常向量地址,一般來(lái)說(shuō)在異常向量地址是一個(gè)跳轉(zhuǎn)指令,使程序進(jìn)入相應(yīng)的異常處理過(guò)程。由于中斷向量表要位于系統(tǒng)的零地址,當(dāng)把啟動(dòng)代碼燒錄到EEPROM中運(yùn)行時(shí)就需要把ROM的地址定義到零地址,所以程序的入口處如下:
系統(tǒng)重新映射當(dāng)你為了提高運(yùn)行速度而把ROM的Image拷貝到RAM后,中斷向量表就不是在零地址處,因此要重新映射存儲(chǔ)單元,把RAM的地址重新設(shè)定為零地址。映射就是把啟動(dòng)代碼從ROM(EEPROM或者Flash)拷貝到SDRAM運(yùn)行,同時(shí)再拷貝完畢以后進(jìn)行內(nèi)存的重新映射,把SDRAM映射到原來(lái)的ROM地址(0x0000)中,這樣就可以用SDRAM中的代碼寫(xiě)Flash,使得程序代碼得以更新。但是需要注意的是,如果程序進(jìn)行了映射,這樣就對(duì)在線(xiàn)調(diào)試帶來(lái)了困難,使得在線(xiàn)調(diào)試不可以在RAM中進(jìn)行(如果寫(xiě)入EEPROM的代碼是映射了的,則在調(diào)試器啟動(dòng)的時(shí)候必然也會(huì)對(duì)程序進(jìn)行映射,使得程序在調(diào)試器中不可以定位到原來(lái)的地方,使得調(diào)試失敗)。一個(gè)折中的方法是,不進(jìn)行映射,就是說(shuō)在調(diào)試的代碼中不可以使用,這樣就可以像普通的代碼一樣進(jìn)行調(diào)試了。
結(jié) 語(yǔ)
做完這些初始化后,讓CPU切換到用戶(hù)模式下,并把堆棧指針SP指定到用戶(hù)堆棧區(qū),就可以進(jìn)入到C代碼區(qū)運(yùn)行。在C代碼中繼續(xù)對(duì)時(shí)鐘、RS232端口進(jìn)行初始化,然后打開(kāi)系統(tǒng)中斷允許位,進(jìn)入到應(yīng)用代碼中執(zhí)行。此程序加載到處S3C4510B中經(jīng)過(guò)調(diào)試,CPU可以正常啟動(dòng),能夠?qū)χ袛嗾?qǐng)求做出及時(shí)的響應(yīng),上層應(yīng)用的主代碼可以加載到Flash中,移植實(shí)時(shí)操作系統(tǒng)RTXC后對(duì)多任務(wù)的調(diào)度控制正常。
參考文獻(xiàn):
1. Steve Furber, ‘ARMSoC體系結(jié)構(gòu)’.北京航空航天大學(xué)出版社,2002.
2. 馬忠梅, ‘ARM嵌入式處理器結(jié)構(gòu)與應(yīng)用基礎(chǔ)’, 北京航空航天大學(xué)出版社,2003.
3. 李駒光, ‘ARM應(yīng)用系統(tǒng)開(kāi)發(fā)詳解—基于S3C4510B的系統(tǒng)設(shè)計(jì)’, 清華大學(xué)出版社,2003.
4. RISC datasheet http://www.hbjingang.com/datasheet/RISC_1189725.html.
5. RS232 datasheet http://www.hbjingang.com/datasheet/RS232_585128.html.
6. ROM datasheet http://www.hbjingang.com/datasheet/ROM_1188413.html.
7. S3C4510B datasheet http://www.hbjingang.com/datasheet/S3C4510B_589499.html.
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫(kù)電子市場(chǎng)網(wǎng)”的所有作品,版權(quán)均屬于維庫(kù)電子市場(chǎng)網(wǎng),轉(zhuǎn)載請(qǐng)必須注明維庫(kù)電子市場(chǎng)網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點(diǎn)或證實(shí)其內(nèi)容的真實(shí)性,不承擔(dān)此類(lèi)作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個(gè)人從本網(wǎng)轉(zhuǎn)載時(shí),必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問(wèn)題,請(qǐng)?jiān)谧髌钒l(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- ARM技術(shù)架構(gòu)與應(yīng)用開(kāi)發(fā)實(shí)踐指南2026/1/6 10:40:19
- 嵌入式實(shí)時(shí)操作系統(tǒng)(RTOS)選型與移植技術(shù)指南2025/12/31 10:42:31
- 工業(yè)嵌入式系統(tǒng):通信接口技術(shù)選型與抗干擾設(shè)計(jì)實(shí)踐2025/12/15 14:36:53
- 深入解析嵌入式 OPENAMP 框架:開(kāi)啟異核通信新時(shí)代2025/7/22 16:27:29
- 一文快速了解OPENWRT基礎(chǔ)知識(shí)2025/7/14 16:59:04
- 編碼器的工作原理及作用1
- 超強(qiáng)整理!PCB設(shè)計(jì)之電流與線(xiàn)寬的關(guān)系2
- 三星(SAMSUNG)貼片電容規(guī)格對(duì)照表3
- 電腦藍(lán)屏代碼大全4
- 國(guó)標(biāo)委發(fā)布《電動(dòng)汽車(chē)安全要求第3部分:人員觸電防護(hù)》第1號(hào)修改單5
- 通俗易懂談上拉電阻與下拉電阻6
- 繼電器的工作原理以及驅(qū)動(dòng)電路7
- 電容單位8
- 跟我學(xué)51單片機(jī)(三):?jiǎn)纹瑱C(jī)串口通信實(shí)例9
- 一種三極管開(kāi)關(guān)電路設(shè)計(jì)10
- PCB焊盤(pán)與過(guò)孔設(shè)計(jì)核心實(shí)操規(guī)范(含可焊性與可靠性保障)
- 汽車(chē)電子常用電子元器件選型指南
- MOSFET驅(qū)動(dòng)與隔離方案設(shè)計(jì)
- 高溫環(huán)境下電源IC選型建議
- 安防監(jiān)控設(shè)備連接器應(yīng)用分析
- 高速PCB信號(hào)完整性(SI)設(shè)計(jì)核心實(shí)操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計(jì)算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對(duì)系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計(jì)
- 連接器耐腐蝕性能測(cè)試方法









