| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309 |
- /*----------------------------------------------------------------------------
- * CMSIS-RTOS - RTX
- *----------------------------------------------------------------------------
- * Name: HAL_CM4.C
- * Purpose: Hardware Abstraction Layer for Cortex-M4
- * Rev.: V4.79
- *----------------------------------------------------------------------------
- *
- * Copyright (c) 1999-2009 KEIL, 2009-2017 ARM Germany GmbH. All rights reserved.
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Licensed under the Apache License, Version 2.0 (the License); you may
- * not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an AS IS BASIS, WITHOUT
- * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- *---------------------------------------------------------------------------*/
- #include "rt_TypeDef.h"
- #include "RTX_Config.h"
- #include "rt_System.h"
- #include "rt_HAL_CM.h"
- #include "rt_Task.h"
- #include "rt_MemBox.h"
- /*----------------------------------------------------------------------------
- * Functions
- *---------------------------------------------------------------------------*/
- /*--------------------------- rt_set_PSP ------------------------------------*/
- __asm void rt_set_PSP (U32 stack) {
- MSR PSP,R0
- BX LR
- }
- /*--------------------------- rt_get_PSP ------------------------------------*/
- __asm U32 rt_get_PSP (void) {
- MRS R0,PSP
- BX LR
- }
- /*--------------------------- os_set_env ------------------------------------*/
- __asm void os_set_env (void) {
- /* Switch to Unprivileged/Privileged Thread mode, use PSP. */
- MOV R0,SP ; PSP = MSP
- MSR PSP,R0
- LDR R0,=__cpp(&os_flags)
- LDRB R0,[R0]
- LSLS R0,#31
- MOVNE R0,#0x02 ; Privileged Thread mode, use PSP
- MOVEQ R0,#0x03 ; Unprivileged Thread mode, use PSP
- MSR CONTROL,R0
- BX LR
- ALIGN
- }
- /*--------------------------- _alloc_box ------------------------------------*/
- __asm void *_alloc_box (void *box_mem) {
- /* Function wrapper for Unprivileged/Privileged mode. */
- LDR R12,=__cpp(rt_alloc_box)
- MRS R3,IPSR
- LSLS R3,#24
- BXNE R12
- MRS R3,CONTROL
- LSLS R3,#31
- BXEQ R12
- SVC 0
- BX LR
- ALIGN
- }
- /*--------------------------- _free_box -------------------------------------*/
- __asm U32 _free_box (void *box_mem, void *box) {
- /* Function wrapper for Unprivileged/Privileged mode. */
- LDR R12,=__cpp(rt_free_box)
- MRS R3,IPSR
- LSLS R3,#24
- BXNE R12
- MRS R3,CONTROL
- LSLS R3,#31
- BXEQ R12
- SVC 0
- BX LR
- ALIGN
- }
- /*-------------------------- SVC_Handler ------------------------------------*/
- __asm void SVC_Handler (void) {
- PRESERVE8
- IMPORT SVC_Count
- IMPORT SVC_Table
- IMPORT rt_stk_check
- #ifdef IFX_XMC4XXX
- EXPORT SVC_Handler_Veneer
- SVC_Handler_Veneer
- #endif
- MRS R0,PSP ; Read PSP
- LDR R1,[R0,#24] ; Read Saved PC from Stack
- LDRB R1,[R1,#-2] ; Load SVC Number
- CBNZ R1,SVC_User
- LDM R0,{R0-R3,R12} ; Read R0-R3,R12 from stack
- PUSH {R4,LR} ; Save EXC_RETURN
- BLX R12 ; Call SVC Function
- POP {R4,LR} ; Restore EXC_RETURN
- MRS R12,PSP ; Read PSP
- STM R12,{R0-R2} ; Store return values
- LDR R3,=__cpp(&os_tsk)
- LDM R3,{R1,R2} ; os_tsk.run, os_tsk.next
- CMP R1,R2
- #ifdef IFX_XMC4XXX
- PUSHEQ {LR}
- POPEQ {PC}
- #else
- BXEQ LR ; RETI, no task switch
- #endif
- CBNZ R1,SVC_ContextSave ; Runtask not deleted?
- TST LR,#0x10 ; is it extended frame?
- BNE SVC_ContextRestore
- LDR R1,=0xE000EF34
- LDR R0,[R1] ; Load FPCCR
- BIC R0,#1 ; Clear LSPACT (Lazy state)
- STR R0,[R1] ; Store FPCCR
- B SVC_ContextRestore
- SVC_ContextSave
- TST LR,#0x10 ; is it extended frame?
- VSTMDBEQ R12!,{S16-S31} ; yes, stack also VFP hi-regs
- MOVEQ R0,#0x01 ; os_tsk->stack_frame val
- MOVNE R0,#0x00
- STRB R0,[R1,#TCB_STACKF] ; os_tsk.run->stack_frame = val
- STMDB R12!,{R4-R11} ; Save Old context
- STR R12,[R1,#TCB_TSTACK] ; Update os_tsk.run->tsk_stack
- PUSH {R2,R3}
- BL rt_stk_check ; Check for Stack overflow
- POP {R2,R3}
- SVC_ContextRestore
- STR R2,[R3] ; os_tsk.run = os_tsk.next
- LDR R12,[R2,#TCB_TSTACK] ; os_tsk.next->tsk_stack
- LDMIA R12!,{R4-R11} ; Restore New Context
- LDRB R0,[R2,#TCB_STACKF] ; Stack Frame
- CMP R0,#0 ; Basic/Extended Stack Frame
- MVNEQ LR,#:NOT:0xFFFFFFFD ; set EXC_RETURN value
- MVNNE LR,#:NOT:0xFFFFFFED
- VLDMIANE R12!,{S16-S31} ; restore VFP hi-registers
- MSR PSP,R12 ; Write PSP
- SVC_Exit
- #ifdef IFX_XMC4XXX
- PUSH {LR}
- POP {PC}
- #else
- BX LR
- #endif
- /*------------------- User SVC ------------------------------*/
- SVC_User
- PUSH {R4,LR} ; Save Registers
- LDR R2,=SVC_Count
- LDR R2,[R2]
- CMP R1,R2
- BHI SVC_Done ; Overflow
- LDR R4,=SVC_Table-4
- LDR R4,[R4,R1,LSL #2] ; Load SVC Function Address
- LDM R0,{R0-R3,R12} ; Read R0-R3,R12 from stack
- BLX R4 ; Call SVC Function
- MRS R12,PSP
- STM R12,{R0-R3} ; Function return values
- SVC_Done
- POP {R4,PC} ; RETI
- ALIGN
- }
- /*-------------------------- PendSV_Handler ---------------------------------*/
- __asm void PendSV_Handler (void) {
- PRESERVE8
- #ifdef IFX_XMC4XXX
- EXPORT PendSV_Handler_Veneer
- PendSV_Handler_Veneer
- #endif
- PUSH {R4,LR} ; Save EXC_RETURN
- BL __cpp(rt_pop_req)
- Sys_Switch
- POP {R4,LR} ; Restore EXC_RETURN
- LDR R3,=__cpp(&os_tsk)
- LDM R3,{R1,R2} ; os_tsk.run, os_tsk.next
- CMP R1,R2
- #ifdef IFX_XMC4XXX
- PUSHEQ {LR}
- POPEQ {PC}
- #else
- BXEQ LR ; RETI, no task switch
- #endif
- MRS R12,PSP ; Read PSP
- TST LR,#0x10 ; is it extended frame?
- VSTMDBEQ R12!,{S16-S31} ; yes, stack also VFP hi-regs
- MOVEQ R0,#0x01 ; os_tsk->stack_frame val
- MOVNE R0,#0x00
- STRB R0,[R1,#TCB_STACKF] ; os_tsk.run->stack_frame = val
- STMDB R12!,{R4-R11} ; Save Old context
- STR R12,[R1,#TCB_TSTACK] ; Update os_tsk.run->tsk_stack
- PUSH {R2,R3}
- BL rt_stk_check ; Check for Stack overflow
- POP {R2,R3}
- STR R2,[R3] ; os_tsk.run = os_tsk.next
- LDR R12,[R2,#TCB_TSTACK] ; os_tsk.next->tsk_stack
- LDMIA R12!,{R4-R11} ; Restore New Context
- LDRB R0,[R2,#TCB_STACKF] ; Stack Frame
- CMP R0,#0 ; Basic/Extended Stack Frame
- MVNEQ LR,#:NOT:0xFFFFFFFD ; set EXC_RETURN value
- MVNNE LR,#:NOT:0xFFFFFFED
- VLDMIANE R12!,{S16-S31} ; restore VFP hi-regs
- MSR PSP,R12 ; Write PSP
- Sys_Exit
- #ifdef IFX_XMC4XXX
- PUSH {LR}
- POP {PC}
- #else
- BX LR ; Return to Thread Mode
- #endif
- ALIGN
- }
- /*-------------------------- SysTick_Handler --------------------------------*/
- __asm void SysTick_Handler (void) {
- PRESERVE8
- #ifdef IFX_XMC4XXX
- EXPORT SysTick_Handler_Veneer
- SysTick_Handler_Veneer
- #endif
- PUSH {R4,LR} ; Save EXC_RETURN
- BL __cpp(rt_systick)
- B Sys_Switch
- ALIGN
- }
- /*-------------------------- OS_Tick_Handler --------------------------------*/
- __asm void OS_Tick_Handler (void) {
- PRESERVE8
- PUSH {R4,LR} ; Save EXC_RETURN
- BL __cpp(os_tick_irqack)
- BL __cpp(rt_systick)
- B Sys_Switch
- ALIGN
- }
- /*----------------------------------------------------------------------------
- * end of file
- *---------------------------------------------------------------------------*/
|