s3c44B0的启动代码44b0init.S的中断分析(3)

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            ;返回

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/a307775f8ce4a63827b43770b5298b97.html