;******************************************************************************************************** ; 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 ; ; V850E2S ; IAR compiler for V850 ; ; Filename : cpu_a.s85 ; Version : V1.32.01 ;******************************************************************************************************** ;******************************************************************************************************** ; PUBLIC FUNCTIONS ;******************************************************************************************************** PUBLIC CPU_SR_Save PUBLIC CPU_SR_Restore PUBLIC CPU_IntDis PUBLIC CPU_IntEn PUBLIC CPU_EIIC_Rd ;******************************************************************************************************** ; EQUATES ;******************************************************************************************************** PSW EQU 5 EIIC EQU 13 ;******************************************************************************************************** ; CODE GENERATION DIRECTIVES ;******************************************************************************************************** RSEG CODE:CODE:NOROOT(2) ;******************************************************************************************************** ; 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) : (1) 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: stsr PSW, r1 ; Store PSW di jmp [lp] CPU_SR_Restore: ldsr r1 , PSW jmp [lp] ;******************************************************************************************************** ; DISABLE and ENABLE INTERRUPTS ; ; Description: Disable/Enable interrupts. ; ; Prototypes : void CPU_IntDis(void); ; void CPU_IntEn (void); ;******************************************************************************************************** CPU_IntDis: di jmp [lp] CPU_IntEn: ei jmp [lp] ;******************************************************************************************************** ; READS CPU EXCEPTION CAUSE REGISTER ; ; Description : Reads CPU EI level exception code register(EIIC), which retains the cause of any EI level ; exception that occurs. ; ; Prototypes : CPU_DATA CPU_EIIC_Rd (void); ; ; Note(s) : None. ; ;******************************************************************************************************** CPU_EIIC_Rd: stsr EIIC, r1 jmp [lp] ;******************************************************************************************************** ; CPU ASSEMBLY PORT FILE END ;******************************************************************************************************** END