OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Source/] [portable/] [IAR/] [78K0R/] [ISR_Support.h] - Blame information for rev 609

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 572 jeremybenn
;/*
2
;    FreeRTOS V6.1.1 - Copyright (C) 2011 Real Time Engineers Ltd.
3
;
4
;    ***************************************************************************
5
;    *                                                                         *
6
;    * If you are:                                                             *
7
;    *                                                                         *
8
;    *    + New to FreeRTOS,                                                   *
9
;    *    + Wanting to learn FreeRTOS or multitasking in general quickly       *
10
;    *    + Looking for basic training,                                        *
11
;    *    + Wanting to improve your FreeRTOS skills and productivity           *
12
;    *                                                                         *
13
;    * then take a look at the FreeRTOS books - available as PDF or paperback  *
14
;    *                                                                         *
15
;    *        "Using the FreeRTOS Real Time Kernel - a Practical Guide"        *
16
;    *                  http://www.FreeRTOS.org/Documentation                  *
17
;    *                                                                         *
18
;    * A pdf reference manual is also available.  Both are usually delivered   *
19
;    * to your inbox within 20 minutes to two hours when purchased between 8am *
20
;    * and 8pm GMT (although please allow up to 24 hours in case of            *
21
;    * exceptional circumstances).  Thank you for your support!                *
22
;    *                                                                         *
23
;    ***************************************************************************
24
;
25
;    This file is part of the FreeRTOS distribution.
26
;
27
;    FreeRTOS is free software; you can redistribute it and/or modify it under
28
;    the terms of the GNU General Public License (version 2) as published by the
29
;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.
30
;    ***NOTE*** The exception to the GPL is included to allow you to distribute
31
;    a combined work that includes FreeRTOS without being obliged to provide the
32
;    source code for proprietary components outside of the FreeRTOS kernel.
33
;    FreeRTOS is distributed in the hope that it will be useful, but WITHOUT
34
;    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
35
;    FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
36
;    more details. You should have received a copy of the GNU General Public
37
;    License and the FreeRTOS license exception along with FreeRTOS; if not it
38
;    can be viewed here: http://www.freertos.org/a00114.html and also obtained
39
;    by writing to Richard Barry, contact details for whom are available on the
40
;    FreeRTOS WEB site.
41
;
42
;    1 tab == 4 spaces!
43
;
44
;    http://www.FreeRTOS.org - Documentation, latest information, license and
45
;    contact details.
46
;
47
;    http://www.SafeRTOS.com - A version that is certified for use in safety
48
;    critical systems.
49
;
50
;    http://www.OpenRTOS.com - Commercial support, development, porting,
51
;    licensing and training services.
52
;*/
53
 
54
#include "FreeRTOSConfig.h"
55
 
56
; Variables used by scheduler
57
;------------------------------------------------------------------------------
58
        EXTERN    pxCurrentTCB
59
        EXTERN    usCriticalNesting
60
 
61
;------------------------------------------------------------------------------
62
;   portSAVE_CONTEXT MACRO
63
;   Saves the context of the general purpose registers, CS and ES (only in far
64
;       memory mode) registers the usCriticalNesting Value and the Stack Pointer
65
;   of the active Task onto the task stack
66
;------------------------------------------------------------------------------
67
portSAVE_CONTEXT MACRO
68
 
69
        PUSH      AX                    ; Save AX Register to stack.
70
        PUSH      HL
71
#if configMEMORY_MODE == 1
72
        MOV       A, CS                 ; Save CS register.
73
        XCH       A, X
74
        MOV       A, ES                 ; Save ES register.
75
        PUSH      AX
76
#else
77
        MOV       A, CS                 ; Save CS register.
78
        PUSH      AX
79
#endif
80
        PUSH      DE                    ; Save the remaining general purpose registers.
81
        PUSH      BC
82
        MOVW      AX, usCriticalNesting ; Save the usCriticalNesting value.
83
        PUSH      AX
84
        MOVW      AX, pxCurrentTCB          ; Save the Stack pointer.
85
        MOVW      HL, AX
86
        MOVW      AX, SP
87
        MOVW      [HL], AX
88
        ENDM
89
;------------------------------------------------------------------------------
90
 
91
;------------------------------------------------------------------------------
92
;   portRESTORE_CONTEXT MACRO
93
;   Restores the task Stack Pointer then use this to restore usCriticalNesting,
94
;   general purpose registers and the CS and ES (only in far memory mode)
95
;   of the selected task from the task stack
96
;------------------------------------------------------------------------------
97
portRESTORE_CONTEXT MACRO
98
        MOVW      AX, pxCurrentTCB          ; Restore the Stack pointer.
99
        MOVW      HL, AX
100
        MOVW      AX, [HL]
101
        MOVW      SP, AX
102
        POP           AX                        ; Restore usCriticalNesting value.
103
        MOVW      usCriticalNesting, AX
104
        POP           BC                    ; Restore the necessary general purpose registers.
105
        POP           DE
106
#if configMEMORY_MODE == 1
107
        POP       AX                    ; Restore the ES register.
108
        MOV       ES, A
109
        XCH       A, X                  ; Restore the CS register.
110
        MOV       CS, A
111
#else
112
        POP       AX
113
        MOV       CS, A                 ; Restore CS register.
114
#endif
115
        POP       HL                    ; Restore general purpose register HL.
116
        POP       AX                    ; Restore AX.
117
        ENDM
118
;------------------------------------------------------------------------------

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.