boot4u/main.S

159 lines
4.8 KiB
ArmAsm
Executable File
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

.text
.align 4
.global _start
_start:
//M4 RTOS loader snipet prep
ldr r4, =0x60006400 //fopen addr
adr r0, [.LC2] //file name
adr r1, [.LC1] //open mode
blx r4
add r5, r4, #0xc //fread addr
mov r3, r0 //file descriptor
ldr r0, =0x1ffe4000 //fread destination
mov r1, #1 //read unit size
mov r2, r0 //read unit count(over size)
blx r5
//M4 RTOS preload
ldr r4, =0x60006400 //fopen addr
adr r0, [.LC3] //file name
adr r1, [.LC1] //open mode
blx r4
add r5, r4, #0xc //fread addr
mov r3, r0 //file descriptor
ldr r0, =0x37400000 //fread destination
mov r1, #1 //read unit size
mov r2, r0 //read unit count(over size)
blx r5
//M4 RTOS size get
ldr r4, =0x60006444 //stat addr
adr r0, [.LC3] //file name
sub sp, sp, #0x14
mov r1, sp
blx r4
ldr r0, =0x373ffffc //store size before data
ldr r1, [sp,#0x10]
str r1, [r0]
//M4 interrupt prep
ldr r4, =0x1ffd20d0 //NVIC MCM vector
ldr r5, =0x1ffe4001 //loader addr | 0x1(thumb)
str r5, [r4] //override interrupt handler
//wait until M4 RTOS copied
ldr r4, =0x1ffd2000 //get sram img start addr
add r0, r0, #4 //get dram rtos addr
ldr r3, [r0, r1] //get last word of rtos on dram
rtos_loop:
ldr r2, [r4,r1] //get last word of rtos on sram
cmp r2,r3
bne rtos_loop
//preload U-Boot from sd
ldr r4, =0x60006400 //fopen addr
adr r0, [.LC0] //file name
adr r1, [.LC1] //open mode
blx r4
add r5, r4, #0xc //fread addr
mov r3, r0 //file descriptor
ldr r0, =0x37500000 //fread destination
mov r1, #1 //read unit size
mov r2, r0 //read unit count(over size)
blx r5
bl continue //to avoid strings address exceeds pc relative offset limit
.LC0:
.ascii "SD0:\\u-boot.bin\000"
.LC1:
.ascii "r\000"
.LC2:
.ascii "SD0:\\m4_loader.bin\000"
.LC3:
.ascii "SD0:\\m4_rtos.bin\000"
.align 4
continue:
cpsid if //disable interrupt
//copy U-Boot to head of RAM
ldr r3, =0x37500000 //copy start
add r1, r3, r0 //copy end
copy_loop:
mov r2, r3
sub r3, r3, #0x7500000 //copy distination
ldr r0, [r2], #4
cmp r2, r1
str r0, [r3]
mov r3, r2
blt copy_loop
//RAM clear
ldr r2,=0x60200000 //clear start
ldr r3,=0x68000000 //clear end
sub r3,r3,#4
eor r1,r1,r1
clear_loop:
cmp r2,r3
str r1,[r2],#4
beq clear_loop
//LCDIF CUR_BUF change
ldr r1,=0x40aa0000 //LCDIF_CTRL
ldr r3,=0x62000000 //new framebuffer addr
str r3,[r1,#0x50]
ldr r0, =0x60000000
mrc p15, 0, r8, c14, c2, 1
bic r8, r8, #1
mcr p15, 0, r8, c14, c2, 1
mrc p15, 0, r8, c14, c3, 1
bic r8, r8, #1
mcr p15, 0, r8, c14, c3, 1
mov r9, #0
mrc p15, 0, r6, c1, c0, 0
bic r6, r6, #4 @ disable dcache
bic r6, r6, #4096 @ disable icache
mcr p15, 0, r6, c1, c0, 0 // write ctrl regs
mcr p15, 0, r9, c7, c5, 0 // invalidate icache
// from: https://www.aps-web.jp/academy/ca/229/#i-2
mov r10,#0 //
mcr p15,2,r10,c0,c0,0 // CSSELR
//
isb //
mrc p15,1,r1,c0,c0,0 // CCSIDR
and r2,r1,#7 // b001=8ワード/
add r2,r2,#4 // DCISW
ldr r4,=0x3FF //
ands r4,r4,r1,LSR #3 // r4
clz r5,r4 // DCISW
ldr r7,=0x7FFF //
ands r7,r7,r1,LSR #13 // r7
// 0x7F=12Kbyte/0xFF=32Kbyte/0x1FF=64Kbyte
loop2:
mov r9,r4 // r9
loop3:
orr r11,r10,r9,LSL r5 //
orr r11,r11,r7,LSL r2 //
mcr p15,0,r11,c7,c6,2 // DCISW/
//
subs r9,r9,#1 // -1
bge loop3 //
subs r7,r7,#1 // -1
bge loop2 //
mcr p15, 0, r9, c8, c7, 0 // invalidate TLB
mcr p15, 0, r9, c7, c5, 6 // invalidate branch predictor array
bic r6, r6, #1 @ disable MMU
mcr p15, 0, r6, c1, c0, 0 // write ctrl regs
bx r0