simplify start.s

This commit is contained in:
ccckmit
2023-05-24 11:42:54 +08:00
parent 873150ceb9
commit 70443b0ab3

View File

@@ -1,27 +1,16 @@
# -- https://matrix89.github.io/writes/writes/experiments-in-riscv/
.equ STACK_SIZE, 8192 .equ STACK_SIZE, 8192
.global _start .global _start
_start: _start:
# setup stacks per hart // hart: hardware thread, core, core csrr a0, mhartid #
csrr t0, mhartid # read current hart id // core id bnez a0, park # 0 park
slli t0, t0, 10 # shift left the hart id by 1024 // t0 = t0*1024 la sp, stacks + STACK_SIZE # 0
la sp, stacks + STACK_SIZE # set the initial stack pointer // sp j os_main # 0 os_main
# to the end of the stack space
add sp, sp, t0 # move the current hart stack pointer // hart
# to its place in the stack space
# park harts with id != 0 park:
csrr a0, mhartid # read current hart id
bnez a0, park # if we're not on the hart 0 // hart 0
# we park the hart
j os_main # hart 0 jump to c // hart 0 C
park: # !
wfi wfi
j park j park
stacks: stacks:
.skip STACK_SIZE * 4 # allocate space for the harts stacks // .skip STACK_SIZE #