mirror of
https://github.com/d0k3/GodMode9.git
synced 2025-06-26 13:42:47 +00:00
- moved brightness control to the ARM11 - moved HID updating to the ARM11 - moved screen init from ARM9 to the ARM11, always performed unconditionally - removed unnecessary SCREENINIT and SET_BRIGHTNESS pxi commands and other stuff I probably forgot about
71 lines
1.2 KiB
ArmAsm
71 lines
1.2 KiB
ArmAsm
.section .text.boot
|
|
.align 4
|
|
|
|
#include <arm.h>
|
|
|
|
#define STACK_SZ (16384)
|
|
|
|
.global __boot
|
|
__boot:
|
|
cpsid aif, #SR_SVC_MODE
|
|
|
|
@ Writeback and invalidate all DCache
|
|
@ Invalidate all caches
|
|
@ Data Synchronization Barrier
|
|
mov r0, #0
|
|
mcr p15, 0, r0, c7, c10, 0
|
|
mcr p15, 0, r0, c7, c7, 0
|
|
mcr p15, 0, r0, c7, c10, 4
|
|
|
|
@ Reset control registers
|
|
ldr r0, =0x00054078
|
|
ldr r1, =0x0000000F
|
|
ldr r2, =0x00F00000
|
|
|
|
mcr p15, 0, r0, c1, c0, 0
|
|
mcr p15, 0, r1, c1, c0, 1
|
|
mcr p15, 0, r2, c1, c0, 2
|
|
|
|
@ Get CPU ID
|
|
mrc p15, 0, r12, c0, c0, 5
|
|
ands r12, r12, #3
|
|
|
|
@ Setup stack according to CPU ID
|
|
ldr sp, =(_stack_base + STACK_SZ)
|
|
ldr r0, =STACK_SZ
|
|
mla sp, r0, r12, sp
|
|
|
|
beq corezero_start
|
|
|
|
cmp r12, #MAX_CPU
|
|
blo coresmp_start
|
|
|
|
1:
|
|
wfi
|
|
b 1b
|
|
|
|
corezero_start:
|
|
@ assume __bss_len is 16 byte aligned
|
|
ldr r0, =__bss_pa
|
|
ldr r1, =__bss_len
|
|
mov r2, #0
|
|
mov r3, #0
|
|
mov r4, #0
|
|
mov r5, #0
|
|
add r1, r0, r1
|
|
.Lclearbss:
|
|
cmp r0, r1
|
|
stmltia r0!, {r2-r5}
|
|
blt .Lclearbss
|
|
|
|
bl SYS_CoreZeroInit
|
|
|
|
coresmp_start:
|
|
bl SYS_CoreInit
|
|
b MainLoop
|
|
|
|
.section .bss.stack
|
|
.align 3
|
|
_stack_base:
|
|
.space (MAX_CPU * STACK_SZ)
|