]> git.sur5r.net Git - freertos/blob - FreeRTOS/Source/portable/IAR/78K0R/ISR_Support.h
baabc16ae616858316792a814d123b5cb2924f62
[freertos] / FreeRTOS / Source / portable / IAR / 78K0R / ISR_Support.h
1 ;/*\r
2 ;    FreeRTOS V8.2.2 - Copyright (C) 2015 Real Time Engineers Ltd.\r
3 ;    All rights reserved\r
4 ;       \r
5 ;\r
6 ;    ***************************************************************************\r
7 ;     *                                                                       *\r
8 ;     *    FreeRTOS tutorial books are available in pdf and paperback.        *\r
9 ;     *    Complete, revised, and edited pdf reference manuals are also       *\r
10 ;     *    available.                                                         *\r
11 ;     *                                                                       *\r
12 ;     *    Purchasing FreeRTOS documentation will not only help you, by       *\r
13 ;     *    ensuring you get running as quickly as possible and with an        *\r
14 ;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *\r
15 ;     *    the FreeRTOS project to continue with its mission of providing     *\r
16 ;     *    professional grade, cross platform, de facto standard solutions    *\r
17 ;     *    for microcontrollers - completely free of charge!                  *\r
18 ;     *                                                                       *\r
19 ;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *\r
20 ;     *                                                                       *\r
21 ;     *    Thank you for using FreeRTOS, and thank you for your support!      *\r
22 ;     *                                                                       *\r
23 ;    ***************************************************************************\r
24 ;\r
25 ;\r
26 ;    This file is part of the FreeRTOS distribution.\r
27 ;\r
28 ;    FreeRTOS is free software; you can redistribute it and/or modify it under\r
29 ;    the terms of the GNU General Public License (version 2) as published by the\r
30 ;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.\r
31 ;    >>>NOTE<<< The modification to the GPL is included to allow you to\r
32 ;    distribute a combined work that includes FreeRTOS without being obliged to\r
33 ;    provide the source code for proprietary components outside of the FreeRTOS\r
34 ;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but\r
35 ;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\r
36 ;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for\r
37 ;    more details. You should have received a copy of the GNU General Public\r
38 ;    License and the FreeRTOS license exception along with FreeRTOS; if not it\r
39 ;    can be viewed here: http://www.freertos.org/a00114.html and also obtained\r
40 ;    by writing to Richard Barry, contact details for whom are available on the\r
41 ;    FreeRTOS WEB site.\r
42 ;\r
43 ;    1 tab == 4 spaces!\r
44 ;\r
45 ;    http://www.FreeRTOS.org - Documentation, latest information, license and\r
46 ;    contact details.\r
47 ;\r
48 ;    http://www.SafeRTOS.com - A version that is certified for use in safety\r
49 ;    critical systems.\r
50 ;\r
51 ;    http://www.OpenRTOS.com - Commercial support, development, porting,\r
52 ;    licensing and training services.\r
53 ;*/\r
54 \r
55 #include "FreeRTOSConfig.h"\r
56 \r
57 ; Variables used by scheduler\r
58 ;------------------------------------------------------------------------------\r
59         EXTERN    pxCurrentTCB\r
60         EXTERN    usCriticalNesting\r
61 \r
62 ;------------------------------------------------------------------------------\r
63 ;   portSAVE_CONTEXT MACRO\r
64 ;   Saves the context of the general purpose registers, CS and ES (only in far \r
65 ;       memory mode) registers the usCriticalNesting Value and the Stack Pointer\r
66 ;   of the active Task onto the task stack\r
67 ;------------------------------------------------------------------------------\r
68 portSAVE_CONTEXT MACRO\r
69 \r
70         PUSH      AX                    ; Save AX Register to stack.\r
71         PUSH      HL\r
72 #if configMEMORY_MODE == 1\r
73         MOV       A, CS                 ; Save CS register.\r
74         XCH       A, X\r
75         MOV       A, ES                 ; Save ES register.\r
76         PUSH      AX\r
77 #else\r
78         MOV       A, CS                 ; Save CS register.\r
79         PUSH      AX\r
80 #endif\r
81         PUSH      DE                    ; Save the remaining general purpose registers.\r
82         PUSH      BC\r
83         MOVW      AX, usCriticalNesting ; Save the usCriticalNesting value.\r
84         PUSH      AX    \r
85         MOVW      AX, pxCurrentTCB          ; Save the Stack pointer.\r
86         MOVW      HL, AX                                        \r
87         MOVW      AX, SP                                        \r
88         MOVW      [HL], AX                                      \r
89         ENDM\r
90 ;------------------------------------------------------------------------------\r
91 \r
92 ;------------------------------------------------------------------------------\r
93 ;   portRESTORE_CONTEXT MACRO\r
94 ;   Restores the task Stack Pointer then use this to restore usCriticalNesting,\r
95 ;   general purpose registers and the CS and ES (only in far memory mode)\r
96 ;   of the selected task from the task stack\r
97 ;------------------------------------------------------------------------------\r
98 portRESTORE_CONTEXT MACRO\r
99         MOVW      AX, pxCurrentTCB          ; Restore the Stack pointer.\r
100         MOVW      HL, AX\r
101         MOVW      AX, [HL]\r
102         MOVW      SP, AX\r
103         POP           AX                        ; Restore usCriticalNesting value.\r
104         MOVW      usCriticalNesting, AX\r
105         POP           BC                    ; Restore the necessary general purpose registers.\r
106         POP           DE\r
107 #if configMEMORY_MODE == 1\r
108         POP       AX                    ; Restore the ES register.\r
109         MOV       ES, A\r
110         XCH       A, X                  ; Restore the CS register.\r
111         MOV       CS, A\r
112 #else\r
113         POP       AX\r
114         MOV       CS, A                 ; Restore CS register.\r
115 #endif\r
116         POP       HL                    ; Restore general purpose register HL.\r
117         POP       AX                    ; Restore AX.\r
118         ENDM\r
119 ;------------------------------------------------------------------------------\r