-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy paththumbv7em-none-eabi.s
70 lines (65 loc) · 1.54 KB
/
thumbv7em-none-eabi.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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
.thumb
.syntax unified
.global __CORTEXM_THREADS_GLOBAL_PTR
.global __CORTEXM_THREADS_wfe
.thumb_func
__CORTEXM_THREADS_wfe:
wfe
bx lr
.global __CORTEXM_THREADS_cpsid
.thumb_func
__CORTEXM_THREADS_cpsid:
cpsid i
bx lr
.global __CORTEXM_THREADS_cpsie
.thumb_func
__CORTEXM_THREADS_cpsie:
cpsie i
bx lr
.global PendSV
.thumb_func
PendSV:
cpsid i
ldr r1, =__CORTEXM_THREADS_GLOBAL_PTR /* r1 = &&OS_PTR */
ldr r1, [r1, 0x0] /* r1 = &OS_PTR */
ldr r1, [r1, 0x0] /* r1 = OS_PTR.curr ( ¤t_thread ) */
cmp r1, 0x0
beq __CORTEXM_THREADS_PENDSV_RESTORE
ldr r2, [r1, 0x4] /* r2 = current_thread.privileged */
cmp r2, 0x0
beq __str_unpriv
mrs r0, msp
b __str_end
__str_unpriv:
mrs r0, psp
__str_end:
stmdb r0!, {r4-r11}
str r0, [r1, 0x0] /* current_thread.sp = sp */
__CORTEXM_THREADS_PENDSV_RESTORE:
ldr r1, =__CORTEXM_THREADS_GLOBAL_PTR /* r1 = &&OS_PTR */
ldr r1, [r1, 0x0] /* r1 = &OS_PTR */
ldr r2, [r1, 0x4] /* r2 = OS_PTR.next */
ldr r3, [r2, 0x0] /* r3 = OS_PTR.next.sp */
ldr r0, [r2, 0x4] /* r0 = OS_PTR.next.privileged */
ldr r1, =__CORTEXM_THREADS_GLOBAL_PTR /* r1 = &&OS_PTR */
ldr r1, [r1, 0x0] /* r1 = &OS_PTR */
ldr r2, [r1, 0x4] /* r2 = &OS.next */
str r2, [r1, 0x0] /* set OS.curr = os.next */
ldmia r3!, {r4-r11}
cmp r0, 0x0
beq __load_unpriv
movs r0, #0x3
msr control, r0
isb
msr msp, r3
ldr r0, =0xFFFFFFF9
b __load_end
__load_unpriv:
movs r0, #0x1
msr control, r0
isb
msr psp, r3
ldr r0, =0xFFFFFFFD
__load_end:
cpsie i
bx r0