4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-25 12:07:23 +08:00

780 lines
33 KiB
Plaintext
Raw Normal View History

ARM Macro Assembler Page 1
1 00000000 ;/*
2 00000000 ;* Copyright (c) 2006-2018, RT-Thread Development Team
3 00000000 ;*
4 00000000 ;* SPDX-License-Identifier: Apache-2.0
5 00000000 ;*
6 00000000 ; * Change Logs:
7 00000000 ; * Date Author Notes
8 00000000 ; * 2009-01-17 Bernard first version.
9 00000000 ; * 2012-01-01 aozima support context switch l
oad/store FPU register.
10 00000000 ; * 2013-06-18 aozima add restore MSP feature.
11 00000000 ; * 2013-06-23 aozima support lazy stack optim
ized.
12 00000000 ; * 2018-07-24 aozima enhancement hard fault e
xception handler.
13 00000000 ; */
14 00000000
15 00000000 ;/**
16 00000000 ; * @addtogroup cortex-m33
17 00000000 ; */
18 00000000 ;/*@{*/
19 00000000
20 00000000 E000ED08
SCB_VTOR
EQU 0xE000ED08 ; Vector Table Offs
et Register
21 00000000 E000ED04
NVIC_INT_CTRL
EQU 0xE000ED04 ; interrupt control
state register
22 00000000 E000ED20
NVIC_SYSPRI2
EQU 0xE000ED20 ; system priority r
egister (2)
23 00000000 FFFF0000
NVIC_PENDSV_PRI
EQU 0xFFFF0000 ; PendSV and SysTic
k priority value (l
owest)
24 00000000 10000000
NVIC_PENDSVSET
EQU 0x10000000 ; value to trigger
PendSV exception
25 00000000
26 00000000 AREA |.text|, CODE, READONLY, ALIGN=
2
27 00000000 THUMB
28 00000000 REQUIRE8
29 00000000 PRESERVE8
30 00000000
31 00000000 IMPORT rt_thread_switch_interrupt_flag
32 00000000 IMPORT rt_interrupt_from_thread
33 00000000 IMPORT rt_interrupt_to_thread
34 00000000 IMPORT rt_trustzone_current_context
35 00000000 IMPORT rt_trustzone_context_load
36 00000000 IMPORT rt_trustzone_context_store
37 00000000
38 00000000 ;/*
ARM Macro Assembler Page 2
39 00000000 ; * rt_base_t rt_hw_interrupt_disable();
40 00000000 ; */
41 00000000 rt_hw_interrupt_disable
PROC
42 00000000 EXPORT rt_hw_interrupt_disable
43 00000000 F3EF 8010 MRS r0, PRIMASK
44 00000004 B672 CPSID I
45 00000006 4770 BX LR
46 00000008 ENDP
47 00000008
48 00000008 ;/*
49 00000008 ; * void rt_hw_interrupt_enable(rt_base_t level);
50 00000008 ; */
51 00000008 rt_hw_interrupt_enable
PROC
52 00000008 EXPORT rt_hw_interrupt_enable
53 00000008 F380 8810 MSR PRIMASK, r0
54 0000000C 4770 BX LR
55 0000000E ENDP
56 0000000E
57 0000000E ;/*
58 0000000E ; * void rt_hw_context_switch(rt_uint32 from, rt_uint32
to);
59 0000000E ; * r0 --> from
60 0000000E ; * r1 --> to
61 0000000E ; */
62 0000000E rt_hw_context_switch_interrupt
63 0000000E EXPORT rt_hw_context_switch_interrupt
64 0000000E rt_hw_context_switch
PROC
65 0000000E EXPORT rt_hw_context_switch
66 0000000E
67 0000000E ; set rt_thread_switch_interrupt_flag to 1
68 0000000E 4A5D LDR r2, =rt_thread_switch_interrupt
_flag
69 00000010 6813 LDR r3, [r2]
70 00000012 2B01 CMP r3, #1
71 00000014 D004 BEQ _reswitch
72 00000016 F04F 0301 MOV r3, #1
73 0000001A 6013 STR r3, [r2]
74 0000001C
75 0000001C 4A5A LDR r2, =rt_interrupt_from_thread ;
set rt_interrupt_f
rom_thread
76 0000001E 6010 STR r0, [r2]
77 00000020
78 00000020 _reswitch
79 00000020 4A5A LDR r2, =rt_interrupt_to_thread ; s
et rt_interrupt_to_
thread
80 00000022 6011 STR r1, [r2]
81 00000024
82 00000024 485A LDR r0, =NVIC_INT_CTRL ; trigger th
e PendSV exception
(causes context swi
tch)
83 00000026 F04F 5180 LDR r1, =NVIC_PENDSVSET
84 0000002A 6001 STR r1, [r0]
85 0000002C 4770 BX LR
ARM Macro Assembler Page 3
86 0000002E ENDP
87 0000002E
88 0000002E ; r0 --> switch from thread stack
89 0000002E ; r1 --> switch to thread stack
90 0000002E ; psr, pc, lr, r12, r3, r2, r1, r0 are pushed into [from
] stack
91 0000002E PendSV_Handler
PROC
92 0000002E EXPORT PendSV_Handler
93 0000002E
94 0000002E ; disable interrupt to protect context switch
95 0000002E F3EF 8210 MRS r2, PRIMASK ; R2 = PRIMASK
96 00000032 B672 CPSID I ; disable all inter
rupt
97 00000034
98 00000034 ; get rt_thread_switch_interrupt_flag
99 00000034 4853 LDR r0, =rt_thread_switch_interrupt
_flag
; r0 = &rt_thread_s
witch_interrupt_fla
g
100 00000036 6801 LDR r1, [r0] ; r1 = *r1
101 00000038 2900 CMP r1, #0x00 ; compare r1 == 0x0
0
102 0000003A D102 BNE schedule
103 0000003C F382 8810 MSR PRIMASK, r2 ; if r1 == 0x00, do
msr PRIMASK, r2
104 00000040 4770 BX lr ; if r1 == 0x00, do
bx lr
105 00000042
106 00000042 schedule
107 00000042 B404 PUSH {r2} ; store interrupt s
tate
108 00000044
109 00000044 ; clear rt_thread_switch_interrupt_flag to 0
110 00000044 F04F 0100 MOV r1, #0x00 ; r1 = 0x00
111 00000048 6001 STR r1, [r0] ; *r0 = r1
112 0000004A
113 0000004A ; skip register save at the first time
114 0000004A 484F LDR r0, =rt_interrupt_from_thread ;
r0 = &rt_interrupt
_from_thread
115 0000004C 6801 LDR r1, [r0] ; r1 = *r0
116 0000004E B359 CBZ r1, switch_to_thread ; if r1 ==
0, goto switch_to_
thread
117 00000050
118 00000050 ; Whether TrustZone thread stack exists
119 00000050 4950 LDR r1, =rt_trustzone_current_cont
ext
; r1 = &rt_secure_c
urrent_context
120 00000052 6809 LDR r1, [r1] ; r1 = *r1
121 00000054 B1A1 CBZ r1, contex_ns_store ; if r1 ==
0, goto contex_ns_s
tore
122 00000056
123 00000056 ;call TrustZone fun, Save TrustZone stack
124 00000056 B503 STMFD sp!, {r0-r1, lr}
ARM Macro Assembler Page 4
; push register
125 00000058 4608 MOV r0, r1 ; r0 = rt_secure_cu
rrent_context
126 0000005A F7FF FFFE BL rt_trustzone_context_store ; ca
ll TrustZone store
fun
127 0000005E E8BD 4003 LDMFD sp!, {r0-r1, lr} ; pop register
128 00000062
129 00000062 ; check break from TrustZone
130 00000062 4672 MOV r2, lr ; r2 = lr
131 00000064 F012 0F40 TST r2, #0x40 ; if EXC_RETURN[6]
is 1, TrustZone sta
ck was used
132 00000068 D00A BEQ contex_ns_store ; if r2 & 0x40
== 0, goto contex_n
s_store
133 0000006A
134 0000006A ; push PSPLIM CONTROL PSP LR current_context to stack
135 0000006A F3EF 830B MRS r3, psplim ; r3 = psplim
136 0000006E F3EF 8414 MRS r4, control ; r4 = control
137 00000072 F3EF 8509 MRS r5, psp ; r5 = psp
138 00000076 E925 001E STMFD r5!, {r1-r4} ; push to thread s
tack
139 0000007A
140 0000007A ; update from thread stack pointer
141 0000007A 6800 LDR r0, [r0] ; r0 = rt_thread_sw
itch_interrupt_flag
142 0000007C 6005 STR r5, [r0] ; *r0 = r5
143 0000007E E013 b switch_to_thread ; goto switch_
to_thread
144 00000080
145 00000080 contex_ns_store
146 00000080
147 00000080 F3EF 8109 MRS r1, psp ; get from thread s
tack pointer
148 00000084
149 00000084 IF {FPU} != "SoftVFP"
150 00000084 F01E 0F10 TST lr, #0x10 ; if(!EXC_RETURN[4]
)
151 00000088 BF08 ED21
8B10 VSTMFDEQ r1!, {d8 - d15} ; push FPU regi
ster s16~s31
152 0000008E ENDIF
153 0000008E
154 0000008E E921 0FF0 STMFD r1!, {r4 - r11} ; push r4 - r11
register
155 00000092
156 00000092 4A40 LDR r2, =rt_trustzone_current_cont
ext
; r2 = &rt_secure_c
urrent_context
157 00000094 6812 LDR r2, [r2] ; r2 = *r2
158 00000096 4673 MOV r3, lr ; r3 = lr
159 00000098 F3EF 840B MRS r4, psplim ; r4 = psplim
160 0000009C F3EF 8514 MRS r5, control ; r5 = control
161 000000A0 E921 003C STMFD r1!, {r2-r5} ; push to thread s
tack
ARM Macro Assembler Page 5
162 000000A4
163 000000A4 6800 LDR r0, [r0]
164 000000A6 6001 STR r1, [r0] ; update from threa
d stack pointer
165 000000A8
166 000000A8 switch_to_thread
167 000000A8 4938 LDR r1, =rt_interrupt_to_thread
168 000000AA 6809 LDR r1, [r1]
169 000000AC 6809 LDR r1, [r1] ; load thread stack
pointer
170 000000AE
171 000000AE ; update current TrustZone context
172 000000AE C93C LDMFD r1!, {r2-r5} ; pop thread stack
173 000000B0 F384 880B MSR psplim, r4 ; psplim = r4
174 000000B4 F385 8814 MSR control, r5 ; control = r5
175 000000B8 469E MOV lr, r3 ; lr = r3
176 000000BA 4E36 LDR r6, =rt_trustzone_current_cont
ext
; r6 = &rt_secure_c
urrent_context
177 000000BC 6032 STR r2, [r6] ; *r6 = r2
178 000000BE 4610 MOV r0, r2 ; r0 = r2
179 000000C0
180 000000C0 ; Whether TrustZone thread stack exists
181 000000C0 B140 CBZ r0, contex_ns_load ; if r0 == 0
, goto contex_ns_lo
ad
182 000000C2 B40A PUSH {r1, r3} ; push lr, thread_s
tack
183 000000C4 F7FF FFFE BL rt_trustzone_context_load ; cal
l TrustZone load fu
n
184 000000C8 BC0A POP {r1, r3} ; pop lr, thread_st
ack
185 000000CA 469E MOV lr, r3 ; lr = r1
186 000000CC F013 0F40 TST r3, #0x40 ; if EXC_RETURN[6]
is 1, TrustZone sta
ck was used
187 000000D0 D000 BEQ contex_ns_load ; if r1 & 0x40 =
= 0, goto contex_ns
_load
188 000000D2 E006 B pendsv_exit
189 000000D4
190 000000D4 contex_ns_load
191 000000D4 E8B1 0FF0 LDMFD r1!, {r4 - r11} ; pop r4 - r11
register
192 000000D8
193 000000D8 IF {FPU} != "SoftVFP"
194 000000D8 F01E 0F10 TST lr, #0x10 ; if(!EXC_RETURN[4]
)
195 000000DC BF08 ECB1
8B10 VLDMFDEQ r1!, {d8 - d15} ; pop FPU regis
ter s16~s31
196 000000E2 ENDIF
197 000000E2
198 000000E2 pendsv_exit
199 000000E2 F381 8809 MSR psp, r1 ; update stack poin
ter
ARM Macro Assembler Page 6
200 000000E6 ; restore interrupt
201 000000E6 BC04 POP {r2}
202 000000E8 F382 8810 MSR PRIMASK, r2
203 000000EC
204 000000EC 4770 BX lr
205 000000EE ENDP
206 000000EE
207 000000EE ;/*
208 000000EE ; * void rt_hw_context_switch_to(rt_uint32 to);
209 000000EE ; * r0 --> to
210 000000EE ; * this fucntion is used to perform the first thread sw
itch
211 000000EE ; */
212 000000EE rt_hw_context_switch_to
PROC
213 000000EE EXPORT rt_hw_context_switch_to
214 000000EE ; set to thread
215 000000EE 4927 LDR r1, =rt_interrupt_to_thread
216 000000F0 6008 STR r0, [r1]
217 000000F2
218 000000F2 IF {FPU} != "SoftVFP"
219 000000F2 ; CLEAR CONTROL.FPCA
220 000000F2 F3EF 8214 MRS r2, CONTROL ; read
221 000000F6 F022 0204 BIC r2, #0x04 ; modify
222 000000FA F382 8814 MSR CONTROL, r2 ; write-back
223 000000FE ENDIF
224 000000FE
225 000000FE ; set from thread to 0
226 000000FE 4922 LDR r1, =rt_interrupt_from_thread
227 00000100 F04F 0000 MOV r0, #0x0
228 00000104 6008 STR r0, [r1]
229 00000106
230 00000106 ; set interrupt flag to 1
231 00000106 491F LDR r1, =rt_thread_switch_interrupt
_flag
232 00000108 F04F 0001 MOV r0, #1
233 0000010C 6008 STR r0, [r1]
234 0000010E
235 0000010E ; set the PendSV and SysTick exception priority
236 0000010E 4822 LDR r0, =NVIC_SYSPRI2
237 00000110 4922 LDR r1, =NVIC_PENDSV_PRI
238 00000112 F8D0 2000 LDR.W r2, [r0,#0x00] ; read
239 00000116 EA41 0102 ORR r1,r1,r2 ; modify
240 0000011A 6001 STR r1, [r0] ; write-back
241 0000011C
242 0000011C ; trigger the PendSV exception (causes context switch)
243 0000011C 481C LDR r0, =NVIC_INT_CTRL
244 0000011E F04F 5180 LDR r1, =NVIC_PENDSVSET
245 00000122 6001 STR r1, [r0]
246 00000124
247 00000124 ; restore MSP
248 00000124 481E LDR r0, =SCB_VTOR
249 00000126 6800 LDR r0, [r0]
250 00000128 6800 LDR r0, [r0]
251 0000012A F380 8808 MSR msp, r0
252 0000012E
253 0000012E ; enable interrupts at processor level
254 0000012E B661 CPSIE F
255 00000130 B662 CPSIE I
ARM Macro Assembler Page 7
256 00000132
257 00000132 ; ensure PendSV exception taken place before subsequent
operation
258 00000132 F3BF 8F4F DSB
259 00000136 F3BF 8F6F ISB
260 0000013A
261 0000013A ; never reach here!
262 0000013A ENDP
263 0000013A
264 0000013A ; compatible with old version
265 0000013A rt_hw_interrupt_thread_switch
PROC
266 0000013A EXPORT rt_hw_interrupt_thread_switch
267 0000013A 4770 BX lr
268 0000013C ENDP
269 0000013C
270 0000013C IMPORT rt_hw_hard_fault_exception
271 0000013C EXPORT HardFault_Handler
272 0000013C HardFault_Handler
PROC
273 0000013C
274 0000013C ; get current context
275 0000013C F3EF 8008 MRS r0, msp ;get fault context
from handler
276 00000140 F01E 0F04 TST lr, #0x04 ;if(!EXC_RETURN[2])
277 00000144 D001 BEQ get_sp_done
278 00000146 F3EF 8009 MRS r0, psp ;get fault context
from thread
279 0000014A get_sp_done
280 0000014A
281 0000014A E920 0FF0 STMFD r0!, {r4 - r11} ; push r4 - r11
register
282 0000014E
283 0000014E 4A11 LDR r2, =rt_trustzone_current_cont
ext
; r2 = &rt_secure_c
urrent_context
284 00000150 6812 LDR r2, [r2] ; r2 = *r2
285 00000152 4673 MOV r3, lr ; r3 = lr
286 00000154 F3EF 840B MRS r4, psplim ; r4 = psplim
287 00000158 F3EF 8514 MRS r5, control ; r5 = control
288 0000015C E920 003C STMFD r0!, {r2-r5} ; push to thread s
tack
289 00000160
290 00000160 F840 ED04 STMFD r0!, {lr} ; push exec_return
register
291 00000164
292 00000164 F01E 0F04 TST lr, #0x04 ; if(!EXC_RETURN[2]
)
293 00000168 D002 BEQ update_msp
294 0000016A F380 8809 MSR psp, r0 ; update stack poin
ter to PSP
295 0000016E E001 B update_done
296 00000170 update_msp
297 00000170 F380 8808 MSR msp, r0 ; update stack poin
ter to MSP
298 00000174 update_done
299 00000174
ARM Macro Assembler Page 8
300 00000174 B500 PUSH {lr}
301 00000176 F7FF FFFE BL rt_hw_hard_fault_exception
302 0000017A F85D EB04 POP {lr}
303 0000017E
304 0000017E F04E 0E04 ORR lr, lr, #0x04
305 00000182 4770 BX lr
306 00000184 ENDP
307 00000184
308 00000184 ALIGN 4
309 00000184
310 00000184 END
00000000
00000000
00000000
E000ED04
00000000
E000ED20
FFFF0000
E000ED08
Command Line: --debug --xref --diag_suppress=9931 --cpu=Cortex-M33 --fpu=FPv5-S
P --depend=.\build\keil\obj\context_rvds.d -o.\build\keil\obj\context_rvds.o -I
D:\1_tool_prog\2_MDK\pack\Keil\STM32H5xx_DFP\1.1.0\Drivers\CMSIS\Device\ST\STM3
2H5xx\Include --predefine="__UVISION_VERSION SETA 536" --predefine="STM32H563xx
SETA 1" --list=context_rvds.lst ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
ARM Macro Assembler Page 1 Alphabetic symbol ordering
Relocatable symbols
.text 00000000
Symbol: .text
Definitions
At line 26 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
None
Comment: .text unused
HardFault_Handler 0000013C
Symbol: HardFault_Handler
Definitions
At line 272 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 271 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: HardFault_Handler used once
PendSV_Handler 0000002E
Symbol: PendSV_Handler
Definitions
At line 91 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 92 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: PendSV_Handler used once
_reswitch 00000020
Symbol: _reswitch
Definitions
At line 78 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 71 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: _reswitch used once
contex_ns_load 000000D4
Symbol: contex_ns_load
Definitions
At line 190 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 181 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 187 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
contex_ns_store 00000080
Symbol: contex_ns_store
Definitions
At line 145 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 121 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 132 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
get_sp_done 0000014A
Symbol: get_sp_done
Definitions
At line 279 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 277 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: get_sp_done used once
pendsv_exit 000000E2
ARM Macro Assembler Page 2 Alphabetic symbol ordering
Relocatable symbols
Symbol: pendsv_exit
Definitions
At line 198 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 188 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: pendsv_exit used once
rt_hw_context_switch 0000000E
Symbol: rt_hw_context_switch
Definitions
At line 64 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 65 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_context_switch used once
rt_hw_context_switch_interrupt 0000000E
Symbol: rt_hw_context_switch_interrupt
Definitions
At line 62 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 63 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_context_switch_interrupt used once
rt_hw_context_switch_to 000000EE
Symbol: rt_hw_context_switch_to
Definitions
At line 212 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 213 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_context_switch_to used once
rt_hw_interrupt_disable 00000000
Symbol: rt_hw_interrupt_disable
Definitions
At line 41 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 42 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_interrupt_disable used once
rt_hw_interrupt_enable 00000008
Symbol: rt_hw_interrupt_enable
Definitions
At line 51 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 52 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_interrupt_enable used once
rt_hw_interrupt_thread_switch 0000013A
Symbol: rt_hw_interrupt_thread_switch
Definitions
At line 265 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 266 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_interrupt_thread_switch used once
schedule 00000042
Symbol: schedule
Definitions
ARM Macro Assembler Page 3 Alphabetic symbol ordering
Relocatable symbols
At line 106 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 102 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: schedule used once
switch_to_thread 000000A8
Symbol: switch_to_thread
Definitions
At line 166 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 116 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 143 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
update_done 00000174
Symbol: update_done
Definitions
At line 298 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 295 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: update_done used once
update_msp 00000170
Symbol: update_msp
Definitions
At line 296 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 293 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: update_msp used once
18 symbols
ARM Macro Assembler Page 1 Alphabetic symbol ordering
Absolute symbols
NVIC_INT_CTRL E000ED04
Symbol: NVIC_INT_CTRL
Definitions
At line 21 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 82 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 243 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
NVIC_PENDSVSET 10000000
Symbol: NVIC_PENDSVSET
Definitions
At line 24 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 83 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 244 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
NVIC_PENDSV_PRI FFFF0000
Symbol: NVIC_PENDSV_PRI
Definitions
At line 23 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 237 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: NVIC_PENDSV_PRI used once
NVIC_SYSPRI2 E000ED20
Symbol: NVIC_SYSPRI2
Definitions
At line 22 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 236 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: NVIC_SYSPRI2 used once
SCB_VTOR E000ED08
Symbol: SCB_VTOR
Definitions
At line 20 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 248 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: SCB_VTOR used once
5 symbols
ARM Macro Assembler Page 1 Alphabetic symbol ordering
External symbols
rt_hw_hard_fault_exception 00000000
Symbol: rt_hw_hard_fault_exception
Definitions
At line 270 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 301 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_hw_hard_fault_exception used once
rt_interrupt_from_thread 00000000
Symbol: rt_interrupt_from_thread
Definitions
At line 32 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 75 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 114 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 226 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
rt_interrupt_to_thread 00000000
Symbol: rt_interrupt_to_thread
Definitions
At line 33 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 79 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 167 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 215 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
rt_thread_switch_interrupt_flag 00000000
Symbol: rt_thread_switch_interrupt_flag
Definitions
At line 31 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 68 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 99 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 231 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
rt_trustzone_context_load 00000000
Symbol: rt_trustzone_context_load
Definitions
At line 35 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 183 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_trustzone_context_load used once
rt_trustzone_context_store 00000000
Symbol: rt_trustzone_context_store
Definitions
At line 36 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Uses
At line 126 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
Comment: rt_trustzone_context_store used once
rt_trustzone_current_context 00000000
Symbol: rt_trustzone_current_context
Definitions
At line 34 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
ARM Macro Assembler Page 2 Alphabetic symbol ordering
External symbols
Uses
At line 119 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 156 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 176 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
At line 283 in file ..\..\..\libcpu\arm\cortex-m33\context_rvds.S
7 symbols
365 symbols in table