]> git.sur5r.net Git - freertos/blobdiff - FreeRTOS/Demo/ColdFire_MCF51CN128_CodeWarrior/Sources/main.c
Update version number in readiness for V10.3.0 release. Sync SVN with reviewed releas...
[freertos] / FreeRTOS / Demo / ColdFire_MCF51CN128_CodeWarrior / Sources / main.c
index b62cd80f04a44143d20734f59f530778ddd0d26d..8b99185a32feb9055461730661874b8dd63e1da5 100644 (file)
@@ -1,70 +1,29 @@
 /*\r
-    FreeRTOS V7.3.0 - Copyright (C) 2012 Real Time Engineers Ltd.\r
-\r
-    FEATURES AND PORTS ARE ADDED TO FREERTOS ALL THE TIME.  PLEASE VISIT \r
-    http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.\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
-    ***************************************************************************\r
-     *                                                                       *\r
-     *    Having a problem?  Start by reading the FAQ "My application does   *\r
-     *    not run, what could be wrong?"                                     *\r
-     *                                                                       *\r
-     *    http://www.FreeRTOS.org/FAQHelp.html                               *\r
-     *                                                                       *\r
-    ***************************************************************************\r
-\r
-    \r
-    http://www.FreeRTOS.org - Documentation, training, latest versions, license \r
-    and contact details.  \r
-    \r
-    http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,\r
-    including FreeRTOS+Trace - an indispensable productivity tool.\r
-\r
-    Real Time Engineers ltd license FreeRTOS to High Integrity Systems, who sell \r
-    the code with commercial support, indemnification, and middleware, under \r
-    the OpenRTOS brand: http://www.OpenRTOS.com.  High Integrity Systems also\r
-    provide a safety engineered and independently SIL3 certified version under \r
-    the SafeRTOS brand: http://www.SafeRTOS.com.\r
-*/\r
+ * FreeRTOS Kernel V10.3.0\r
+ * Copyright (C) 2020 Amazon.com, Inc. or its affiliates.  All Rights Reserved.\r
+ *\r
+ * Permission is hereby granted, free of charge, to any person obtaining a copy of\r
+ * this software and associated documentation files (the "Software"), to deal in\r
+ * the Software without restriction, including without limitation the rights to\r
+ * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of\r
+ * the Software, and to permit persons to whom the Software is furnished to do so,\r
+ * subject to the following conditions:\r
+ *\r
+ * The above copyright notice and this permission notice shall be included in all\r
+ * copies or substantial portions of the Software.\r
+ *\r
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\r
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS\r
+ * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR\r
+ * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER\r
+ * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN\r
+ * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\r
+ *\r
+ * http://www.FreeRTOS.org\r
+ * http://aws.amazon.com/freertos\r
+ *\r
+ * 1 tab == 4 spaces!\r
+ */\r
 \r
 \r
 /*\r
  * pages display some TCP/IP status information and permit LED3 to be turned on\r
  * and off using a check box.\r
  *\r
- * Tick hook function that implements a "Check" function -  This is executed \r
- * every 5 seconds from the tick hook function.  It checks to ensure that all \r
- * the standard demo tasks are still operational and running without error.  \r
- * The system status (pass/fail) is then displayed underneith the task table on \r
- * the served WEB pages.  \r
+ * Tick hook function that implements a "Check" function -  This is executed\r
+ * every 5 seconds from the tick hook function.  It checks to ensure that all\r
+ * the standard demo tasks are still operational and running without error.\r
+ * The system status (pass/fail) is then displayed underneith the task table on\r
+ * the served WEB pages.\r
  *\r
  * "Reg test" tasks - These fill the registers with known values, then check\r
  * that each register still contains its expected value.  Each task uses\r
@@ -171,8 +130,8 @@ extern void vBasicWEBServer( void *pv );
 \r
        /* Setup the hardware ready for this demo. */\r
        prvSetupHardware();\r
-       \r
-       xTaskCreate( vuIP_Task, ( signed char * ) "uIP", mainBASIC_WEB_STACK_SIZE, NULL, mainCHECK_TASK_PRIORITY - 1, NULL );\r
+\r
+       xTaskCreate( vuIP_Task, "uIP", mainBASIC_WEB_STACK_SIZE, NULL, mainCHECK_TASK_PRIORITY - 1, NULL );\r
 \r
        /* Start the standard demo tasks. */\r
        vStartLEDFlashTasks( tskIDLE_PRIORITY );\r
@@ -182,8 +141,8 @@ extern void vBasicWEBServer( void *pv );
        vStartBlockingQueueTasks( mainBLOCK_Q_PRIORITY );\r
 \r
        /* Start the reg test tasks - defined in this file. */\r
-       xTaskCreate( vRegTest1Task, ( signed char * ) "Reg1", configMINIMAL_STACK_SIZE, ( void * ) &ulRegTest1Counter, tskIDLE_PRIORITY, NULL );\r
-       xTaskCreate( vRegTest2Task, ( signed char * ) "Reg2", configMINIMAL_STACK_SIZE, ( void * ) &ulRegTest2Counter, tskIDLE_PRIORITY, NULL );\r
+       xTaskCreate( vRegTest1Task, "Reg1", configMINIMAL_STACK_SIZE, ( void * ) &ulRegTest1Counter, tskIDLE_PRIORITY, NULL );\r
+       xTaskCreate( vRegTest2Task, "Reg2", configMINIMAL_STACK_SIZE, ( void * ) &ulRegTest2Counter, tskIDLE_PRIORITY, NULL );\r
 \r
        /* Start the scheduler. */\r
        vTaskStartScheduler();\r
@@ -199,18 +158,18 @@ extern void vBasicWEBServer( void *pv );
 void vApplicationTickHook( void )\r
 {\r
 static unsigned long ulExecutionCount = 0, ulLastRegTest1Count = 0, ulLastRegTest2Count = 0;\r
-const unsigned long ulExecutionRate = 5000 / portTICK_RATE_MS;\r
-       \r
+const unsigned long ulExecutionRate = 5000 / portTICK_PERIOD_MS;\r
+\r
     /* Increment the count of how many times the tick hook has been called. */\r
     ulExecutionCount++;\r
-    \r
+\r
     /* Is it time to perform the check again? */\r
        if( ulExecutionCount >= ulExecutionRate )\r
        {\r
                /* Reset the execution count so this function is called again in 5\r
                seconds time. */\r
                ulExecutionCount = 0;\r
-       \r
+\r
                /* Has an error been found in any task? */\r
                if( xAreGenericQueueTasksStillRunning() != pdTRUE )\r
                {\r
@@ -248,13 +207,13 @@ const unsigned long ulExecutionRate = 5000 / portTICK_RATE_MS;
 }\r
 /*-----------------------------------------------------------*/\r
 \r
-static void prvSetupHardware( void ) \r
+static void prvSetupHardware( void )\r
 {\r
        /* Disable the watchdog, STOP and WAIT modes. */\r
        SOPT1 = 0;\r
 \r
        /* --- Setup clock to use external 25MHz source. --- */\r
-       \r
+\r
        /* Extal and xtal pin ON. */\r
        PTDPF1_D4 = 0x03;\r
        PTDPF1_D5 = 0x03;\r
@@ -264,12 +223,12 @@ static void prvSetupHardware( void )
        MCGC2 = MCGC2_ERCLKEN_MASK  /* Activate external reference clock */\r
              | MCGC2_EREFS_MASK    /* Because crystal is being used */\r
              | MCGC2_RANGE_MASK;   /* High range */\r
-               \r
+\r
        /* Select clock mode and clear IREFs. */\r
        MCGC1 = (0x02 << 6 )        /* CLKS = 10 -> external reference clock. */\r
              | (0x04 << 3 )        /* RDIV = 2^4 -> 25MHz/16 = 1.5625 MHz */\r
              | MCGC1_IRCLKEN_MASK; /* IRCLK to RTC enabled */\r
-         \r
+\r
        /* Wait for Reference and Clock status bits to update. */\r
        while( MCGSC_IREFST | ( MCGSC_CLKST != 0x02 ) )\r
        {\r
@@ -287,7 +246,7 @@ static void prvSetupHardware( void )
        }\r
 \r
 \r
-       /* Now in PBE Mode, finally switch from PBE to PEE (PLL enabled external \r
+       /* Now in PBE Mode, finally switch from PBE to PEE (PLL enabled external\r
        mode). */\r
        MCGC1_CLKS  = 0b00; /* PLL clock to system (MCGOUT) */\r
 \r
@@ -302,7 +261,7 @@ static void prvSetupHardware( void )
 }\r
 /*-----------------------------------------------------------*/\r
 \r
-void vApplicationStackOverflowHook( xTaskHandle pxTask, signed char *pcTaskName )\r
+void vApplicationStackOverflowHook( TaskHandle_t pxTask, char *pcTaskName )\r
 {\r
        /* This will get called if a stack overflow is detected during the context\r
        switch.  Set configCHECK_FOR_STACK_OVERFLOWS to 2 to also check for stack\r
@@ -322,7 +281,7 @@ static void vRegTest1Task( void *pvParameters )
 {\r
   /* Just to remove compiler warnings. */\r
   ( void ) pvParameters;\r
-  \r
+\r
        /* Set all the registers to known values, then check that each retains its\r
        expected value - as described at the top of this file.  If an error is\r
        found then the loop counter will no longer be incremented allowing the check\r
@@ -333,7 +292,7 @@ static void vRegTest1Task( void *pvParameters )
                                                "       moveq           #3, d2                                  \n\t"\r
                                                "       moveq           #4, d3                                  \n\t"\r
                                                "       moveq           #5, d4                                  \n\t"\r
-                                               "       moveq           #6, d5                                  \n\t"                                           \r
+                                               "       moveq           #6, d5                                  \n\t"\r
                                                "       moveq           #7, d6                                  \n\t"\r
                                                "       moveq           #8, d7                                  \n\t"\r
                                                "       move            #9, a0                                  \n\t"\r