112 lines
4.5 KiB
Plaintext
112 lines
4.5 KiB
Plaintext
;********************************************************************************************************
|
|
; 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
|
|
;
|
|
; M16C
|
|
; Renesas HEW w/NC30 C Compiler
|
|
;
|
|
; Filename : cpu_a.a30
|
|
; Version : V1.32.01
|
|
;********************************************************************************************************
|
|
|
|
|
|
;********************************************************************************************************
|
|
; EQUATES
|
|
;********************************************************************************************************
|
|
|
|
|
|
;********************************************************************************************************
|
|
; CODE GENERATION DIRECTIVES
|
|
;********************************************************************************************************
|
|
|
|
|
|
;********************************************************************************************************
|
|
; PUBLIC FUNCTIONS
|
|
;********************************************************************************************************
|
|
|
|
|
|
;*********************************************************************************************************
|
|
; DISABLE and ENABLE INTERRUPTS
|
|
;
|
|
; Description : Disable/Enable interrupts.
|
|
;
|
|
; Prototypes : void CPU_IntDis(void);
|
|
; void CPU_IntEn (void);
|
|
;*********************************************************************************************************
|
|
|
|
.SECTION program
|
|
.GLB _CPU_IntDis
|
|
_CPU_IntDis:
|
|
FCLR I
|
|
RTS
|
|
|
|
|
|
.SECTION program
|
|
.GLB _CPU_IntEn
|
|
_CPU_IntEn:
|
|
FSET I
|
|
RTS
|
|
|
|
|
|
;*********************************************************************************************************
|
|
; CRITICAL SECTION FUNCTIONS
|
|
;
|
|
; Description : Disable/Enable interrupts by preserving the state of interrupts. Generally speaking, the
|
|
; state of the interrupt disable 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 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); */
|
|
; :
|
|
; }
|
|
;*********************************************************************************************************
|
|
|
|
.SECTION program
|
|
.GLB _CPU_SR_Save
|
|
_CPU_SR_Save:
|
|
STC FLG, R0
|
|
FCLR I
|
|
RTS
|
|
|
|
|
|
.SECTION program
|
|
.GLB _CPU_SR_Restore
|
|
|
|
_CPU_SR_Restore:
|
|
LDC R0, FLG
|
|
RTS
|
|
|
|
|
|
;********************************************************************************************************
|
|
; CPU ASSEMBLY PORT FILE END
|
|
;********************************************************************************************************
|
|
|
|
.END
|