2022-08-09 20:17:46 +02:00
|
|
|
# qemu -kernel loads the kernel at 0x80000000
|
|
|
|
# and causes each hart (i.e. CPU) to jump there.
|
2020-08-15 11:46:32 +02:00
|
|
|
# kernel.ld causes the following code to
|
|
|
|
# be placed at 0x80000000.
|
2019-05-31 15:45:59 +02:00
|
|
|
.section .text
|
2020-10-20 15:42:34 +02:00
|
|
|
.global _entry
|
2019-05-31 15:45:59 +02:00
|
|
|
_entry:
|
2022-08-09 20:17:46 +02:00
|
|
|
# set up a stack for C.
|
2019-07-23 17:14:10 +02:00
|
|
|
# stack0 is declared in start.c,
|
|
|
|
# with a 4096-byte stack per CPU.
|
|
|
|
# sp = stack0 + (hartid * 4096)
|
2019-05-31 15:45:59 +02:00
|
|
|
la sp, stack0
|
2019-06-05 17:42:03 +02:00
|
|
|
li a0, 1024*4
|
2022-08-09 20:17:46 +02:00
|
|
|
csrr a1, mhartid
|
2019-06-05 17:42:03 +02:00
|
|
|
addi a1, a1, 1
|
|
|
|
mul a0, a0, a1
|
|
|
|
add sp, sp, a0
|
2022-08-09 20:17:46 +02:00
|
|
|
# jump to start() in start.c
|
2019-07-23 20:31:12 +02:00
|
|
|
call start
|
2020-08-15 11:46:32 +02:00
|
|
|
spin:
|
|
|
|
j spin
|