mirror of
https://github.com/FreeRTOS/FreeRTOS-Kernel.git
synced 2025-04-19 21:11:57 -04:00
Continue 78K0R development.
This commit is contained in:
parent
299557fed2
commit
bfd67da1e7
99
Source/portable/IAR/78K0R/ISR_Support.h
Normal file
99
Source/portable/IAR/78K0R/ISR_Support.h
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
; FreeRTOS.org V5.1.1 - Copyright (C) 2003-2008 Richard Barry.
|
||||||
|
;
|
||||||
|
; This file is part of the FreeRTOS.org distribution.
|
||||||
|
;
|
||||||
|
; FreeRTOS.org is free software; you can redistribute it and/or modify
|
||||||
|
; it under the terms of the GNU General Public License as published by
|
||||||
|
; the Free Software Foundation; either version 2 of the License, or
|
||||||
|
; (at your option) any later version.
|
||||||
|
;
|
||||||
|
; FreeRTOS.org is distributed in the hope that it will be useful,
|
||||||
|
; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
; GNU General Public License for more details.
|
||||||
|
;
|
||||||
|
; You should have received a copy of the GNU General Public License
|
||||||
|
; along with FreeRTOS.org; if not, write to the Free Software
|
||||||
|
; Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
;
|
||||||
|
; A special exception to the GPL can be applied should you wish to distribute
|
||||||
|
; a combined work that includes FreeRTOS.org, without being obliged to provide
|
||||||
|
; the source code for any proprietary components. See the licensing section
|
||||||
|
; of http://www.FreeRTOS.org for full details of how and when the exception
|
||||||
|
; can be applied.
|
||||||
|
;
|
||||||
|
; ***************************************************************************
|
||||||
|
; See http://www.FreeRTOS.org for documentation, latest information, license
|
||||||
|
; and contact details. Please ensure to read the configuration and relevant
|
||||||
|
; port sections of the online documentation.
|
||||||
|
; ***************************************************************************
|
||||||
|
;
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "FreeRTOSConfig.h"
|
||||||
|
|
||||||
|
; Variables used by scheduler
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
EXTERN pxCurrentTCB
|
||||||
|
EXTERN usCriticalNesting
|
||||||
|
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
; portSAVE_CONTEXT MACRO
|
||||||
|
; Saves the context of the remaining general purpose registers, CS and ES
|
||||||
|
; (only in far memory mode) registers
|
||||||
|
; the usCriticalNesting Value and the Stack Pointer
|
||||||
|
; of the active Task onto the task stack
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
portSAVE_CONTEXT MACRO
|
||||||
|
|
||||||
|
PUSH AX ; save AX Register to stack
|
||||||
|
PUSH HL
|
||||||
|
#if configMEMORY_MODE == 1
|
||||||
|
MOV A, CS ; save CS register
|
||||||
|
XCH A, X
|
||||||
|
MOV A, ES ; save ES register
|
||||||
|
PUSH AX
|
||||||
|
#else
|
||||||
|
MOV A, CS ; save CS register
|
||||||
|
PUSH AX
|
||||||
|
#endif
|
||||||
|
PUSH DE ; save the remaining general purpose registers
|
||||||
|
PUSH BC
|
||||||
|
MOVW AX, usCriticalNesting ; save the usCriticalNesting value
|
||||||
|
PUSH AX
|
||||||
|
MOVW AX, pxCurrentTCB ; save the Stack pointer
|
||||||
|
MOVW HL, AX
|
||||||
|
MOVW AX, SP
|
||||||
|
MOVW [HL], AX
|
||||||
|
ENDM
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
; portRESTORE_CONTEXT MACRO
|
||||||
|
; Restores the context of the Stack Pointer, usCriticalNesting
|
||||||
|
; value, general purpose registers and the CS and ES (only in far memory mode)
|
||||||
|
; of the selected task from the task stack
|
||||||
|
;------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
portRESTORE_CONTEXT MACRO
|
||||||
|
MOVW AX, pxCurrentTCB ; restore the Stack pointer
|
||||||
|
MOVW HL, AX
|
||||||
|
MOVW AX, [HL]
|
||||||
|
MOVW SP, AX
|
||||||
|
POP AX ; restore usCriticalNesting value
|
||||||
|
MOVW usCriticalNesting, AX
|
||||||
|
POP BC ; restore the necessary general purpose registers
|
||||||
|
POP DE
|
||||||
|
#if configMEMORY_MODE == 1
|
||||||
|
POP AX ; restore the ES register
|
||||||
|
MOV ES, A
|
||||||
|
XCH A, X ; restore the CS register
|
||||||
|
MOV CS, A
|
||||||
|
#else
|
||||||
|
POP AX
|
||||||
|
MOV CS, A ; restore CS register
|
||||||
|
#endif
|
||||||
|
POP HL ; restore general purpose register HL
|
||||||
|
POP AX ; restore AX
|
||||||
|
ENDM
|
||||||
|
;------------------------------------------------------------------------------
|
|
@ -29,8 +29,7 @@
|
||||||
; ***************************************************************************
|
; ***************************************************************************
|
||||||
;
|
;
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
; Note: Select the correct include files for the device used by the application.
|
#include "ISR_Support.h"
|
||||||
#include "FreeRTOSConfig.h"
|
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
|
|
||||||
#if __CORE__ != __78K0R__
|
#if __CORE__ != __78K0R__
|
||||||
|
@ -51,12 +50,6 @@
|
||||||
EXTERN vTaskSwitchContext
|
EXTERN vTaskSwitchContext
|
||||||
EXTERN vTaskIncrementTick
|
EXTERN vTaskIncrementTick
|
||||||
|
|
||||||
; Variables used by scheduler
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
EXTERN pxCurrentTCB
|
|
||||||
EXTERN usCriticalNesting
|
|
||||||
|
|
||||||
|
|
||||||
; Tick ISR Prototype
|
; Tick ISR Prototype
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
EXTERN ?CL78K0R_V2_L00
|
EXTERN ?CL78K0R_V2_L00
|
||||||
|
@ -68,66 +61,6 @@ MD_INTTM05 SYMBOL "MD_INTTM05"
|
||||||
`??MD_INTTM05??INTVEC 68` SYMBOL "??INTVEC 68", MD_INTTM05
|
`??MD_INTTM05??INTVEC 68` SYMBOL "??INTVEC 68", MD_INTTM05
|
||||||
|
|
||||||
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
; portSAVE_CONTEXT MACRO
|
|
||||||
; Saves the context of the remaining general purpose registers, CS and ES
|
|
||||||
; (only in far memory mode) registers
|
|
||||||
; the usCriticalNesting Value and the Stack Pointer
|
|
||||||
; of the active Task onto the task stack
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
portSAVE_CONTEXT MACRO
|
|
||||||
|
|
||||||
PUSH AX ; save AX Register to stack
|
|
||||||
PUSH HL
|
|
||||||
#if configMEMORY_MODE == 1
|
|
||||||
MOV A, CS ; save CS register
|
|
||||||
XCH A, X
|
|
||||||
MOV A, ES ; save ES register
|
|
||||||
PUSH AX
|
|
||||||
#else
|
|
||||||
MOV A, CS ; save CS register
|
|
||||||
PUSH AX
|
|
||||||
#endif
|
|
||||||
PUSH DE ; save the remaining general purpose registers
|
|
||||||
PUSH BC
|
|
||||||
MOVW AX, usCriticalNesting ; save the usCriticalNesting value
|
|
||||||
PUSH AX
|
|
||||||
MOVW AX, pxCurrentTCB ; save the Stack pointer
|
|
||||||
MOVW HL, AX
|
|
||||||
MOVW AX, SP
|
|
||||||
MOVW [HL], AX
|
|
||||||
ENDM
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
; portRESTORE_CONTEXT MACRO
|
|
||||||
; Restores the context of the Stack Pointer, usCriticalNesting
|
|
||||||
; value, general purpose registers and the CS and ES (only in far memory mode)
|
|
||||||
; of the selected task from the task stack
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
portRESTORE_CONTEXT MACRO
|
|
||||||
MOVW AX, pxCurrentTCB ; restore the Stack pointer
|
|
||||||
MOVW HL, AX
|
|
||||||
MOVW AX, [HL]
|
|
||||||
MOVW SP, AX
|
|
||||||
POP AX ; restore usCriticalNesting value
|
|
||||||
MOVW usCriticalNesting, AX
|
|
||||||
POP BC ; restore the necessary general purpose registers
|
|
||||||
POP DE
|
|
||||||
#if configMEMORY_MODE == 1
|
|
||||||
POP AX ; restore the ES register
|
|
||||||
MOV ES, A
|
|
||||||
XCH A, X ; restore the CS register
|
|
||||||
MOV CS, A
|
|
||||||
#else
|
|
||||||
POP AX
|
|
||||||
MOV CS, A ; restore CS register
|
|
||||||
#endif
|
|
||||||
POP HL ; restore general purpose register HL
|
|
||||||
POP AX ; restore AX
|
|
||||||
ENDM
|
|
||||||
;------------------------------------------------------------------------------
|
|
||||||
|
|
||||||
;------------------------------------------------------------------------------
|
;------------------------------------------------------------------------------
|
||||||
; Port Yield function to check for a Task switch in the cooperative mode
|
; Port Yield function to check for a Task switch in the cooperative mode
|
||||||
|
|
|
@ -124,9 +124,8 @@ extern volatile unsigned portSHORT usCriticalNesting; \
|
||||||
|
|
||||||
/* Task utilities. */
|
/* Task utilities. */
|
||||||
extern void vPortStart( void );
|
extern void vPortStart( void );
|
||||||
extern void portSAVE_CONTEXT( void );
|
|
||||||
extern void portRESTORE_CONTEXT( void );
|
|
||||||
#define portYIELD() __asm( "BRK" )
|
#define portYIELD() __asm( "BRK" )
|
||||||
|
#define portYIELD_FROM_ISR( xHigherPriorityTaskWoken ) if( xHigherPriorityTaskWoken ) vTaskSwitchContext()
|
||||||
#define portNOP() __asm( "NOP" )
|
#define portNOP() __asm( "NOP" )
|
||||||
/*-----------------------------------------------------------*/
|
/*-----------------------------------------------------------*/
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue