]> git.sur5r.net Git - freertos/blobdiff - FreeRTOS/Demo/CORTEX_LPC1768_GCC_RedSuite/src/main.c
Update version number in readiness for V10.3.0 release. Sync SVN with reviewed releas...
[freertos] / FreeRTOS / Demo / CORTEX_LPC1768_GCC_RedSuite / src / main.c
index 2e3b5210d223fd2dcdf0dde5a582bfc095a8ac66..3d001eb7cf4547e6c558d350f14d6edf5d8e28f5 100644 (file)
@@ -1,72 +1,29 @@
 /*\r
-    FreeRTOS V7.1.1 - Copyright (C) 2012 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
-    ***************************************************************************\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 information, \r
-    license 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
-\r
-\r
-#error The batch file Demo\CORTEX_LPC1768_GCC_RedSuite\CreateProjectDirectoryStructure.bat must be executed before the first build.  After executing the batch file hit F5 to refrech the Eclipse project, then delete this line.\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
@@ -85,7 +42,7 @@
  *\r
  * "uIP" task -  This is the task that handles the uIP stack.  All TCP/IP\r
  * processing is performed in this task.\r
- * \r
+ *\r
  * "USB" task - Enumerates the USB device as a CDC class, then echoes back all\r
  * received characters with a configurable offset (for example, if the offset\r
  * is 1 and 'A' is received then 'B' will be sent back).  A dumb terminal such\r
 #include "QPeek.h"\r
 #include "recmutex.h"\r
 \r
-/* Red Suite includes. */\r
-#include "lcd_driver.h"\r
-#include "lcd.h"\r
-\r
 /*-----------------------------------------------------------*/\r
 \r
 /* The time between cycles of the 'check' functionality (defined within the\r
 tick hook. */\r
-#define mainCHECK_DELAY                                                ( ( portTickType ) 5000 / portTICK_RATE_MS )\r
+#define mainCHECK_DELAY                                                ( ( TickType_t ) 5000 / portTICK_PERIOD_MS )\r
 \r
 /* Task priorities. */\r
 #define mainQUEUE_POLL_PRIORITY                                ( tskIDLE_PRIORITY + 2 )\r
@@ -192,15 +145,16 @@ char cIPAddress[ 16 ]; /* Enough space for "xxx.xxx.xxx.xxx\0". */
        vStartLEDFlashTasks( mainFLASH_TASK_PRIORITY );\r
 \r
     /* Create the USB task. */\r
-    xTaskCreate( vUSBTask, ( signed char * ) "USB", configMINIMAL_STACK_SIZE, ( void * ) NULL, tskIDLE_PRIORITY, NULL );\r
-       \r
-       /* Display the IP address, then create the uIP task.  The WEB server runs \r
-       in this task. */\r
+    xTaskCreate( vUSBTask, "USB", configMINIMAL_STACK_SIZE, ( void * ) NULL, tskIDLE_PRIORITY, NULL );\r
+\r
+       /* Display the IP address, then create the uIP task.  The WEB server runs\r
+       in this task.  --- Due to tool changes since this demo was created the LCD\r
+       is no longer used.\r
        LCDdriver_initialisation();\r
        LCD_PrintString( 5, 10, "FreeRTOS.org", 14, COLOR_GREEN);\r
        sprintf( cIPAddress, "%d.%d.%d.%d", configIP_ADDR0, configIP_ADDR1, configIP_ADDR2, configIP_ADDR3 );\r
        LCD_PrintString( 5, 30, cIPAddress, 14, COLOR_RED);\r
-    xTaskCreate( vuIP_Task, ( signed char * ) "uIP", mainBASIC_WEB_STACK_SIZE, ( void * ) NULL, mainUIP_TASK_PRIORITY, NULL );\r
+    xTaskCreate( vuIP_Task, "uIP", mainBASIC_WEB_STACK_SIZE, ( void * ) NULL, mainUIP_TASK_PRIORITY, NULL ); */\r
 \r
     /* Start the scheduler. */\r
        vTaskStartScheduler();\r
@@ -289,48 +243,47 @@ void prvSetupHardware( void )
                LPC_SC->PLL0FEED = PLLFEED_FEED1;\r
                LPC_SC->PLL0FEED = PLLFEED_FEED2;\r
        }\r
-       \r
+\r
        /* Disable PLL, disconnected. */\r
        LPC_SC->PLL0CON = 0;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED2;\r
-           \r
+\r
        /* Enable main OSC. */\r
        LPC_SC->SCS |= 0x20;\r
        while( !( LPC_SC->SCS & 0x40 ) );\r
-       \r
+\r
        /* select main OSC, 12MHz, as the PLL clock source. */\r
        LPC_SC->CLKSRCSEL = 0x1;\r
-       \r
+\r
        LPC_SC->PLL0CFG = 0x20031;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED2;\r
-             \r
+\r
        /* Enable PLL, disconnected. */\r
        LPC_SC->PLL0CON = 1;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED2;\r
-       \r
+\r
        /* Set clock divider. */\r
        LPC_SC->CCLKCFG = 0x03;\r
-       \r
+\r
        /* Configure flash accelerator. */\r
        LPC_SC->FLASHCFG = 0x403a;\r
-       \r
+\r
        /* Check lock bit status. */\r
        while( ( ( LPC_SC->PLL0STAT & ( 1 << 26 ) ) == 0 ) );\r
-           \r
+\r
        /* Enable and connect. */\r
        LPC_SC->PLL0CON = 3;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL0FEED = PLLFEED_FEED2;\r
        while( ( ( LPC_SC->PLL0STAT & ( 1 << 25 ) ) == 0 ) );\r
 \r
-       \r
-       \r
-       \r
+\r
+\r
+\r
        /* Configure the clock for the USB. */\r
-         \r
        if( LPC_SC->PLL1STAT & ( 1 << 9 ) )\r
        {\r
                /* Enable PLL, disconnected. */\r
@@ -338,29 +291,29 @@ void prvSetupHardware( void )
                LPC_SC->PLL1FEED = PLLFEED_FEED1;\r
                LPC_SC->PLL1FEED = PLLFEED_FEED2;\r
        }\r
-       \r
+\r
        /* Disable PLL, disconnected. */\r
        LPC_SC->PLL1CON = 0;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED2;\r
-       \r
+\r
        LPC_SC->PLL1CFG = 0x23;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED2;\r
-             \r
+\r
        /* Enable PLL, disconnected. */\r
        LPC_SC->PLL1CON = 1;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED2;\r
        while( ( ( LPC_SC->PLL1STAT & ( 1 << 10 ) ) == 0 ) );\r
-       \r
+\r
        /* Enable and connect. */\r
        LPC_SC->PLL1CON = 3;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED1;\r
        LPC_SC->PLL1FEED = PLLFEED_FEED2;\r
        while( ( ( LPC_SC->PLL1STAT & ( 1 << 9 ) ) == 0 ) );\r
 \r
-       /*  Setup the peripheral bus to be the same as the PLL output (64 MHz). */\r
+       /*  Setup the peripheral bus to be the same as the CPU output (100 MHz). */\r
        LPC_SC->PCLKSEL0 = 0x05555555;\r
 \r
        /* Configure the LEDs. */\r
@@ -368,7 +321,7 @@ void prvSetupHardware( void )
 }\r
 /*-----------------------------------------------------------*/\r
 \r
-void vApplicationStackOverflowHook( xTaskHandle pxTask, signed char *pcTaskName )\r
+void vApplicationStackOverflowHook( TaskHandle_t pxTask, char *pcTaskName )\r
 {\r
        /* This function will get called if a task overflows its stack. */\r
 \r