AREA Init,CODE,READONLY
ENTRY
0 b ResetHandler ;for debug
4 b HandlerUndef ;handlerUndef
8 b HandlerSWI ;SWI interrupt handler
0x0C b HandlerPabort ;handlerPAbort
0x10 b HandlerDabort ;handlerDAbort
0x14 b . ;handlerReserved
0x18 b HandlerIRQ 这里会被替换
0x1C b HandlerFIQ
HandlerFIQ HANDLER HandleFIQ
HandlerIRQ HANDLER HandleIRQ
HandlerUndef HANDLER HandleUndef
HandlerSWI HANDLER HandleSWI
HandlerDabort HANDLER HandleDabort
HandlerPabort HANDLER HandlePabort
HandlerADC HANDLER HandleADC HandleADC刚好是IRQ中断处理表的首址,为了和非向量式中断处理的逻辑符合
HandlerRTC HANDLER HandleRTC
HandlerUTXD1 HANDLER HandleUTXD1
HandlerUTXD0 HANDLER HandleUTXD0
HandlerSIO HANDLER HandleSIO
HandlerIIC HANDLER HandleIIC
。
。
。
——————————————————————————————————————————————————————
那什么是非向量式中断呢?
解答:非向量式中断就是不用硬件判断,而改用软件(44b0init.s里)判断,如下:
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;非向量中断的处理 ;
;如果I_ISPC的使用不正确,此时I_ISPR可能为零 ;
;堆栈内容的变化 ;
; ;
;H sp |--| |--| |--| |--| sp |--| ;
; | | sp | | | | |ad|->pc | | ;
; | | | | |r9| |r9|->r9 | | ;
;L | | | | sp |r8| sp |r8|->r8 | | ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
IsrIRQ ;using I_ISPR register.
sub sp,sp,#4 ;预留返回指针的存储位置
stmfd sp!,{r8-r9}
ldr r9,=I_ISPR
ldr r9,[r9] ;载入I_ISPR
cmp r9, #0x0 ;If the IDLE mode work-around is used,r9 may be 0 sometimes.
beq %F2 ;无可处理中断,返回
mov r8,#0x0 ;r8为偏移量,清零
0
movs r9,r9,lsr #1 ;从右向左逐位检验
bcs %F1
add r8,r8,#4 ;偏移量累加
b %B0
1
ldr r9,=HandleADC ;中断处理表的首址
add r9,r9,r8 ;计算中断处理表的入口地址 r9+r8,即装载中断处理函数的指针
ldr r9,[r9] ;装载中断处理函数的地址
str r9,[sp,#8] ;将中断处理函数的地址存入刚才预留的位置,r8和r9的上面
ldmfd sp!,{r8-r9,pc} ;出栈后,pc指向的既是中断处理函数的地址
2
ldmfd sp!,{r8-r9} ;恢复r8,r9
add sp,sp,#4 ;恢复栈指针
subs pc,lr,#4 ;返回