【bootloader】关于2440+WinCE5.0,2440init.s文件代码问题

2023-05-23  

刚才一个小伙子在论坛提问如下:


我在学习2440+WinCE5.0系统,正在看中断相关的。 

在文件2440init.s里找到如下代码 


    AREA    Init,CODE,READONLY 


    ENTRY  

    ;1)The code, which converts to Big-endian, should be in little endian code. 

    ;2)The following little endian code will be compiled in Big-Endian mode.  

    ;  The code byte order should be changed as the memory bus width. 

    ;3)The pseudo instruction,DCD can't be used here because the linker generates error. 

    ASSERT  :DEF:ENDIAN_CHANGE 

    b   ResetHandler    ; 0x00 Reset 

    b   .               ; 0x04 Undefined 

    b   .               ; 0x08 Supervisor 

    b   .               ; 0x0c Prefetch Abort 

    b   .               ; 0x10 Data Abort 

    b   .               ; 0x14 Reserved 

    b   .               ; 0x18 IRQ 

    b   .               ; 0x1c FIQ 


地址0x04-0x1C均无有效跳转代码,是否意味着这些异常没有使用?但是在后面又看到如下些代码,很疑惑。上面那段代码存在flash里而下面这段是在RAM里?请知道的朋友讲解一下。 


AREA RamData, DATA, READWRITE 


        ^   _ISR_STARTADDRESS 

HandleReset     #   4  

HandleUndef     #   4 

HandleSWI       #   4 

HandlePabort    #   4 

HandleDabort    #   4 

HandleReserved  #   4 

HandleIRQ       #   4 

HandleFIQ       #   4




--------------------我做了如下回答:


根据我的理解,上面的 

b   ResetHandler    ; 0x00 Reset  

    b   .               ; 0x04 Undefined  

    b   .               ; 0x08 Supervisor  

    b   .               ; 0x0c Prefetch Abort  

    b   .               ; 0x10 Data Abort  

    b   .               ; 0x14 Reserved  

    b   .               ; 0x18 IRQ  

    b   .               ; 0x1c FIQ  

还在内部SRAM 


并且这时候代码刚启动,如果发生复位以外的中断都是没有任何意义,甚至是不可取的,所以发生干脆让 ARM 死循环了,b. 


而下面的 


        AREA RamData, DATA, READWRITE  


        ^   _ISR_STARTADDRESS  

HandleReset     #   4   

HandleUndef     #   4  

HandleSWI       #   4  

HandlePabort    #   4  

HandleDabort    #   4  

HandleReserved  #   4  

HandleIRQ       #   4  

HandleFIQ       #   4 

已经是外部内存的 一些中断向量了吧,这时候代码已经在外部内存跑,会发生我们要的中断了,所以必须分配好。 

这两个环境已经不一样了。 

_ISR_STARTADDRESS 指向的地址肯定是外部物理内存的了。 


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。