⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 inflashokeb40800init.s

📁 at91arm7处理器的启动源码
💻 S
字号:
;初始化后COL1…COL4锁成0
;PIO中断时处理键的扫描、去抖、处理
;100X XXXX,读写键盘,防止对LCD操作


;LCD的操作中
;XXXX 1111,还可以禁止键盘

		AREA BOOTROM, CODE, READONLY
;0x0000
AT91_MEM        EQU     0xFFE00000 ; Memory controller
MEM_RCR         EQU     0xFFE00020 ; remap control register


ONCHIP_RAM      EQU     0x00300000 ; Onchip SRAM base address (REBOOT mode)
CODE_SRAM       EQU     0X02000000;SRAM ON BORAD


Mode_USR        EQU     0x10
Mode_IRQ        EQU     0x12
Mode_SVC        EQU     0x13

I_Bit           EQU     0x80
F_Bit           EQU     0x40


BOOTROMREG      EQU     0x0100203E
;NCS0-Flash ROM
;0x0100203E
;0x0100
;%0010,0000
;%0011,1110
;0x01000000(0x-0 0000-0xF FFFF)use 0-7FFFF, 1MB (A0-A19),0 cycles added after transfer, 8 wait states 225ns ,8-bit,

CSR1DEF         EQU     0x02003001
;NCS1-SRAM
;0x02000000(0x00000-3FFFF), NO TDF,1MB(A0-A19),0 cycles added after transfer, no wait states,16-bit,
;upper and lower byte with two select lines, and separate read write signals.

CSR2DEF         EQU     0x20000086
;disable 0x20000000,NO TDF,4MB, 8-bit, 0 wait state

CSR3DEF         EQU     0x30000082 
;disable 0x30000000,NO TDF,4MB, 8-bit,  0 wait state

CSR4DEF         EQU     0x40002002
;LCD and keyboard 
;=>8-bit  1tdf 0 waitstate
;0x4000203E
;0x4000
;%0010,0000
;%0000,0010
;0x40000000(0x0000-0xFFFF), 1MB (A0-A19),0 cycles added after transfer,  0 wait states,8-bit,


CSR5DEF         EQU     0x500000BD ;disable 0x50000000,NO TDF,4MB, 16-bit, 8 wait state
CSR6DEF         EQU     0x60000000 ;disable 0x60000000, 
CSR7DEF         EQU     0x70000000 ;disable 0x70000000, 
MCRDEF          EQU     0x00000007 ;4 memory regions only, standard read

;%_ _ _ _,_ _ _ _
;%_ _ _ _,0 0 0 0(BA)
;%0 0 1(CSEN)0(BAT),_ _ _(TDF)_(PAGES)
;%_(PAGES)0 1(WSE)_,_ _(NWS)_ _(DBW)

USART0  EQU  0xFFFD0000


TC_1_BASE       EQU      0xFFFE0040
TC_2_BASE       EQU      0xFFFE0080

TC_BCR          EQU      0xFFFE00C0
TC_BMR          EQU      0xFFFE00C4

;Time Counter 1 IRQ
AIC_SMR5        EQU      0xFFFFF014
AIC_SVR5        EQU      0xFFFFF094

;PIO IRQ
AIC_SMR8        EQU      0xFFFFF020
AIC_SVR8        EQU      0xFFFFF0A0


AIC_IECR       EQU       0xFFFFF120 
AIC_IDCR       EQU       0xFFFFF124

AIC_BASE         EQU   0xFFFFF000
AIC_EOICR        EQU   0x130

PIO_BASE       EQU       0xFFFF0000
P0_P7MASK EQU  0xFFFFFF00

C_ADD    EQU   0x10000010
D_ADD    EQU   0x10000110  

;External SRAM
RAM_Limit       EQU     0x0204FFFF      ;SRAM end
;?????????????????????????????????????????????????

;RAM_Limit       EQU     0x00001FFF      ;on chip SRAM end
;RAM_Limit       EQU     0x00301FFF      ;on chip SRAM end


IRQ_Stack       EQU     RAM_Limit       ; 1K IRQ stack at top of memory
SVC_Stack       EQU     RAM_Limit-2048  ; followed by SVC stack 0x1F7FF
USR_Stack       EQU     SVC_Stack-2048  ; followed by USR stack 0x1EFFF

;SVC_Stack       EQU     RAM_Limit-200  ; followed by SVC stack 0x1F7FF
;USR_Stack       EQU     SVC_Stack-200  ; followed by USR stack 0x1EFFF

num_stack       EQU     USR_Stack-2048-3
                      ;10位,first cell cntain the current position 0xe7fc
command_stack   EQU     num_stack-80;0xE7aC



send_bufffer     EQU  0x0200e600;e75c
receive_bufffer  EQU  0x0200e500;


;internal SRAM

LCDx_y   EQU     0x00000F00

cur_downkey       EQU     0x00000F10;(keynumber) waitting for the key up
;Last time have key down? FLAG                       (R0)
cur_column        EQU     0x00000F14; addr of column now scaning (r3)

cur_num  EQU     0x00000F20
set_num_return    EQU     0x00000F24



addr_download     EQU     0x00000F88;start address of download
secsize_download  EQU     0x00000F8C;sector size of download


;external ROM

;@@@@@@@@@@@@@@@@@@@@@@@@@@

m_start  EQU  0x01002ed4;########key\scan_KEY\scan_key.s
;***************************
addr_AIC_SVR5 EQU 0x000002b8;#########
addr_AIC_SVR8 EQU 0x02010000

		ENTRY
vectors
		B       resetvec ; reqset
		B       undefvec ; Udef
		B       swivec   ; SW
		B       pabtvec  ; P abt
		B       dabtvec  ; D abt
		B       rsvdvec  ; reserved
               ldr     pc, [pc,#-&F20] ; IRQ : read the Advanced Interrupt Controller
               ldr     pc, [pc,#-&F20] ; FIQ : read the Advanced Interrupt Controller


resetvec

		;point at the base address
		LDR     r0, =AT91_MEM
		;program chip select and memory control registers
		LDR     r1, =BOOTROMREG
		STR     r1, [r0, #0]
		LDR     r1, =CSR1DEF
		STR     r1, [r0, #4]
		LDR     r1, =CSR2DEF
		STR     r1, [r0, #8]
		LDR     r1, =CSR3DEF
		STR     r1, [r0, #12]
		LDR     r1, =CSR4DEF
		STR     r1, [r0, #16]
		LDR     r1, =CSR5DEF
		STR     r1, [r0, #20]
		LDR     r1, =CSR6DEF
		STR     r1, [r0, #24]
		LDR     r1, =CSR7DEF
		STR     r1, [r0, #28]
		LDR     r1, =MCRDEF     ;Memory Control Register
		STR     r1, [r0, #36]
copytosram
		; copy first 2048 bytes of ROM to internal SRAM
		; r0 destination address
		; r1 source address
		; r2 end of source address
		; r3 corrupted

		LDR     r0, =ONCHIP_RAM
		MOV     r1, #0
                ldr     r2,=0x0f00

		; r0 destination address
		; r1 source address
		; r2 end of source address
		; r3 Temporary register
copyloop
		CMP     r1,r2
		BGE     remap
		LDR     r3,[r1],#4
		STR     r3,[r0]
		LDR     r3,[r0],#4
		B       copyloop
remap
		; SRAM and ROM have same code so remap now
		LDR     r0, =MEM_RCR
		MOV     r1, #1
		STR     r1, [r0]

; --- Initialise stack pointer registers
; Enter IRQ mode and set up the IRQ stack pointer
         MOV     R0, #Mode_IRQ:OR:I_Bit:OR:F_Bit ; No interrupts
         MSR     CPSR_c, R0
         LDR     R13, =IRQ_Stack

; Set up other stack pointers if necessary
;...

; Set up the SVC stack pointer last and return to SVC mode
         MOV     R0, #Mode_SVC:OR:I_Bit:OR:F_Bit ; No interrupts
         MSR     CPSR_c, R0
         LDR     R13, =SVC_Stack


; --- Initialise critical IO devices
         LDR   R0,=PIO_BASE 
;P16,P17,P18,P19 for keyboard
;P0-P7 for LCD

         LDR   R1,=0xFFF0FF00
         STR   R1,[R0,#0x04];PIO_PDR,p16-p19 and p0-p7is valueable
         LDR   R1,=0x000F00FF
         STR   R1,[R0,#0x00];PIO_PER
             
         LDR   R1,=0xFFFFFFFF
         STR   R1,[R0,#0x20];PIO_IFER,all pins have input filter
         LDR   R1,=0x0
         STR   R1,[R0,#0x24];PIO_IFDR

         LDR   R1,=0xFFFFFF00
         STR   R1,[R0,#0x14];PIO_ODR,all pins as input EXCEPT P0-7
         LDR   R1,=0x000000FF
         STR   R1,[R0,#0x10];PIO_OER,P0-7 AS OUTPUT
;may be need changes


         LDR   R1,=0xFFF0FFFF
         STR   R1,[R0,#0x44];PIO_IDR interupt,p16-p19 is valueable
         LDR   R1,=0x000F0000
         STR   R1,[R0,#0x40];PIO_IER


; --- Initialise interrupt system variables here

;Setup AIC for TC1
;             LDR R0,=0x00000007;AIC_SMR5 value,prior 7
;             LDR R1,=AIC_SMR5
;             STR R0,[R1]
;             LDR R0,=addr_AIC_SVR5;AIC_SVR5 value:Addr of scankey
;             LDR R1,=AIC_SVR5
;             STR R0,[R1]

;Setup AIC for key_down PIO
             LDR R0,=0x00000006;AIC_SMR8 value,prior 6
             LDR R1,=AIC_SMR8
             STR R0,[R1]

             LDR R0,= addr_AIC_SVR8
;AIC_SVR8 value:Addr of keydown
             LDR R1,=AIC_SVR8
             STR R0,[R1]

             LDR R0,=0xFFFFFEFF;AIC_IDCR:ALL DISABLE ,EXCEPT 8 ENABLE
             LDR R1,=AIC_IDCR
             STR R0,[R1]
             LDR R0,=0x00000100;AIC_IECR: 8 ENABLE
             LDR R1,=AIC_IECR
             STR R0,[R1]


             LDR  R1,=0xFFFFFFFF;SET OR CLEAR VALUE OUTPUT:ALL=0
             LDR  R0,=PIO_BASE
             STR  R1,[R0,#0x34];CLEAR OUTPUT DATA REGISTER


            
             ldr r1,=0xeafffffe;waithere
             ldr r0,=0x02010000
             str r1,[r0]
             
         MOV     R0, #Mode_USR:OR:I_Bit:OR:F_Bit; No FAST interrupts
         MSR     CPSR_c, R0
         LDR     sp, =USR_Stack

               BL LIGHTLED
;light LED

               ldrb r0,=0x50    
               bl R0_writeP0_P7
         
  
waithere        B  waithere


R0_writeP0_P7
          STMFD sp!,{r1-r3,lr}

;R0 LOW 8-BIT => PIO0-PIO7
;SET R0 BEFORE CALL

              LDR  R1,=PIO_BASE
              LDR  R3,=P0_P7MASK

              MOV  R2,R0;backup r0
              BIC  R2,R2,R3
              STR  R2,[R1,#0x30];SET OUTPUT DATA REGISTER

              MVN  R2,R0
              BIC  R2,R2,R3
              STR  R2,[R1,#0x34];CLEAR OUTPUT DATA REGISTER

          LDMFD sp!,{r1-r3,PC};Return




LIGHTLED      STMDB sp!,{R0-R3,lr}
              LDR     R2,=0x0;COUNT
              LDRB     R3,=0x02        
              
LIGHTLED_LOOP
              ldrb r0,=0x55
              bl  R0_writeP0_P7
              bl delay1s

              ldrb r0,=0xaa
              bl  R0_writeP0_P7
              bl delay1s
              ADD     R2,R2,#1
              CMP     R2,R3                       
              BNE     LIGHTLED_LOOP        
                                   
              LDMIA sp!,{R0-R3,PC};Return

delay1s
       STMFD sp!,{r0,lr}
       ldr r0, =0x0065b9aa
dly1s
       sub r0,r0,#1
       CMP R0,#0            
       bne dly1s

       LDMFD sp!,{r0,PC};Return                  	


              
                   
undefvec
		B       undefvec
swivec
		B       swivec
pabtvec
		B       pabtvec
dabtvec
		B       pabtvec
rsvdvec
		B       rsvdvec
progend
		END

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -