新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 基于ARM的硬件啟動(dòng)程序設(shè)計(jì)-分配中斷向量表

基于ARM的硬件啟動(dòng)程序設(shè)計(jì)-分配中斷向量表

作者: 時(shí)間:2016-11-10 來源:網(wǎng)絡(luò) 收藏
ARM要求中斷向量表必須防放置在從0x00000000地址開始的連續(xù)32字節(jié)的空間內(nèi)。ARM9定義的中斷向量在向量表中的地址如下面所示:

本文引用地址:http://2s4d.com/article/201611/317201.htm

當(dāng)中斷發(fā)生后,ARM處理器會(huì)強(qiáng)制把PC指針指向中斷向量表中對(duì)應(yīng)的終端類型的地址處。

中斷向量表的程序設(shè)計(jì)如下:

CODE32
AREA Startup,CODE,READONLY
; /* 異常向量表 */
Vectors
LDR PC, ResetAddr ;把ResetAdde地址上的存儲(chǔ)器的內(nèi)容裝載到PC上
LDR PC, UndefinedAddr
LDR PC, SWI_Addr
LDR PC, PrefetchAddr
LDR PC, DataAbortAddr
DCD 0
LDR PC, IRQ_Addr
LDR PC, FIQ_Addr

ResetAddr DCD ResetInit;為ResetAddr分配以ResetInit地址值,
UndefinedAddr DCD Undefined
SWI_Addr DCD SoftwareInterrupt
PrefetchAddr DCD PrefetchAbort
DataAbortAddr DCD DataAbort
Nouse DCD 0
IRQ_Addr DCD IRQ_Exception
FIQ_Addr DCD FIQ_Handler

對(duì)ResetAddr而言,此時(shí)ResetAddr實(shí)質(zhì)上只作為一個(gè)指針(指向ResetInit),沒有分配空間,ResetAddr地址的存儲(chǔ)器上裝載的是ResetInit的地址。

ResetInit
BL InitStack ; 初始化堆棧
BL TargetBusInit ; 總線系統(tǒng)初始化 (函數(shù)中不允許堆棧操作)
BLTargetResetInit; 針對(duì)目標(biāo)板的系統(tǒng)初始化

以ResetInit為例,存儲(chǔ)器空間分配如下所示:

注意中斷向量表要存放在代碼段startup的開始處(Entry開始),而程序被鏈接時(shí),該startup代碼段被鏈接在整個(gè)程序的入口地址。



評(píng)論


技術(shù)專區(qū)

關(guān)閉