73 lines
1.2 KiB
ArmAsm
Raw Normal View History

2017-07-26 21:39:30 +02:00
.section .text.boot
2017-08-21 21:01:18 -03:00
.align 4
2017-07-26 21:39:30 +02:00
2017-08-08 23:04:17 -03:00
#include <arm.h>
#define STACK_SZ (8192)
2017-07-26 21:39:30 +02:00
.global __boot
__boot:
cpsid aif, #SR_SVC_MODE
2017-07-26 21:39:30 +02:00
@ Writeback and invalidate all DCache
@ Invalidate all caches
@ Data Synchronization Barrier
2017-07-26 21:39:30 +02:00
mov r0, #0
mcr p15, 0, r0, c7, c10, 0
2017-07-26 21:39:30 +02:00
mcr p15, 0, r0, c7, c7, 0
mcr p15, 0, r0, c7, c10, 4
@ Reset control registers
2017-07-26 21:39:30 +02:00
ldr r0, =0x00054078
ldr r1, =0x0000000F
ldr r2, =0x00F00000
2017-07-26 21:39:30 +02:00
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:
ldr r0, =__bss_start
ldr r1, =__bss_end
mov r2, #0
.Lclearbss:
cmp r0, r1
strlt r2, [r0], #4
blt .Lclearbss
@ Set up IRQ vector
ldr r0, =0x1FFFFFA0
ldr r1, =0xE51FF004
ldr r2, =irq_vector
stmia r0, {r1, r2}
coresmp_start:
bl SYS_CoreInit
bl MPCoreMain
2017-07-26 21:39:30 +02:00
b __boot
.section .bss.stack
.align 3
_stack_base:
.space (MAX_CPU * STACK_SZ)