/*\r
- FreeRTOS.org V4.0.5 - Copyright (C) 2003-2006 Richard Barry.\r
-\r
- This file is part of the FreeRTOS.org distribution.\r
-\r
- FreeRTOS.org is free software; you can redistribute it and/or modify\r
- it under the terms of the GNU General Public License as published by\r
- the Free Software Foundation; either version 2 of the License, or\r
- (at your option) any later version.\r
-\r
- FreeRTOS.org is distributed in the hope that it will be useful,\r
- but WITHOUT ANY WARRANTY; without even the implied warranty of\r
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the\r
- GNU General Public License for more details.\r
-\r
- You should have received a copy of the GNU General Public License\r
- along with FreeRTOS.org; if not, write to the Free Software\r
- Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA\r
-\r
- A special exception to the GPL can be applied should you wish to distribute\r
- a combined work that includes FreeRTOS.org, without being obliged to provide\r
- the source code for any proprietary components. See the licensing section \r
- of http://www.FreeRTOS.org for full details of how and when the exception\r
- can be applied.\r
-\r
- ***************************************************************************\r
- See http://www.FreeRTOS.org for documentation, latest information, license \r
- and contact details. Please ensure to read the configuration and relevant \r
- port sections of the online documentation.\r
- ***************************************************************************\r
+ FreeRTOS V7.0.1 - Copyright (C) 2011 Real Time Engineers Ltd.\r
+ \r
+\r
+ ***************************************************************************\r
+ * *\r
+ * FreeRTOS tutorial books are available in pdf and paperback. *\r
+ * Complete, revised, and edited pdf reference manuals are also *\r
+ * available. *\r
+ * *\r
+ * Purchasing FreeRTOS documentation will not only help you, by *\r
+ * ensuring you get running as quickly as possible and with an *\r
+ * in-depth knowledge of how to use FreeRTOS, it will also help *\r
+ * the FreeRTOS project to continue with its mission of providing *\r
+ * professional grade, cross platform, de facto standard solutions *\r
+ * for microcontrollers - completely free of charge! *\r
+ * *\r
+ * >>> See http://www.FreeRTOS.org/Documentation for details. <<< *\r
+ * *\r
+ * Thank you for using FreeRTOS, and thank you for your support! *\r
+ * *\r
+ ***************************************************************************\r
+\r
+\r
+ This file is part of the FreeRTOS distribution.\r
+\r
+ FreeRTOS is free software; you can redistribute it and/or modify it under\r
+ the terms of the GNU General Public License (version 2) as published by the\r
+ Free Software Foundation AND MODIFIED BY the FreeRTOS exception.\r
+ >>>NOTE<<< The modification to the GPL is included to allow you to\r
+ distribute a combined work that includes FreeRTOS without being obliged to\r
+ provide the source code for proprietary components outside of the FreeRTOS\r
+ kernel. FreeRTOS is distributed in the hope that it will be useful, but\r
+ WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\r
+ or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for\r
+ more details. You should have received a copy of the GNU General Public\r
+ License and the FreeRTOS license exception along with FreeRTOS; if not it\r
+ can be viewed here: http://www.freertos.org/a00114.html and also obtained\r
+ by writing to Richard Barry, contact details for whom are available on the\r
+ FreeRTOS WEB site.\r
+\r
+ 1 tab == 4 spaces!\r
+\r
+ http://www.FreeRTOS.org - Documentation, latest information, license and\r
+ contact details.\r
+\r
+ http://www.SafeRTOS.com - A version that is certified for use in safety\r
+ critical systems.\r
+\r
+ http://www.OpenRTOS.com - Commercial support, development, porting,\r
+ licensing and training services.\r
*/\r
\r
/*\r
Changes from V2.0.0\r
\r
+ Delay periods are now specified using variables and constants of\r
- portTickType rather than unsigned portLONG.\r
+ portTickType rather than unsigned long.\r
\r
Changes from V2.6.1\r
\r
+ The IAR and WinAVR AVR ports are now maintained separately.\r
+\r
+Changes from V4.0.5\r
+\r
+ + Modified to demonstrate the use of co-routines.\r
+\r
*/\r
\r
#include <stdlib.h>\r
/* Scheduler include files. */\r
#include "FreeRTOS.h"\r
#include "task.h"\r
+#include "croutine.h"\r
\r
/* Demo file headers. */\r
#include "PollQ.h"\r
#include "integer.h"\r
#include "serial.h"\r
#include "comtest.h"\r
-#include "flash.h"\r
+#include "crflash.h"\r
#include "print.h"\r
#include "partest.h"\r
+#include "regtest.h"\r
\r
/* Priority definitions for most of the tasks in the demo application. Some\r
tasks just use the idle priority. */\r
#define mainCHECK_TASK_PRIORITY ( tskIDLE_PRIORITY + 3 )\r
\r
/* Baud rate used by the serial port tasks. */\r
-#define mainCOM_TEST_BAUD_RATE ( ( unsigned portLONG ) 38400 )\r
+#define mainCOM_TEST_BAUD_RATE ( ( unsigned long ) 38400 )\r
\r
/* LED used by the serial port tasks. This is toggled on each character Tx,\r
and mainCOM_TEST_LED + 1 is toggles on each character Rx. */\r
the demo application is not unexpectedly resetting. */\r
#define mainRESET_COUNT_ADDRESS ( ( void * ) 0x50 )\r
\r
+/* The number of coroutines to create. */\r
+#define mainNUM_FLASH_COROUTINES ( 3 )\r
+\r
/*\r
* The task function for the "Check" task.\r
*/\r
*/\r
static void prvIncrementResetCount( void );\r
\r
-portSHORT main( void )\r
+/*\r
+ * The idle hook is used to scheduler co-routines.\r
+ */\r
+void vApplicationIdleHook( void );\r
+\r
+/*-----------------------------------------------------------*/\r
+\r
+short main( void )\r
{\r
prvIncrementResetCount();\r
\r
/* Setup the LED's for output. */\r
vParTestInitialise();\r
\r
+ /* Create the standard demo tasks. */\r
vStartIntegerMathTasks( tskIDLE_PRIORITY );\r
vAltStartComTestTasks( mainCOM_TEST_PRIORITY, mainCOM_TEST_BAUD_RATE, mainCOM_TEST_LED );\r
- vStartLEDFlashTasks( mainLED_TASK_PRIORITY );\r
vStartPolledQueueTasks( mainQUEUE_POLL_PRIORITY );\r
+ vStartRegTestTasks();\r
+ \r
+ /* Create the tasks defined within this file. */\r
+ xTaskCreate( vErrorChecks, ( signed char * ) "Check", configMINIMAL_STACK_SIZE, NULL, mainCHECK_TASK_PRIORITY, NULL );\r
\r
- xTaskCreate( vErrorChecks, "Check", configMINIMAL_STACK_SIZE, NULL, mainCHECK_TASK_PRIORITY, NULL );\r
-\r
+ /* Create the co-routines that flash the LED's. */\r
+ vStartFlashCoRoutines( mainNUM_FLASH_COROUTINES );\r
+ \r
/* In this port, to use preemptive scheduler define configUSE_PREEMPTION \r
as 1 in portmacro.h. To use the cooperative scheduler define \r
configUSE_PREEMPTION as 0. */\r
\r
static void vErrorChecks( void *pvParameters )\r
{\r
-static volatile unsigned portLONG ulDummyVariable = 3UL;\r
+static volatile unsigned long ulDummyVariable = 3UL;\r
\r
/* The parameters are not used. */\r
( void ) pvParameters;\r
xErrorHasOccurred = pdTRUE;\r
}\r
\r
+ if( xAreRegTestTasksStillRunning() != pdTRUE )\r
+ {\r
+ xErrorHasOccurred = pdTRUE;\r
+ }\r
+ \r
if( xErrorHasOccurred == pdFALSE )\r
{\r
/* Toggle the LED if everything is okay so we know if an error occurs even if not\r
\r
static void prvIncrementResetCount( void )\r
{\r
-unsigned portCHAR ucCount;\r
+unsigned char ucCount;\r
\r
eeprom_read_block( &ucCount, mainRESET_COUNT_ADDRESS, sizeof( ucCount ) );\r
ucCount++;\r
eeprom_write_byte( mainRESET_COUNT_ADDRESS, ucCount );\r
}\r
+/*-----------------------------------------------------------*/\r
+\r
+void vApplicationIdleHook( void )\r
+{\r
+ vCoRoutineSchedule();\r
+}\r
\r