s3c44b0启动代码

转载 2007年09月12日 14:00:00

;****************************************************************************
; Name  : 44BINIT.S                             *
; Modified : GongJun        2004-4-26 20:26                       *
; Description:                               *
; C start up codes                                 *
; Configure memory, Initialize ISR ,stacks                       *
;   Initialize C-variables                            *
; Fill zeros into zero-initialized C-variables                      *
;****************************************************************************
 
    get option.inc
    get memcfg.inc

;****************************************************************************
;存储器空间
;GCS6 64M 16bit(8MB) DRAM/SDRAM(0xc000000-0xc7fffff)
;APP    RAM=0xc000000~0xc7effff
;44BMON RAM=0xc7f0000-0xc7fffff
;STACK    =0xc7ffa00    

;****************************************************************************
;中断控制预定义
INTPND     EQU 0x01e00004
INTMOD     EQU 0x01e00008
INTMSK     EQU 0x01e0000c
I_ISPR     EQU 0x01e00020
I_CMST     EQU 0x01e0001c

;****************************************************************************
;看门狗定时器预定义
WTCON     EQU 0x01d30000

;****************************************************************************
;系统时钟预定义
PLLCON     EQU 0x01d80000
CLKCON     EQU 0x01d80004
LOCKTIME    EQU 0x01d8000c
 
;****************************************************************************
;存储器控制预定义
REFRESH     EQU 0x01c80024

;****************************************************************************
;BDMA目的寄存器
BDIDES0     EQU 0x1f80008
BDIDES1     EQU 0x1f80028

;****************************************************************************
;预定义常数(常量)
USERMODE    EQU 0x10
FIQMODE     EQU 0x11
IRQMODE     EQU 0x12
SVCMODE     EQU 0x13
ABORTMODE   EQU 0x17
UNDEFMODE   EQU 0x1b
MODEMASK    EQU 0x1f
NOINT     EQU 0xc0

;****************************************************************************
;检查是否使用tasm.exe进行编译
    GBLL    THUMBCODE
    [ {CONFIG} = 16 
THUMBCODE SETL {TRUE}
    CODE32
    |  
THUMBCODE SETL {FALSE}
    ]

    [ THUMBCODE
    CODE32   ;for start-up code for Thumb mode
    ]

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;Vector Macro;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
    MACRO
$HandlerLabel HANDLER $HandleLabel

$HandlerLabel
    sub     sp,sp,#4   ;decrement sp(to store jump address)
    stmfd   sp!,{r0}   ;PUSH the work register to stack(lr do not push because it return to original address)
    ldr     r0,=$HandleLabel ;load the address of HandleXXX to r0
    ldr     r0,[r0]    ;load the contents(service routine start address) of HandleXXX
    str     r0,[sp,#4]   ;store the contents(ISR) of HandleXXX to stack
    ldmfd   sp!,{r0,pc}   ;POP the work register and pc(jump to ISR)
    MEND
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

    IMPORT  Main    ;The main entry of mon program

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;Code Begin;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
    AREA    Init,CODE,READONLY

    ENTRY
ResetEntry
    b ResetHandler    ;for debug
    b HandlerUndef    ;handlerUndef
    b HandlerSWI    ;SWI interrupt handler
    b HandlerPabort    ;handlerPAbort
    b HandlerDabort    ;handlerDAbort
    b .       ;handlerReserved
    b HandlerIRQ
    b HandlerFIQ
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IMPORTANT NOTE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;If the H/W vectored interrutp mode is enabled, The above two instructions should                       ;
;be changed like below, to work-around with H/W bug of S3C44B0X interrupt controller.                   ;
; b HandlerIRQ  ->  subs pc,lr,#4                                                                       ;
; b HandlerIRQ  ->  subs pc,lr,#4                                                                       ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;中断向量表
VECTOR_BRANCH
    ldr pc,=HandlerEINT0 ;mGA 0x20
    ldr pc,=HandlerEINT1 ; 
    ldr pc,=HandlerEINT2 ;
    ldr pc,=HandlerEINT3 ;
    ldr pc,=HandlerEINT4567 ;
    ldr pc,=HandlerTICK  ;mGA 0x34
 b .
 b .
    ldr pc,=HandlerZDMA0 ;mGB 0x40
    ldr pc,=HandlerZDMA1 ;
    ldr pc,=HandlerBDMA0 ;
    ldr pc,=HandlerBDMA1 ;
    ldr pc,=HandlerWDT  ;
    ldr pc,=HandlerUERR01 ;mGB 0x54
    b .
    b .
    ldr pc,=HandlerTIMER0 ;mGC 0x60
    ldr pc,=HandlerTIMER1 ;
    ldr pc,=HandlerTIMER2 ;
    ldr pc,=HandlerTIMER3 ;
    ldr pc,=HandlerTIMER4 ;
    ldr pc,=HandlerTIMER5 ;mGC 0x74
    b .
    b .
    ldr pc,=HandlerURXD0 ;mGD 0x80
    ldr pc,=HandlerURXD1 ;
    ldr pc,=HandlerIIC  ;
    ldr pc,=HandlerSIO  ;
    ldr pc,=HandlerUTXD0 ;
    ldr pc,=HandlerUTXD1 ;mGD 0x94
    b .
    b .
    ldr pc,=HandlerRTC  ;mGKA 0xa0
    b .
    b .
    b .
    b .
    b .      ;mGKA
    b .
    b .
    ldr pc,=HandlerADC     ;mGKB 0xc0
    b .      ;
    b .      ;
    b .      ;
    b .      ;
    b .      ;mGKB
    b .
    b .
    ldr pc,=EnterPWDN  ;0xe0=EnterPWDN

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;向量中断的处理方法                                                                                      ;
;Example: HandlerADC HANDLE HandleADC 解为               ;
;HandlerADC      ;HandlerADC为中断向量表的入口            ;
;   sub     sp,sp,#4   ;将sp减少一个字节,使其在堆栈高端留出存储返回地址,因为pc在寄存器组中的   ;
;        ;的位置大于r0,出栈时装入的是栈的高端的内容         ;
;   stmfd   sp!,{r0}   ;保存r0                 ;
;   ldr     r0,=HandleADC  ;装载中断处理函数的指针             ;
;   ldr     r0,[r0]    ;装载中断处理函数的地址             ;
;   str     r0,[sp,#4]   ;将中断处理函数的地址存入刚才预留的位置,r0的上面        ;
;   ldmfd   sp!,{r0,pc}   ;出栈后,pc指向的既是中断处理函数的地址           ;
;                                                                                                       ;
; INTCON^2 == 0时,vector table使能                  ;
; 发生中断->HandlerADC->HandleADC(pISR_ADC,即:_ISR_STARTADDRESS+0x20);         ;                         
; 若要在程序中处理此中断,只要将中断服务函数的指针赋给pISR_ADC,如:pISR_ADC = (int)ADCIsr                   ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;复位中断处理函数                       ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
ResetHandler
    ldr     r0,=WTCON     ;禁止看门狗
    ldr     r1,=0x0   
    str     r1,[r0]

    ldr     r0,=INTMSK
    ldr     r1,=0x07ffffff  ;禁止所有中断
    str     r1,[r0]

    ;以下三段设置时钟控制寄存器
    ldr  r0,=LOCKTIME
    ldr  r1,=0xfff
    str  r1,[r0]

    [ PLLONSTART
 ldr  r0,=PLLCON   ;锁相环倍频设定
    ldr  r1,=((M_DIV<<12)+(P_DIV<<4)+S_DIV)  ;设定系统主时钟频率
 str  r1,[r0]
    ]

    ldr     r0,=CLKCON  
    ldr     r1,=0x7ff8     ;所有功能单元块时钟使能
    str     r1,[r0]
 
 ;****************************************************
 ;change BDMACON reset value for BDMA                *
 ;****************************************************
    ldr     r0,=BDIDES0      
    ldr     r1,=0x40000000   ;BDIDESn reset value should be 0x40000000 
    str     r1,[r0]

    ldr     r0,=BDIDES1     
    ldr     r1,=0x40000000   ;BDIDESn reset value should be 0x40000000 
    str     r1,[r0]

    ;****************************************************
    ;设定存储器控制寄存器                 *  
    ;****************************************************
 adr r0, ResetHandler
 ldr r1, =ResetHandler
 sub r0, r1, r0  
 ldr r1, =SMRDATA
 sub r0, r1, r0
 ldmia   r0, {r1-r13}
 ldr     r0, =0x01c80000   ;BWSCON Address
 stmia   r0, {r1-r13} 

    ;****************************************************
    ;初始化堆栈                     *
    ;****************************************************
    ldr     sp, =SVCStack  ;复位后位SVC模式
    bl     InitStacks

    ;****************************************************
    ;设置中断处理                    *
    ;****************************************************
    ldr     r0,=HandleIRQ  ;This routine is needed
    ldr     r1,=IsrIRQ   ;if there is not 'subs pc,lr,#4' at 0x18, 0x1c
    str     r1,[r0]

    ;****************************************************
    ;拷贝并粘贴 RW data/zero initialized data             *
    ;****************************************************
 adr  r0, ResetEntry     
 ldr  r1, BaseOfROM
 cmp  r0, r1
 ldreq r0, TopOfROM
 beq  InitRamData
 
 ;****************************************************
 ;计算拷贝程序在flash中的实际位置         *
 ;****************************************************
 ldr  r2, =CopyProcBeg
 sub  r1, r2, r1
 add  r0, r0, r1 
 ldr  r3, =CopyProcEnd
 
 ;****************************************************
 ;将拷贝程序复制到ram中        *
 ;****************************************************

 ldmia r0!, {r4-r7}
 stmia r2!, {r4-r7}
 cmp  r2, r3
 bcc  %B0 
 
 ;********************************************************
 ;开始用ram中的拷贝程序复本将所有剩下的代码复制到ram中 *
 ;********************************************************
 ldr  r3, TopOfROM  
 ldr  pc, =CopyProcBeg
 
 ;********************************************************
 ;本段将代码由实际烧入的地址拷贝到ro-base所指定的位置 *
 ;只拷贝CopyProcEnd以后的代码       *
 ;********************************************************
CopyProcBeg 

 ldmia r0!, {r4-r11}
 stmia r2!, {r4-r11}
 cmp  r2, r3
 bcc  %B0 
CopyProcEnd
 
 sub  r1, r2, r3
 sub  r0, r0, r1  
 
InitRamData 
 ldr  r2, BaseOfBSS
 ldr  r3, BaseOfZero 
0
 cmp  r2, r3
 ldrcc r1, [r0], #4
 strcc r1, [r2], #4
 bcc  %B0 

 mov  r0, #0
 ldr  r3, EndOfBSS

 cmp  r2, r3
 strcc r0, [r2], #4
 bcc  %B1   
        
    [ :LNOT:THUMBCODE
 BL  Main     ;从汇编进入C语言代码空间,不要使用main()
 B .      
    ]

    [ THUMBCODE      ;for start-up code for Thumb mode
 orr     lr,pc,#1
 bx      lr
 CODE16
 bl      Main     ;从汇编进入C语言代码空间,不要使用main()
 b       .
 CODE32
    ]
   
   
;********************************************* 
 
   EXPORT  initIRQ  ;启动IRQ
initIRQ
  
    mrs r0, cpsr
    and r0, r0,#0x7f 
    msr cpsr_cxsf, r0 
   
 MOV     PC,LR
     
   
;********************************************* 

   
 LTORG
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;中断向量表                                                                                       ;
;Example: HandlerADC HANDLE HandleADC 解为               ;
;HandlerADC      ;HandlerADC为中断向量表的入口           ;
;   sub     sp,sp,#4   ;将sp减少一个字节,使其在堆栈高端留出存储返回地址,因为pc在寄存器组中的 ;
;        ;的位置大于r0,出栈时装入的是栈的高端的内容        ;
;   stmfd   sp!,{r0}   ;保存r0                 ;
;   ldr     r0,=HandleADC  ;装载中断处理函数的指针             ;
;   ldr     r0,[r0]    ;装载中断处理函数的地址             ;
;   str     r0,[sp,#4]   ;将中断处理函数的地址存入刚才预留的位置,r0的上面      ;
;   ldmfd   sp!,{r0,pc}   ;出栈后,pc指向的既是中断处理函数的地址         ;
;                                                                                                       ;
; INTCON^2 == 0时,vector table使能                 ;
; 发生中断->HandlerADC->HandleADC(pISR_ADC,即:_ISR_STARTADDRESS+0x20);        ;                         
; 若要在程序中处理此中断,只要将中断服务函数的指针赋给pISR_ADC,如:pISR_ADC = (int)ADCIsr             ;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
HandlerFIQ  HANDLER HandleFIQ
HandlerIRQ  HANDLER HandleIRQ
HandlerUndef HANDLER HandleUndef
HandlerSWI  HANDLER HandleSWI
HandlerDabort HANDLER HandleDabort
HandlerPabort HANDLER HandlePabort

HandlerADC  HANDLER HandleADC
HandlerRTC  HANDLER HandleRTC
HandlerUTXD1 HANDLER HandleUTXD1
HandlerUTXD0 HANDLER HandleUTXD0
HandlerSIO  HANDLER HandleSIO
HandlerIIC  HANDLER HandleIIC
HandlerURXD1 HANDLER HandleURXD1
HandlerURXD0 HANDLER HandleURXD0
HandlerTIMER5 HANDLER HandleTIMER5
HandlerTIMER4 HANDLER HandleTIMER4
HandlerTIMER3 HANDLER HandleTIMER3
HandlerTIMER2 HANDLER HandleTIMER2
HandlerTIMER1 HANDLER HandleTIMER1
HandlerTIMER0 HANDLER HandleTIMER0
HandlerUERR01 HANDLER HandleUERR01
HandlerWDT  HANDLER HandleWDT
HandlerBDMA1 HANDLER HandleBDMA1
HandlerBDMA0 HANDLER HandleBDMA0
HandlerZDMA1 HANDLER HandleZDMA1
HandlerZDMA0 HANDLER HandleZDMA0
HandlerTICK  HANDLER HandleTICK
HandlerEINT4567 HANDLER HandleEINT4567
HandlerEINT3 HANDLER HandleEINT3
HandlerEINT2 HANDLER HandleEINT2
HandlerEINT1 HANDLER HandleEINT1
HandlerEINT0 HANDLER HandleEINT0

;***********************************************
 IMPORT |Image$$RO$$Base| ; ROM code start 
 IMPORT |Image$$RO$$Limit| ; RAM data starts after ROM program
 IMPORT |Image$$RW$$Base| ; Pre-initialised variables
 IMPORT |Image$$ZI$$Base| ; uninitialised variables
 IMPORT |Image$$ZI$$Limit| ; End of variable RAM space


BaseOfROM DCD |Image$$RO$$Base|
TopOfROM DCD |Image$$RO$$Limit|
BaseOfBSS DCD |Image$$RW$$Base|
BaseOfZero DCD |Image$$ZI$$Base|
EndOfBSS DCD |Image$$ZI$$Limit|

 EXPORT GetBaseOfROM
 EXPORT GetEndOfROM
 EXPORT GetBaseOfBSS
 EXPORT GetBaseOfZero
 EXPORT GetEndOfBSS
 
GetBaseOfROM
 ldr  r0, BaseOfROM
 mov  pc, lr 
GetEndOfROM
 ldr  r0, TopOfROM
 mov  pc, lr
GetBaseOfBSS
 ldr  r0, BaseOfBSS
 mov  pc, lr
GetBaseOfZero
 ldr  r0, BaseOfZero
 mov  pc, lr
GetEndOfBSS
 ldr  r0, EndOfBSS
 mov  pc, lr

;****************************************************
;* The function for initializing stack    *
;****************************************************
InitStacks
 ;Do not use DRAM,such as stmfd,ldmfd......
 ;SVCstack is initialized before
 ;Under toolkit ver 2.50, 'msr cpsr,r1' can be used instead of 'msr cpsr_cxsf,r1'

    mrs     r0,cpsr
    bic     r0,r0,#MODEMASK
    orr     r1,r0,#UNDEFMODE|NOINT
    msr     cpsr_cxsf,r1   ;UndefMode
    ldr     sp,=UndefStack
 
    orr     r1,r0,#ABORTMODE|NOINT
    msr     cpsr_cxsf,r1       ;AbortMode
    ldr     sp,=AbortStack

    orr     r1,r0,#IRQMODE|NOINT
    msr     cpsr_cxsf,r1       ;IRQMode
    ldr     sp,=IRQStack
 
    orr     r1,r0,#FIQMODE|NOINT
    msr     cpsr_cxsf,r1       ;FIQMode
    ldr     sp,=FIQStack

 orr r1, r0, #SVCMODE
 msr cpsr_cxsf, r1  ;SVCMode
 ldr sp, =SVCStack

 ;USER mode is not initialized.
    mov     pc,lr ;The LR register may be not valid for the mode changes.
   
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;非向量中断的处理                        ;
;如果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       ;reserved for PC
    stmfd   sp!,{r8-r9}  

 ;IMPORTANT CAUTION
 ;if I_ISPC is not used properly, I_ISPR can be 0 in this routine.

    ldr     r9,=I_ISPR
    ldr     r9,[r9]

 cmp  r9, #0x0 ;If the IDLE mode work-around is used,
      ;r9 may be 0 sometimes.
 beq  %F2

    mov     r8,#0x0
0
    movs    r9,r9,lsr #1
    bcs     %F1
    add     r8,r8,#4
    b     %B0

1
    ldr     r9,=HandleADC
    add     r9,r9,r8
    ldr     r9,[r9]
    str     r9,[sp,#8]
    ldmfd   sp!,{r8-r9,pc}

2
 ldmfd sp!,{r8-r9}
 add  sp,sp,#4
 subs pc,lr,#4

;****************************************************
;* The function for entering power down mode  *
;****************************************************
;void EnterPWDN(int CLKCON);
EnterPWDN
    mov     r2,r0               ;r0=CLKCON
    ldr     r0,=REFRESH  
    ldr     r3,[r0]
    mov     r1, r3
    orr     r1, r1, #0x400000   ;self-refresh enable
    str     r1, [r0]

    nop     ;Wait until self-refresh is issued. May not be needed.
    nop     ;If the other bus master holds the bus, ...
    nop     ; mov r0, r0
    nop
    nop
    nop
    nop

;enter POWERDN mode
    ldr     r0,=CLKCON
    str     r2,[r0]

;wait until enter SL_IDLE,STOP mode and until wake-up
    mov     r0,#0xff
0   subs    r0,r0,#1
    bne     %B0

;exit from DRAM/SDRAM self refresh mode.
    ldr     r0,=REFRESH
    str     r3,[r0]
    mov     pc,lr
   
   
    EXPORT DisableInt
DisableInt
 mrs r0, cpsr
 orr r0, r0, #NOINT
 msr cpsr_cf, r0
 mov pc, lr
 
 EXPORT EnableInt
EnableInt
 mrs r0, cpsr
 bic r0, r0, #NOINT
 msr cpsr_cf, r0
 mov pc, lr
   

    LTORG

SMRDATA DATA
;*****************************************************************
; Memory configuration has to be optimized for best performance  *
; The following parameter is not optimized.                      *
;*****************************************************************

;*** memory access cycle parameter strategy ***
; 1) Even FP-DRAM, EDO setting has more late fetch point by half-clock
; 2) The memory settings,here, are made the safe parameters even at 66Mhz.
; 3) FP-DRAM Parameters:tRCD=3 for tRAC, tcas=2 for pad delay, tcp=2 for bus load.
; 4) DRAM refresh rate is for 40Mhz.

;bank0 16bit BOOT ROM SST39VF160/SST39VF320
;bank1 8bit Nand Flash K9F2808U0A/K9F5608U0A
;bank2 16bit USB1.1 PDIUSBD12
;bank3 RTL8019
;bank4 No Uesed
;bank5 No Uesed
;bank6 16bit SDRAM
;bank7 16bit SDRAM
;    [ BUSWIDTH=16
;  DCD 0x11111111 ;Bank0=OM[1:0], Bank0~Bank7=16bit
;  DCD 0x11111001 ;Bank0=OM[1:0]  16bit BootRomSST39VF160/SST39VF320) :0x0
;             |||||||-  Bank1=8bit Nand Flash
;             |||||---  Bank2=8bit PDIUSBD12
;             ||||----  Bank3=16bit RTL8019
;             |||-----  Bank4~5=16bit No Uesd
;             --------  Bank6~7=16bit SDRAM
   [ BUSWIDTH=16   
 DCD 0x11110002 ;Bank0=16bit BootRom(AT29C010A*2) :0x0
    | ;BUSWIDTH=32
 DCD 0x22222220 ;Bank0=OM[1:0], Bank1~Bank7=32bit
    ]
 
 DCD  ((B0_Tacs<<13)+(B0_Tcos<<11)+(B0_Tacc<<8)+(B0_Tcoh<<6)+(B0_Tah<<4)+(B0_Tacp<<2)+(B0_PMC)) ;GCS0
 DCD  ((B1_Tacs<<13)+(B1_Tcos<<11)+(B1_Tacc<<8)+(B1_Tcoh<<6)+(B1_Tah<<4)+(B1_Tacp<<2)+(B1_PMC)) ;GCS1
 DCD  ((B2_Tacs<<13)+(B2_Tcos<<11)+(B2_Tacc<<8)+(B2_Tcoh<<6)+(B2_Tah<<4)+(B2_Tacp<<2)+(B2_PMC)) ;GCS2
 DCD  ((B3_Tacs<<13)+(B3_Tcos<<11)+(B3_Tacc<<8)+(B3_Tcoh<<6)+(B3_Tah<<4)+(B3_Tacp<<2)+(B3_PMC)) ;GCS3
 DCD  ((B4_Tacs<<13)+(B4_Tcos<<11)+(B4_Tacc<<8)+(B4_Tcoh<<6)+(B4_Tah<<4)+(B4_Tacp<<2)+(B4_PMC)) ;GCS4
 DCD  ((B5_Tacs<<13)+(B5_Tcos<<11)+(B5_Tacc<<8)+(B5_Tcoh<<6)+(B5_Tah<<4)+(B5_Tacp<<2)+(B5_PMC)) ;GCS5
 
 [ BDRAMTYPE="DRAM"
 DCD  ((B6_MT<<15)+(B6_Trcd<<4)+(B6_Tcas<<3)+(B6_Tcp<<2)+(B6_CAN)) ;GCS6 check the MT value in parameter.a
 DCD  ((B7_MT<<15)+(B7_Trcd<<4)+(B7_Tcas<<3)+(B7_Tcp<<2)+(B7_CAN)) ;GCS7
 | ;"SDRAM"
 DCD  ((B6_MT<<15)+(B6_Trcd<<2)+(B6_SCAN)) ;GCS6
 DCD  ((B7_MT<<15)+(B7_Trcd<<2)+(B7_SCAN)) ;GCS7
 ]
 
 DCD  ((REFEN<<23)+(TREFMD<<22)+(Trp<<20)+(Trc<<18)+(Tchr<<16)+REFCNT) ;REFRESH RFEN=1, TREFMD=0, trp=3clk, trc=5clk, tchr=3clk,count=1019
 DCD  0x10   ;SCLK power down mode, BANKSIZE 32M/32M
 DCD  0x20   ;MRSR6 CL=2clk
 DCD  0x20   ;MRSR7

 ALIGN

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;RW BEGIN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
 AREA RamData, DATA, READWRITE

 ^ (_ISR_STARTADDRESS-0x500)
    
UserStack  # 256 ;c1(c7)ffa00
SVCStack  # 256 ;c1(c7)ffb00
UndefStack  # 256 ;c1(c7)ffc00
AbortStack  # 256 ;c1(c7)ffd00
IRQStack  # 256 ;c1(c7)ffe00
FIQStack  # 0 ;c1(c7)fff00


  ^ _ISR_STARTADDRESS
HandleReset  # 4
HandleUndef  # 4
HandleSWI  # 4
HandlePabort # 4
HandleDabort # 4
HandleReserved # 4
HandleIRQ  # 4
HandleFIQ  # 4

;Do not use the label 'IntVectorTable',
;because armasm.exe can not recognize this label correctly.
;the value is different with an address you think it may be.
;IntVectorTable
HandleADC  # 4
HandleRTC  # 4
HandleUTXD1  # 4
HandleUTXD0  # 4
HandleSIO  # 4
HandleIIC  # 4
HandleURXD1  # 4
HandleURXD0  # 4
HandleTIMER5 # 4
HandleTIMER4 # 4
HandleTIMER3 # 4
HandleTIMER2 # 4
HandleTIMER1 # 4
HandleTIMER0 # 4
HandleUERR01 # 4
HandleWDT  # 4
HandleBDMA1  # 4
HandleBDMA0  # 4
HandleZDMA1  # 4
HandleZDMA0  # 4
HandleTICK  # 4
HandleEINT4567 # 4
HandleEINT3  # 4
HandleEINT2  # 4
HandleEINT1  # 4
HandleEINT0  # 4   ;0xc1(c7)fff84

  END

 

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

问题一:什么是向量式中断处理和非向量式中断处理 解答:向量式中断处理是有硬件判断优先级,这个硬件逻辑提供矢量表的一条跳转指令放到0x1C或0x18,这个地址提供了相应服务程序的跳转指令。 ;中断向...
  • conjimmy
  • conjimmy
  • 2012年08月17日 11:33
  • 653

S3C44B0的中断模式

S3C44B0的向量中断模式概念   注:arm7的工作模式是arm7的这个内核提供的,而厂商在生产时,在arm7这个内核的基础上,外扩了各种中断及其相关的中断控制器,而这些中断发生一般会进入I...
  • qingfengtsing
  • qingfengtsing
  • 2014年01月21日 23:01
  • 1059

STM32学习笔记(6): 启动代码(Startup Code)

本文将对ST官网提供的关于STM32F429的启动代码(在startup_stm32f429xx.s文件中)作出详细的解释,希望能够起到抛砖引玉的作用,帮助大家理解ST其他型号MCU的启动代码。由于启...
  • Cacti_one
  • Cacti_one
  • 2017年05月30日 19:28
  • 548

关于S3C44B0中断的具体的启动代码解释

关于中断的具体的启动代码解释:       可以这么理解,44B0 中断系统中有两张中断转移表,经过二重转移才跳到中断处理程序。第一张中断向量表由硬件决定,所在区域为ROM(flash),地址空间...
  • qingfengtsing
  • qingfengtsing
  • 2014年01月21日 22:52
  • 649

S3C44B0

S3C44B0
  • songfengcn
  • songfengcn
  • 2010年06月25日 12:32
  • 161

S3C2440启动代码详细注释

功能:作为C程序启动代码,配置内存、中断向量、栈,初始化C语言环境变量 大概流程: 1.定义处理器模式及各模式的堆栈指针常量用于初始化堆栈sp(R13) 2.设置处理器模式 3.宏定义MO...
  • jijikiki
  • jijikiki
  • 2012年02月19日 20:08
  • 2922

对Keil MDK 启动代码的理解

http://blog.sina.com.cn/s/blog_701d4b0601014vn2.html 对Keil MDK 启动代码的理解  (2012-09-18 19:15:...
  • weichushun
  • weichushun
  • 2016年01月12日 07:28
  • 404

单片机启动代码详解

启动代码通常都烧写在flash中,它是系统一上电就执行的一段程序,它运行在任何用户c代码之前。上电后,arm处理器处于arm态,运行于管理模式,同时系统所有中断被禁止,pc到地址0处取指令执行。一个可...
  • lyn620
  • lyn620
  • 2015年02月09日 20:57
  • 1295

ARM启动代码(适用于arm9)

启动代码是几乎是每个arm程序程序必备的,刚开始看的时候看别人的启动代码时感觉云里雾里,所以懒惰的想法浮现脑中:别人都写好了我还写什么,直接拿来用不就行了,对在我懂得情况下,我一定会拿来就用,但是现在...
  • dinghu721521
  • dinghu721521
  • 2010年12月17日 16:49
  • 1037

手把手之STM32启动代码

http://blog.chinaunix.net/uid-29270124-id-5747094.html 对于熟悉电脑的伙伴们来说,BIOS(那个蓝色的界面)可能不会太陌生吧,这货就是电脑的...
  • Stephen_yu
  • Stephen_yu
  • 2017年05月09日 09:07
  • 647
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:s3c44b0启动代码
举报原因:
原因补充:

(最多只允许输入30个字)