]> git.sur5r.net Git - freertos/blob - Demo/PIC18_MPLAB/main2.c
Update to V4.7.2.
[freertos] / Demo / PIC18_MPLAB / main2.c
1 /*\r
2         FreeRTOS.org V4.7.2 - 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         Please ensure to read the configuration and relevant port sections of the \r
29         online documentation.\r
30 \r
31         +++ http://www.FreeRTOS.org +++\r
32         Documentation, latest information, license and contact details.  \r
33 \r
34         +++ http://www.SafeRTOS.com +++\r
35         A version that is certified for use in safety critical systems.\r
36 \r
37         +++ http://www.OpenRTOS.com +++\r
38         Commercial support, development, porting, licensing and training services.\r
39 \r
40         ***************************************************************************\r
41 */\r
42 \r
43 /*\r
44  * Instead of the normal single demo application, the PIC18F demo is split \r
45  * into several smaller programs of which this is the second.  This enables the \r
46  * demo's to be executed on the RAM limited 40 pin devices.  The 64 and 80 pin \r
47  * devices require a more costly development platform and are not so readily \r
48  * available.\r
49  *\r
50  * The RTOSDemo2 project is configured for a PIC18F452 device.  Main2.c starts  \r
51  * 5 tasks (including the idle task).\r
52  * \r
53  * The first, second and third tasks do nothing but flash an LED.  This gives\r
54  * visual feedback that everything is executing as expected.  One task flashes\r
55  * an LED every 333ms (i.e. on and off every 333/2 ms), then next every 666ms\r
56  * and the last every 999ms.\r
57  *\r
58  * The last task runs at the idle priority.  It repeatedly performs a 32bit \r
59  * calculation and checks it's result against the expected value.  This checks \r
60  * that the temporary storage utilised by the compiler to hold intermediate \r
61  * results does not get corrupted when the task gets switched in and out.\r
62  * should the calculation ever provide an incorrect result the final LED is\r
63  * turned on.\r
64  *\r
65  * On entry to main() an 'X' is transmitted.  Monitoring the serial port using a\r
66  * dumb terminal allows for verification that the device is not continuously \r
67  * being reset (no more than one 'X' should be transmitted).\r
68  *\r
69  * http://www.FreeRTOS.org contains important information on the use of the \r
70  * PIC18F port.\r
71  */\r
72 \r
73 /*\r
74 Changes from V2.0.0\r
75 \r
76         + Delay periods are now specified using variables and constants of\r
77           portTickType rather than unsigned portLONG.\r
78 */\r
79 \r
80 /* Scheduler include files. */\r
81 #include "FreeRTOS.h"\r
82 #include "task.h"\r
83 \r
84 /* Demo app include files. */\r
85 #include "flash.h"\r
86 #include "partest.h"\r
87 #include "serial.h"\r
88 \r
89 /* Priority definitions for the LED tasks.  Other tasks just use the idle\r
90 priority. */\r
91 #define mainLED_FLASH_PRIORITY                  ( tskIDLE_PRIORITY + ( unsigned portBASE_TYPE ) 1 )\r
92 \r
93 /* The LED that is lit when should the calculation fail. */\r
94 #define mainCHECK_TASK_LED                              ( ( unsigned portBASE_TYPE ) 3 )\r
95 \r
96 /* Constants required for the communications.  Only one character is ever \r
97 transmitted. */\r
98 #define mainCOMMS_QUEUE_LENGTH                  ( ( unsigned portBASE_TYPE ) 5 )\r
99 #define mainNO_BLOCK                                    ( ( portTickType ) 0 )\r
100 #define mainBAUD_RATE                                   ( ( unsigned portLONG ) 9600 )\r
101 \r
102 /*\r
103  * The task that performs the 32 bit calculation at the idle priority.\r
104  */\r
105 static void vCalculationTask( void *pvParameters );\r
106 \r
107 /*-----------------------------------------------------------*/\r
108 \r
109 /* Creates the tasks, then starts the scheduler. */\r
110 void main( void )\r
111 {\r
112         /* Initialise the required hardware. */\r
113         vParTestInitialise();\r
114         vPortInitialiseBlocks();\r
115 \r
116         /* Send a character so we have some visible feedback of a reset. */\r
117         xSerialPortInitMinimal( mainBAUD_RATE, mainCOMMS_QUEUE_LENGTH );\r
118         xSerialPutChar( NULL, 'X', mainNO_BLOCK );\r
119 \r
120         /* Start the standard LED flash tasks as defined in demo/common/minimal. */\r
121         vStartLEDFlashTasks( mainLED_FLASH_PRIORITY );\r
122 \r
123         /* Start the check task defined in this file. */\r
124         xTaskCreate( vCalculationTask, ( const portCHAR * const ) "Check", configMINIMAL_STACK_SIZE, NULL, tskIDLE_PRIORITY, NULL );\r
125 \r
126         /* Start the scheduler. */\r
127         vTaskStartScheduler();\r
128 }\r
129 /*-----------------------------------------------------------*/\r
130 \r
131 static void vCalculationTask( void *pvParameters )\r
132 {\r
133 volatile unsigned long ulCalculatedValue; /* Volatile to ensure optimisation is minimal. */\r
134 \r
135         /* Continuously perform a calculation.  If the calculation result is ever\r
136         incorrect turn the LED on. */\r
137         for( ;; )\r
138         {\r
139                 /* A good optimising compiler would just remove all this! */\r
140                 ulCalculatedValue = 1234UL;\r
141                 ulCalculatedValue *= 99UL;\r
142 \r
143                 if( ulCalculatedValue != 122166UL )\r
144                 {\r
145                         vParTestSetLED( mainCHECK_TASK_LED, pdTRUE );\r
146                 }\r
147 \r
148                 ulCalculatedValue *= 9876UL;\r
149 \r
150                 if( ulCalculatedValue != 1206511416UL )\r
151                 {\r
152                         vParTestSetLED( mainCHECK_TASK_LED, pdTRUE );\r
153                 }\r
154 \r
155                 ulCalculatedValue /= 15UL;\r
156 \r
157                 if( ulCalculatedValue != 80434094UL )\r
158                 {\r
159                         vParTestSetLED( mainCHECK_TASK_LED, pdTRUE );\r
160                 }\r
161 \r
162                 ulCalculatedValue += 918273UL;\r
163 \r
164                 if( ulCalculatedValue != 81352367UL )\r
165                 {\r
166                         vParTestSetLED( mainCHECK_TASK_LED, pdTRUE );\r
167                 }\r
168         }\r
169 }\r
170 /*-----------------------------------------------------------*/\r
171 \r