bs_bcu_app/system/uC-OS3/uC-CPU/LatticeMico32/GNU/cpu_a.s

95 lines
3.7 KiB
ArmAsm
Raw Normal View History

2024-11-07 17:24:19 +08:00
/*
*********************************************************************************************************
* uC/CPU
* CPU CONFIGURATION & PORT LAYER
*
* Copyright 2004-2021 Silicon Laboratories Inc. www.silabs.com
*
* SPDX-License-Identifier: APACHE-2.0
*
* This software is subject to an open source license and is distributed by
* Silicon Laboratories Inc. pursuant to the terms of the Apache License,
* Version 2.0 available at www.apache.org/licenses/LICENSE-2.0.
*
*********************************************************************************************************
*/
/*
*********************************************************************************************************
*
* CPU PORT FILE
*
* LatticeMico32
* GNU C/C++ Compiler
*
* Filename : cpu_a.s
* Version : V1.32.01
*********************************************************************************************************
*/
/*
*********************************************************************************************************
* PUBLIC FUNCTIONS
*********************************************************************************************************
*/
.global CPU_SR_Save
.global CPU_SR_Restore
/*
*********************************************************************************************************
* CODE GENERATION DIRECTIVES
*********************************************************************************************************
*/
.text
/*
*********************************************************************************************************
* SAVE/RESTORE CPU STATUS REGISTER
*
* Description : Save/Restore the state of CPU interrupts, if possible.
*
* (1) (c) For CPU_CRITICAL_METHOD_STATUS_LOCAL, the state of the interrupt status flag is
* stored in the local variable 'cpu_sr' & interrupts are then disabled ('cpu_sr' is
* allocated in all functions that need to disable interrupts). The previous interrupt
* status state is restored by copying 'cpu_sr' into the CPU's status register.
*
*
* Prototypes : CPU_SR CPU_SR_Save (void);
* void CPU_SR_Restore(CPU_SR cpu_sr);
*
* Note(s) : (2) These functions are used in general like this :
*
* void Task (void *p_arg)
* {
* CPU_SR_ALLOC(); /* Allocate storage for CPU status register */
* :
* :
* CPU_CRITICAL_ENTER(); /* cpu_sr = CPU_SR_Save(); */
* :
* :
* CPU_CRITICAL_EXIT(); /* CPU_SR_Restore(cpu_sr); */
* :
* }
*********************************************************************************************************
*/
CPU_SR_Save:
rcsr r1, ie
wcsr ie, r0
ret
CPU_SR_Restore:
wcsr ie, r1
ret
/*
*********************************************************************************************************
* CPU ASSEMBLY PORT FILE END
*********************************************************************************************************
*/