Files
linux-kernel-module-cheat/baremetal/arch/arm/multicore.S
Ciro Santilli 六四事件 法轮功 b3874cc72b asm: make all text section labels .L local
To help with backtraces if we ever fix them due to the lkmc_asm_main_after_prologue debacle.
2019-06-16 12:28:53 +01:00

39 lines
657 B
ArmAsm

/* https://github.com/cirosantilli/linux-kernel-module-cheat#arm-multicore */
#include <lkmc.h>
LKMC_PROLOGUE
mov r0, 0
ldr r1, =spinlock
str r0, [r1]
/* Get CPU ID. */
mrc p15, 0, r1, c0, c0, 5
ands r1, r1, 3
beq cpu0_only
.Lcpu1_only:
mov r0, 1
ldr r1, =spinlock
str r0, [r1]
dmb sy
sev
.Lcpu1_sleep_forever:
wfe
b .Lcpu1_sleep_forever
cpu0_only:
#if !LKMC_GEM5
/* PSCI CPU_ON. */
ldr r0, =0x84000003
mov r1, 1
ldr r2, =.Lcpu1_only
mov r3, 0
hvc 0
#endif
spinlock_start:
ldr r0, spinlock
wfe
cmp r0, 0
beq spinlock_start
LKMC_EPILOGUE
spinlock:
.skip 4