|
@@ -18,7 +18,7 @@
|
|
SCB_VTOR EQU 0xE000ED08 ; Vector Table Offset Register
|
|
SCB_VTOR EQU 0xE000ED08 ; Vector Table Offset Register
|
|
NVIC_INT_CTRL EQU 0xE000ED04 ; interrupt control state register
|
|
NVIC_INT_CTRL EQU 0xE000ED04 ; interrupt control state register
|
|
NVIC_SYSPRI2 EQU 0xE000ED20 ; system priority register (2)
|
|
NVIC_SYSPRI2 EQU 0xE000ED20 ; system priority register (2)
|
|
-NVIC_PENDSV_PRI EQU 0x00FF0000 ; PendSV priority value (lowest)
|
|
|
|
|
|
+NVIC_PENDSV_PRI EQU 0xFFFF0000 ; PendSV and SysTick priority value (lowest)
|
|
NVIC_PENDSVSET EQU 0x10000000 ; value to trigger PendSV exception
|
|
NVIC_PENDSVSET EQU 0x10000000 ; value to trigger PendSV exception
|
|
|
|
|
|
AREA |.text|, CODE, READONLY, ALIGN=2
|
|
AREA |.text|, CODE, READONLY, ALIGN=2
|
|
@@ -145,7 +145,7 @@ rt_hw_context_switch_to PROC
|
|
MOV r0, #1
|
|
MOV r0, #1
|
|
STR r0, [r1]
|
|
STR r0, [r1]
|
|
|
|
|
|
- ; set the PendSV exception priority
|
|
|
|
|
|
+ ; set the PendSV and SysTick exception priority
|
|
LDR r0, =NVIC_SYSPRI2
|
|
LDR r0, =NVIC_SYSPRI2
|
|
LDR r1, =NVIC_PENDSV_PRI
|
|
LDR r1, =NVIC_PENDSV_PRI
|
|
LDR.W r2, [r0,#0x00] ; read
|
|
LDR.W r2, [r0,#0x00] ; read
|