mirror of
https://github.com/isometimes/rpi4-osdev
synced 2024-11-09 11:50:40 +00:00
80 lines
1.9 KiB
ArmAsm
80 lines
1.9 KiB
ArmAsm
#define LOCAL_CONTROL 0xff800000
|
|
#define LOCAL_PRESCALER 0xff800008
|
|
#define OSC_FREQ 54000000
|
|
#define MAIN_STACK 0x400000
|
|
|
|
.section ".text.boot" // Make sure the linker puts this at the start of the kernel image
|
|
|
|
.global _start // Execution starts here
|
|
|
|
_start:
|
|
ldr x0, =LOCAL_CONTROL // Sort out the timer
|
|
str wzr, [x0]
|
|
mov w1, 0x80000000
|
|
str w1, [x0, #(LOCAL_PRESCALER - LOCAL_CONTROL)]
|
|
|
|
ldr x0, =OSC_FREQ
|
|
msr cntfrq_el0, x0
|
|
msr cntvoff_el2, xzr
|
|
|
|
// Check processor ID is zero (executing on main core), else hang
|
|
mrs x1, mpidr_el1
|
|
and x1, x1, #3
|
|
cbz x1, 2f
|
|
|
|
// We're not on the main core, so hang in an infinite wait loop
|
|
adr x5, spin_cpu0
|
|
1: wfe
|
|
ldr x4, [x5, x1, lsl #3]
|
|
cbz x4, 1b
|
|
|
|
ldr x2, =__stack_start // Get ourselves a fresh stack - location depends on CPU core asking
|
|
lsl x1, x1, #9 // Multiply core_number by 512
|
|
add x3, x2, x1 // Add to the address
|
|
mov sp, x3
|
|
|
|
mov x0, #0
|
|
mov x1, #0
|
|
mov x2, #0
|
|
mov x3, #0
|
|
br x4
|
|
b 1b
|
|
2: // We're on the main core!
|
|
|
|
// Set stack to start somewhere safe
|
|
mov sp, #MAIN_STACK
|
|
|
|
// Clean the BSS section
|
|
ldr x1, =__bss_start // Start address
|
|
ldr w2, =__bss_size // Size of the section
|
|
3: cbz w2, 4f // Quit loop if zero
|
|
str xzr, [x1], #8
|
|
sub w2, w2, #1
|
|
cbnz w2, 3b // Loop if non-zero
|
|
|
|
// Jump to our main() routine in C (make sure it doesn't return)
|
|
4: bl main
|
|
// In case it does return, halt the master core too
|
|
b 1b
|
|
|
|
.ltorg
|
|
|
|
.org 0xd8
|
|
.globl spin_cpu0
|
|
spin_cpu0:
|
|
.quad 0
|
|
|
|
.org 0xe0
|
|
.globl spin_cpu1
|
|
spin_cpu1:
|
|
.quad 0
|
|
|
|
.org 0xe8
|
|
.globl spin_cpu2
|
|
spin_cpu2:
|
|
.quad 0
|
|
|
|
.org 0xf0
|
|
.globl spin_cpu3
|
|
spin_cpu3:
|
|
.quad 0
|