📄 initbdi_key(串口调试,display_memory register ok没有键盘液晶).s
字号:
AREA BOOTROM, CODE, READONLY
;3d00
ARM_MODE_SYS EQU 0x1F
ARM_MODE_IRQ EQU 0x12
I_BIT EQU 0x80
Mode_USR EQU 0x10
Mode_IRQ EQU 0x12
Mode_SVC EQU 0x13
I_Bit EQU 0x80
F_Bit EQU 0x40
AIC_BASE EQU 0xFFFFF000
AIC_EOICR EQU 0x0130
;PIO IRQ
AIC_SMR8 EQU 0xFFFFF020
AIC_SVR8 EQU 0xFFFFF0A0
AIC_IECR EQU 0xFFFFF120
AIC_IDCR EQU 0xFFFFF124
PIO_ISR EQU 0xFFFF004C
PIO_PDSR EQU 0xFFFF003C
PIO_BASE EQU 0xFFFF0000
P0_P7MASK EQU 0xFFFFFF00
USART0 EQU 0xFFFD0000
USART1 EQU 0xFFFCC000
CS4_addr EQU 0x40000000
;LCD and keyboard
;ON Chip RAM
send_bufffer EQU 0x00000E00;
receive_bufffer EQU 0x00000D00;
addr_download EQU 0x00000F88;start address of download
secsize_download EQU 0x00000F8C;sector size of download
debug_SP_Start EQU 0x00000F90;sector size of download
debug_SP_End EQU 0x00000F94;sector size of download
s_addr_display EQU 0x00000F98;start address of download
LCDparam EQU 0x00000F00;????????????????????
RAM_Limit EQU 0x02080000 ;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
;XXXX 0000
;E(1),R/~W,RS(1 data,0 commmand)
LCD_CW_E EQU 0x80
;100 X
LCD_CR_E EQU 0xC0
;110 X
LCD_DW_E EQU 0xA0
;101 X
LCD_DR_E EQU 0xE0
;111 X
;write to cs4
LCD_CW EQU 0x00
;000 X
LCD_CR EQU 0x40
;010 X
LCD_DW EQU 0x20
;001 X
LCD_DR EQU 0x60
;011 X
;write to cs4
ENTRY
ldr r0,=0xe51fff20
ldr r1,=0x18
str r0,[r1]
ldr r0,=0xe51fff20
ldr r1,=0x1c
str r0,[r1]
; --- 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,= PIO_int
;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 R2,=CS4_addr
ldrb r1,=0x00
strb r1,[r2]
; BL LIGHTLED
;light LED
ldrb r0,=0x55
;bl R0_writeP0_P7
MOV R0,#Mode_SVC:OR:I_Bit:OR:F_Bit ; No interrupts
MSR CPSR_c, R0
;start debug from UART0
initUART0_debug
;bl INITLCD
bl init_USART0
LDR R1,=send_bufffer;ADDR OF STRING
LDR R0,=0x434C4557;WELC
STR R0,[R1]
LDR R0,=0x21454D4F;OME!
STR R0,[R1,#4]
LDR R5,=0x00000008
BL sendstring
;after welcome message
;PC:any key to continue
BL getbyte
CMP R5,#0x52;"R"
BNE initUART0_debug
LDR R5,=0x00000041;"A"
BL sendbyte
UART0_debugloop
mov r0,sp
ldr r1,=debug_SP_Start
str r0,[r1]
stmfd sp!,{r0-r12,lr}
stmfd sp!,{r1,r2}
;... ...
mov r0,sp
ldr r1,=debug_SP_End
str r0,[r1]
;all register push into stack
;save SP in :debug_SP
BL getbyte
CMP R5,#0x46;"F" File
bleq COM_download
CMP R5,#0x44;"D" Display
bleq COM_Display
CMP R5,#0x43;"C" Change
bleq COM_Change
B UART0_debugloop
ldmfd sp!,{r1,r2}
ldmfd sp!,{r0-r12,lr}
;----------------------------------------------------------------------
PIO_int
;- Adjust and save LR of current mode in current stack
sub r14, r14, #4
stmfd sp!, {r14}
;- Save SPSR and r0 in current stack
mrs r14, SPSR
stmfd sp!, {r0, r14}
;- Save used registers and LR_usr in the System/User Stack
stmfd sp!, {r0-r4, r14}
;-----------------------------------------------------------------------
LDR R2,=PIO_ISR
LDR R0,[R2]
BIC R0,R0,#0xFFF0FFFF
;row in r0
;1000 =>p19 0x80
;0100 =>p18 0x40
;0010 =>p17 0x20
;0001 =>p16 0x10
bl CPL_P0P7
ldr r3,=0x00000000;clr keydown
start_scan_COL
;scan col
ldr r1,=0xFFFFFFF7;1111 0111->COL4
bl delay20ms
bl CPL_P0P7
scan_nextCOL
LDR R2,=CS4_addr
bic r4,r1,#0xFFFFFFF0
strb r4,[r2]
nop
nop
nop
nop
nop
scan_thisCOL
LDR R2,=PIO_PDSR
LDR R4,[R2]
mvn r2,r4
BIC R2,R2,#0xFFF0FFFF
cmp r0,#0
beq end_of_keydown
; cmp r2,#0
; beq end_of_keydown
cmp r2,r0
beq keydown_is_curCOL
no_keydown_thiscol
mov r1,r1,ROR #1
cmp r1,#0x7FFFFFFF
beq this_scan_no_keydown
B scan_nextCOL
keydown_is_curCOL
;r1 0xFFFFFFF0
;r0 0x000F 0000->0x0000 00F0
MOV R2,R2,LSR #12
BIC R4,R1,#0xFFFFFFF0
add r3,r2,r4
; mov r3,r2
B scan_thisCOL;key in r3
;0x0000 0017:F3
;0x0000 001B:E
;0x0000 001D:0
;0x0000 001E:9
;0x0000 0027:1
;0x0000 002B:5
;0x0000 002D:7
;0x0000 002E:6
;0x0000 0047:FE
;0x0000 004B:F2
;0x0000 004D:F4
;0x0000 004E:8
;0x0000 0087:2
;0x0000 008B:3
;0x0000 008D:F1
;0x0000 008E:4
this_scan_no_keydown
;process key
cmp r3,#0x1E;9
bleq COM_download;download file to target
cmp r3,#0x2E;6
bleq init_USART0
cmp r3,#0x4D;F4
; bleq test_USART0
cmp r3,#0x27
bleq LIGHTLED
cmp r3,#0x87
bleq INITLCD
cmp r3,#0x8B
bleq lcd_main
cmp r3,#0x2B
bleq test_DISPLAY_R0
end_of_keydown
bl delay20ms
LDR R2,=PIO_ISR
LDR R0,[R2]
LDR R2,=CS4_addr
ldrb r1,=0x00
strb r1,[r2];re enable
;-----------------------------------------------------------------------
;- Restore used registers and LR_usr from the System/User Stack
ldmfd sp!, {r0-r4,r14}
;- Mark the End of Interrupt on the interrupt controller
ldr r0, = AIC_BASE
str r0, [r0, #AIC_EOICR]
;- Restore SPSR_irq and r0 from the IRQ stack
ldmfd sp!, {r0, r14}
msr SPSR, r14
;- Restore ajusted LR_irq from IRQ stack directly in the PC
ldmfd sp!, {pc}^
;-------------------------------------------------------------------
COM_download STMFD sp!,{R0-R2,R5,lr}
; BL on_p7;START TRANSFER
LDR R1,=send_bufffer;ADDR OF STRING
LDR R0,=0x434C4557;WELC
STR R0,[R1]
LDR R0,=0x21454D4F;OME!
STR R0,[R1,#4]
LDR R5,=0x00000008
BL sendstring
BL getbyte
CMP R5,#82;"R"
BNE COM_ERROR
LDR R5,=0x00000041;"A"
BL sendbyte
LDR R5,=0x00000004;get the start address of download
BL getstring
LDR R1,=receive_bufffer;save the start address
LDR R0,[R1]
LDR R2,=addr_download
STR R0,[R2]
; BL DISPLAY_R0
LDR R5,=0x00000053;"S"
BL sendbyte
LDR R5,=0x00000004;get the sector size of download,128 bytes/sector
BL getstring
LDR R0,[R1];save the sector size
LDR R2,=secsize_download
STR R0,[R2]
; BL DISPLAY_R0
SEC_WRI BL getbyte
CMP R5,#71;"G"
BNE COM_downloadEND
LDR R5,=0x00000047;"G"
BL sendbyte;start sector write
LDR R5,=0x00000080;get a sector(128 bytes)
BL getstring
BL BUF2ROM
LDR R2,=secsize_download
LDR R0,[R2]
SUB R0,R0,#1
CMP R0,#0
BEQ END_FILE
STR R0,[R2]
B SEC_WRI
END_FILE
LDR R5,=0x00000045;"E"
BL sendbyte;END OF TRANSFER
BL TRANSFEROK
COM_downloadEND
LDMFD sp!,{R0-R2,R5,PC};Return
COM_ERROR
; BL off_p7
;B COM_downloadEND
B COM_ERROR
TRANSFEROK STMFD sp!,{lr}
; BL on_p7
LDMFD sp!,{PC};Return
COM_Display
STMFD sp!,{R0-R4,lr}
;Display-R,(Register)
; M,(Memory)
LDR R5,=0x00000041;"A"
BL sendbyte
BL getbyte
CMP R5,#0x52;"R" File
bleq COM_Register
CMP R5,#0x4D;"M" Display
bleq COM_Memory
LDMFD sp!,{R0-R4,PC};Return
COM_Register
STMFD sp!,{R0-R4,lr}
;display R,(Register) 128-Byte
LDR R5,=0x00000041;"A"
BL sendbyte
BL getbyte
CMP R5,#0x52;"R" reply
LDR R2,=debug_SP_End
STR R0,[R2]
LDR R2,=s_addr_display
STR R0,[R2]
LDR R5,=0x00000040
BL send_MEM_UART0
;s_addr_display,64-byte(0x40)r0-r15
LDMFD sp!,{R0-R4,PC};Return
COM_Memory
STMFD sp!,{R0-R4,lr}
;display M,(Memory) 128-Byte
LDR R5,=0x00000041;"A"
BL sendbyte
LDR R5,=0x00000004;get the start address of download
BL getstring
LDR R5,=0x00000041;"A"
BL sendbyte
BL getbyte
CMP R5,#0x52;"R" File
LDR R1,=receive_bufffer;save the start address
LDR R0,[R1]
LDR R2,=s_addr_display
STR R0,[R2]
LDR R5,=0x00000100
BL send_MEM_UART0
;s_addr_display,256-byte(0x100)
LDMFD sp!,{R0-R4,PC};Return
send_MEM_UART0
STMFD sp!,{R0-R4,lr}
;s_addr_display
;R5:COUNT OF TRANSMIT LOW 16-BIT
;SET R5,BEFORE CALL,256-byte(0x100)
LDR R0,=USART0
send_MEMwait2 LDR R1,[R0,#0x14];US_CSR
LDR R2,=0xFFFFFFEF
BIC R1,R1,R2;ENDTX
CMP R1,#0
BEQ send_MEMwait2
LDR R2,=s_addr_display;start ADDR OF MEM
ldr r1,[r2]
STR R1,[R0,#0x38];US_TPR
;ADDR OF TRANSMITTER POIONTER
STR R5,[R0,#0x3C];US_TCR
send_MEMwait4 LDR R1,[R0,#0x14];US_CSR
LDR R2,=0xFFFFFFEF
BIC R1,R1,R2;ENDTX
CMP R1,#0
BEQ send_MEMwait4
LDMFD sp!,{R0-R4,PC};Return
COM_Change
STMFD sp!,{R0-R4,lr}
;Display-R,(Register)
; M,(Memory)
LDR R5,=0x00000041;"A"
BL sendbyte
BL getbyte
CMP R5,#0x52;"R" File
bleq COM_download
CMP R5,#0x4D;"M" Display
bleq COM_Display
LDMFD sp!,{R0-R4,PC};Return
BUF2ROM STMFD sp!,{R0-R4,lr}
LDR R2,=0x00000D80;END OF RECEIVE_BUFFER
LDR R1,=receive_bufffer
SUB R1,R1,#4
LDR R4,=addr_download
LDR R3,[R4]
SUB R3,R3,#4
BUFWRI_LOOP LDR R0,[R1,#4]!
STR R0,[R3,#4]!
CMP R1,R2;RECEIVE_BUFFFER END
BNE BUFWRI_LOOP
STR R3,[R4]
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -