]> git.sur5r.net Git - freertos/blob - FreeRTOS/Demo/CORTEX_STM32F107_GCC_Rowley/ParTest/ParTest.c
Add additional critical section to the default tickless implementations.
[freertos] / FreeRTOS / Demo / CORTEX_STM32F107_GCC_Rowley / ParTest / ParTest.c
1 /*\r
2     FreeRTOS V7.5.2 - Copyright (C) 2013 Real Time Engineers Ltd.\r
3 \r
4     VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.\r
5 \r
6     ***************************************************************************\r
7      *                                                                       *\r
8      *    FreeRTOS provides completely free yet professionally developed,    *\r
9      *    robust, strictly quality controlled, supported, and cross          *\r
10      *    platform software that has become a de facto standard.             *\r
11      *                                                                       *\r
12      *    Help yourself get started quickly and support the FreeRTOS         *\r
13      *    project by purchasing a FreeRTOS tutorial book, reference          *\r
14      *    manual, or both from: http://www.FreeRTOS.org/Documentation        *\r
15      *                                                                       *\r
16      *    Thank you!                                                         *\r
17      *                                                                       *\r
18     ***************************************************************************\r
19 \r
20     This file is part of the FreeRTOS distribution.\r
21 \r
22     FreeRTOS is free software; you can redistribute it and/or modify it under\r
23     the terms of the GNU General Public License (version 2) as published by the\r
24     Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.\r
25 \r
26     >>! NOTE: The modification to the GPL is included to allow you to distribute\r
27     >>! a combined work that includes FreeRTOS without being obliged to provide\r
28     >>! the source code for proprietary components outside of the FreeRTOS\r
29     >>! kernel.\r
30 \r
31     FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY\r
32     WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS\r
33     FOR A PARTICULAR PURPOSE.  Full license text is available from the following\r
34     link: http://www.freertos.org/a00114.html\r
35 \r
36     1 tab == 4 spaces!\r
37 \r
38     ***************************************************************************\r
39      *                                                                       *\r
40      *    Having a problem?  Start by reading the FAQ "My application does   *\r
41      *    not run, what could be wrong?"                                     *\r
42      *                                                                       *\r
43      *    http://www.FreeRTOS.org/FAQHelp.html                               *\r
44      *                                                                       *\r
45     ***************************************************************************\r
46 \r
47     http://www.FreeRTOS.org - Documentation, books, training, latest versions,\r
48     license and Real Time Engineers Ltd. contact details.\r
49 \r
50     http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,\r
51     including FreeRTOS+Trace - an indispensable productivity tool, a DOS\r
52     compatible FAT file system, and our tiny thread aware UDP/IP stack.\r
53 \r
54     http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High\r
55     Integrity Systems to sell under the OpenRTOS brand.  Low cost OpenRTOS\r
56     licenses offer ticketed support, indemnification and middleware.\r
57 \r
58     http://www.SafeRTOS.com - High Integrity Systems also provide a safety\r
59     engineered and independently SIL3 certified version for use in safety and\r
60     mission critical applications that require provable dependability.\r
61 \r
62     1 tab == 4 spaces!\r
63 */\r
64 \r
65 /*-----------------------------------------------------------\r
66  * Simple parallel port IO routines.\r
67  *-----------------------------------------------------------*/\r
68 \r
69 /* FreeRTOS.org includes. */\r
70 #include "FreeRTOS.h"\r
71 #include "task.h"\r
72 #include "partest.h"\r
73 \r
74 /* Standard includes. */\r
75 #include <string.h>\r
76 \r
77 /* Library includes. */\r
78 #include "stm32f10x_lib.h"\r
79 \r
80 #define partstNUM_LEDs          4\r
81 \r
82 /* Holds the current output state for each of the LEDs. */\r
83 static unsigned char ucBitStates[ partstNUM_LEDs ];\r
84 \r
85 /* Holds the port used by each of the LEDs. */\r
86 static GPIO_TypeDef * uxIO_Port[ partstNUM_LEDs ];\r
87 \r
88 /* Holds the pin used by each of the LEDs. */\r
89 static const unsigned short uxIO_Pins[ partstNUM_LEDs ] = { GPIO_Pin_14, GPIO_Pin_13, GPIO_Pin_3, GPIO_Pin_4 };\r
90 \r
91 /*-----------------------------------------------------------*/\r
92 \r
93 void vParTestInitialise( void )\r
94 {\r
95 GPIO_InitTypeDef GPIO_InitStructure;\r
96 \r
97         /* Configure PE14, PD13, PD3 and PD4 output push-pull */\r
98         GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_14;\r
99         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;\r
100         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;\r
101         GPIO_Init( GPIOE, &GPIO_InitStructure );\r
102 \r
103         GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_13;\r
104         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;\r
105         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;\r
106         GPIO_Init( GPIOD, &GPIO_InitStructure );\r
107 \r
108         GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_3 | GPIO_Pin_4;\r
109         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;\r
110         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;\r
111         GPIO_Init( GPIOD, &GPIO_InitStructure );\r
112 \r
113         memset( ucBitStates, 0x00, sizeof( ucBitStates ) );\r
114 \r
115         uxIO_Port[ 0 ] =  GPIOE;\r
116     uxIO_Port[ 1 ] =  GPIOD;\r
117     uxIO_Port[ 2 ] =  GPIOD;\r
118     uxIO_Port[ 3 ] =  GPIOD;\r
119 }\r
120 /*-----------------------------------------------------------*/\r
121 \r
122 void vParTestSetLED( unsigned portBASE_TYPE uxLED, signed portBASE_TYPE xValue )\r
123 {\r
124         if( uxLED < partstNUM_LEDs )\r
125         {\r
126                 portENTER_CRITICAL();\r
127                 {\r
128                         if( xValue != pdFALSE )\r
129                         {\r
130                                 ucBitStates[ uxLED ] = pdTRUE;\r
131                         }\r
132                         else\r
133                         {\r
134                                 ucBitStates[ uxLED ] = pdFALSE;\r
135                         }\r
136 \r
137             GPIO_WriteBit( uxIO_Port[ uxLED ], uxIO_Pins[ uxLED ], ucBitStates[ uxLED ] );\r
138                 }\r
139                 portEXIT_CRITICAL();\r
140         }\r
141 }\r
142 /*-----------------------------------------------------------*/\r
143 \r
144 void vParTestToggleLED( unsigned portBASE_TYPE uxLED )\r
145 {\r
146         if( uxLED < partstNUM_LEDs )\r
147         {\r
148                 portENTER_CRITICAL();\r
149                 {\r
150                         ucBitStates[ uxLED ] = !ucBitStates[ uxLED ];\r
151             GPIO_WriteBit( uxIO_Port[ uxLED ], uxIO_Pins[ uxLED ], ucBitStates[ uxLED ] );\r
152                 }\r
153                 portEXIT_CRITICAL();\r
154         }\r
155 }\r
156 /*-----------------------------------------------------------*/\r
157 \r
158 portBASE_TYPE xGetLEDState( unsigned portBASE_TYPE uxLED )\r
159 {\r
160         if( uxLED < partstNUM_LEDs )\r
161         {\r
162                 return ( portBASE_TYPE ) ucBitStates[ uxLED ];\r
163         }\r
164         else\r
165         {\r
166                 return 0;\r
167         }\r
168 }\r