-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathboot_picorv32.S
55 lines (49 loc) · 980 Bytes
/
boot_picorv32.S
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
.section .init
.global main
reset_vec:
j start
start:
addi x1, zero, 0
addi x2, zero, 0
addi x3, zero, 0
addi x4, zero, 0
addi x5, zero, 0
addi x6, zero, 0
addi x7, zero, 0
addi x8, zero, 0
addi x9, zero, 0
addi x10, zero, 0
addi x11, zero, 0
addi x12, zero, 0
addi x13, zero, 0
addi x14, zero, 0
addi x15, zero, 0
addi x16, zero, 0
addi x17, zero, 0
addi x18, zero, 0
addi x19, zero, 0
addi x20, zero, 0
addi x21, zero, 0
addi x22, zero, 0
addi x23, zero, 0
addi x24, zero, 0
addi x25, zero, 0
addi x26, zero, 0
addi x27, zero, 0
addi x28, zero, 0
addi x29, zero, 0
addi x30, zero, 0
addi x31, zero, 0
/* set stack pointer to end of block ram */
// lui sp, %hi(5120)
// addi sp, sp, %lo(5120)
lui sp, %hi(6144)
addi sp, sp, %lo(6144)
/* call firmware main */
jal ra, main
/* set stack pointer to end of main memory */
lui sp, %hi(0x42000000)
addi sp, sp, %lo(0x42000000)
/* jump to LIX or baremetal app */
li a0, 0x40000000
jr a0