]> git.sur5r.net Git - freertos/blob - Source/portable/RVDS/ARM7_LPC21xx/portmacro.h
Update ready for V5.1.0 release.
[freertos] / Source / portable / RVDS / ARM7_LPC21xx / portmacro.h
1 /*\r
2         FreeRTOS.org V5.1.0 - Copyright (C) 2003-2008 Richard Barry.\r
3 \r
4         This file is part of the FreeRTOS.org distribution.\r
5 \r
6         FreeRTOS.org is free software; you can redistribute it and/or modify\r
7         it under the terms of the GNU General Public License as published by\r
8         the Free Software Foundation; either version 2 of the License, or\r
9         (at your option) any later version.\r
10 \r
11         FreeRTOS.org is distributed in the hope that it will be useful,\r
12         but WITHOUT ANY WARRANTY; without even the implied warranty of\r
13         MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
14         GNU General Public License for more details.\r
15 \r
16         You should have received a copy of the GNU General Public License\r
17         along with FreeRTOS.org; if not, write to the Free Software\r
18         Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
19 \r
20         A special exception to the GPL can be applied should you wish to distribute\r
21         a combined work that includes FreeRTOS.org, without being obliged to provide\r
22         the source code for any proprietary components.  See the licensing section \r
23         of http://www.FreeRTOS.org for full details of how and when the exception\r
24         can be applied.\r
25 \r
26     ***************************************************************************\r
27     ***************************************************************************\r
28     *                                                                         *\r
29     * SAVE TIME AND MONEY!  We can port FreeRTOS.org to your own hardware,    *\r
30     * and even write all or part of your application on your behalf.          *\r
31     * See http://www.OpenRTOS.com for details of the services we provide to   *\r
32     * expedite your project.                                                  *\r
33     *                                                                         *\r
34     ***************************************************************************\r
35     ***************************************************************************\r
36 \r
37         Please ensure to read the configuration and relevant port sections of the\r
38         online documentation.\r
39 \r
40         http://www.FreeRTOS.org - Documentation, latest information, license and \r
41         contact details.\r
42 \r
43         http://www.SafeRTOS.com - A version that is certified for use in safety \r
44         critical systems.\r
45 \r
46         http://www.OpenRTOS.com - Commercial support, development, porting, \r
47         licensing and training services.\r
48 */\r
49 \r
50 \r
51 #ifndef PORTMACRO_H\r
52 #define PORTMACRO_H\r
53 \r
54 #ifdef __cplusplus\r
55 extern "C" {\r
56 #endif\r
57 \r
58 /*-----------------------------------------------------------\r
59  * Port specific definitions.  \r
60  *\r
61  * The settings in this file configure FreeRTOS correctly for the\r
62  * given hardware and compiler.\r
63  *\r
64  * These settings should not be altered.\r
65  *-----------------------------------------------------------\r
66  */\r
67 \r
68 /* Type definitions. */\r
69 #define portCHAR                char\r
70 #define portFLOAT               float\r
71 #define portDOUBLE              double\r
72 #define portLONG                long\r
73 #define portSHORT               short\r
74 #define portSTACK_TYPE  unsigned portLONG\r
75 #define portBASE_TYPE   portLONG\r
76 \r
77 #if( configUSE_16_BIT_TICKS == 1 )\r
78         typedef unsigned portSHORT portTickType;\r
79         #define portMAX_DELAY ( portTickType ) 0xffff\r
80 #else\r
81         typedef unsigned portLONG portTickType;\r
82         #define portMAX_DELAY ( portTickType ) 0xffffffff\r
83 #endif\r
84 /*-----------------------------------------------------------*/ \r
85 \r
86 /* Hardware specifics. */\r
87 #define portSTACK_GROWTH                        ( -1 )\r
88 #define portTICK_RATE_MS                        ( ( portTickType ) 1000 / configTICK_RATE_HZ )          \r
89 #define portBYTE_ALIGNMENT                      4\r
90 /*-----------------------------------------------------------*/ \r
91 \r
92 /* Task utilities. */\r
93 \r
94 /*-----------------------------------------------------------\r
95  * ISR entry and exit macros.  These are only required if a task switch\r
96  * is required from an ISR.\r
97  *----------------------------------------------------------*/\r
98 \r
99 /* If a switch is required then we just need to call */ \r
100 /* vTaskSwitchContext() as the context has already been */\r
101 /* saved. */\r
102 \r
103 #define portEXIT_SWITCHING_ISR(SwitchRequired)                           \\r
104 {                                                                                                                        \\r
105 extern void vTaskSwitchContext(void);                                            \\r
106                                                                                                                          \\r
107                 if(SwitchRequired)                                                                       \\r
108                 {                                                                                                        \\r
109                         vTaskSwitchContext();                                                    \\r
110                 }                                                                                                        \\r
111 }                                                                                                                        \\r
112 \r
113 extern void vPortYield( void );\r
114 #define portYIELD() vPortYield()\r
115 \r
116 \r
117 /* Critical section management. */\r
118 \r
119 /*\r
120  ****************************************************************** \r
121  * We don't need to worry about whether we're in ARM or\r
122  * THUMB mode with the Keil Real View compiler when enabling \r
123  * or disabling interrupts as the compiler's intrinsic functions \r
124  * take care of that for us.\r
125  *******************************************************************\r
126  */\r
127 #define portDISABLE_INTERRUPTS()        __disable_irq()                                 \r
128 #define portENABLE_INTERRUPTS()         __enable_irq()\r
129 \r
130 \r
131 /*-----------------------------------------------------------\r
132  * Critical section control\r
133  *\r
134  * The code generated by the Keil compiler does not maintain separate\r
135  * stack and frame pointers. The portENTER_CRITICAL macro cannot therefore\r
136  * use the stack as per other ports.  Instead a variable is used to keep\r
137  * track of the critical section nesting.  This necessitates the use of a \r
138  * function in place of the macro.\r
139  *----------------------------------------------------------*/\r
140 \r
141 extern void vPortEnterCritical( void );\r
142 extern void vPortExitCritical( void );\r
143 \r
144 #define portENTER_CRITICAL()            vPortEnterCritical();\r
145 #define portEXIT_CRITICAL()                     vPortExitCritical();\r
146 /*-----------------------------------------------------------*/ \r
147 \r
148 /* Compiler specifics. */\r
149 #define inline\r
150 #define register\r
151 #define portNOP()       __asm{ NOP }\r
152 /*-----------------------------------------------------------*/ \r
153 \r
154 /* Task function macros as described on the FreeRTOS.org WEB site. */\r
155 #define portTASK_FUNCTION_PROTO( vFunction, pvParameters )      void vFunction( void *pvParameters )\r
156 #define portTASK_FUNCTION( vFunction, pvParameters )    void vFunction( void *pvParameters )\r
157 \r
158 #ifdef __cplusplus\r
159 }\r
160 #endif\r
161 \r
162 #endif /* PORTMACRO_H */\r
163 \r