]> git.sur5r.net Git - freertos/blob - FreeRTOS/Source/portable/IAR/RL78/ISR_Support.h
Update version numbers to V7.4.1.
[freertos] / FreeRTOS / Source / portable / IAR / RL78 / ISR_Support.h
1 ;/*\r
2 ;    FreeRTOS V7.4.1 - Copyright (C) 2013 Real Time Engineers Ltd.\r
3 ;       \r
4 ;\r
5 ;    ***************************************************************************\r
6 ;     *                                                                       *\r
7 ;     *    FreeRTOS tutorial books are available in pdf and paperback.        *\r
8 ;     *    Complete, revised, and edited pdf reference manuals are also       *\r
9 ;     *    available.                                                         *\r
10 ;     *                                                                       *\r
11 ;     *    Purchasing FreeRTOS documentation will not only help you, by       *\r
12 ;     *    ensuring you get running as quickly as possible and with an        *\r
13 ;     *    in-depth knowledge of how to use FreeRTOS, it will also help       *\r
14 ;     *    the FreeRTOS project to continue with its mission of providing     *\r
15 ;     *    professional grade, cross platform, de facto standard solutions    *\r
16 ;     *    for microcontrollers - completely free of charge!                  *\r
17 ;     *                                                                       *\r
18 ;     *    >>> See http://www.FreeRTOS.org/Documentation for details. <<<     *\r
19 ;     *                                                                       *\r
20 ;     *    Thank you for using FreeRTOS, and thank you for your support!      *\r
21 ;     *                                                                       *\r
22 ;    ***************************************************************************\r
23 ;\r
24 ;\r
25 ;    This file is part of the FreeRTOS distribution.\r
26 ;\r
27 ;    FreeRTOS is free software; you can redistribute it and/or modify it under\r
28 ;    the terms of the GNU General Public License (version 2) as published by the\r
29 ;    Free Software Foundation AND MODIFIED BY the FreeRTOS exception.\r
30 ;    >>>NOTE<<< The modification to the GPL is included to allow you to\r
31 ;    distribute a combined work that includes FreeRTOS without being obliged to\r
32 ;    provide the source code for proprietary components outside of the FreeRTOS\r
33 ;    kernel.  FreeRTOS is distributed in the hope that it will be useful, but\r
34 ;    WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\r
35 ;    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for\r
36 ;    more details. You should have received a copy of the GNU General Public\r
37 ;    License and the FreeRTOS license exception along with FreeRTOS; if not it\r
38 ;    can be viewed here: http://www.freertos.org/a00114.html and also obtained\r
39 ;    by writing to Richard Barry, contact details for whom are available on the\r
40 ;    FreeRTOS WEB site.\r
41 ;\r
42 ;    1 tab == 4 spaces!\r
43 ;\r
44 ;    http://www.FreeRTOS.org - Documentation, latest information, license and\r
45 ;    contact details.\r
46 ;\r
47 ;    http://www.SafeRTOS.com - A version that is certified for use in safety\r
48 ;    critical systems.\r
49 ;\r
50 ;    http://www.OpenRTOS.com - Commercial support, development, porting,\r
51 ;    licensing and training services.\r
52 ;*/\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 __DATA_MODEL__ == __DATA_MODEL_FAR__\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 __DATA_MODEL__ == __DATA_MODEL_FAR__\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