]> git.sur5r.net Git - freertos/blobdiff - FreeRTOS/Source/portable/CodeWarrior/ColdFire_V1/port.c
Update copyright date ready for tagging V10.1.0.
[freertos] / FreeRTOS / Source / portable / CodeWarrior / ColdFire_V1 / port.c
index 40d5172648f04dbf9513b170b6aac1b520fd9cee..654aa9fb56a5157dba33de3a2e44c1eb2e6a00b3 100644 (file)
 /*\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
+ * FreeRTOS Kernel V10.1.0\r
+ * Copyright (C) 2018 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
 /* Kernel includes. */\r
 #include "FreeRTOS.h"\r
 #include "task.h"\r
 \r
 \r
-#define portINITIAL_FORMAT_VECTOR              ( ( portSTACK_TYPE ) 0x4000 )\r
+#define portINITIAL_FORMAT_VECTOR              ( ( StackType_t ) 0x4000 )\r
 \r
 /* Supervisor mode set. */\r
-#define portINITIAL_STATUS_REGISTER            ( ( portSTACK_TYPE ) 0x2000)\r
+#define portINITIAL_STATUS_REGISTER            ( ( StackType_t ) 0x2000)\r
 \r
 /* The clock prescale into the timer peripheral. */\r
-#define portPRESCALE_VALUE                             ( ( unsigned char ) 10 )\r
+#define portPRESCALE_VALUE                             ( ( uint8_t ) 10 )\r
 \r
 /* The clock frequency into the RTC. */\r
-#define portRTC_CLOCK_HZ                               ( ( unsigned long ) 1000 )\r
+#define portRTC_CLOCK_HZ                               ( ( uint32_t ) 1000 )\r
 \r
 asm void interrupt VectorNumber_VL1swi vPortYieldISR( void );\r
 static void prvSetupTimerInterrupt( void );\r
 \r
 /* Used to keep track of the number of nested calls to taskENTER_CRITICAL().  This\r
 will be set to 0 prior to the first task being started. */\r
-static unsigned long ulCriticalNesting = 0x9999UL;\r
+static uint32_t ulCriticalNesting = 0x9999UL;\r
 \r
 /*-----------------------------------------------------------*/\r
 \r
-portSTACK_TYPE *pxPortInitialiseStack( portSTACK_TYPE * pxTopOfStack, pdTASK_CODE pxCode, void *pvParameters )\r
+StackType_t *pxPortInitialiseStack( StackType_t * pxTopOfStack, TaskFunction_t pxCode, void *pvParameters )\r
 {\r
 \r
-unsigned long ulOriginalA5;\r
+uint32_t ulOriginalA5;\r
 \r
        __asm{ MOVE.L A5, ulOriginalA5 };\r
 \r
 \r
-       *pxTopOfStack = (portSTACK_TYPE) 0xDEADBEEF;\r
+       *pxTopOfStack = (StackType_t) 0xDEADBEEF;\r
        pxTopOfStack--;\r
 \r
        /* Exception stack frame starts with the return address. */\r
-       *pxTopOfStack = ( portSTACK_TYPE ) pxCode;\r
+       *pxTopOfStack = ( StackType_t ) pxCode;\r
        pxTopOfStack--;\r
 \r
        *pxTopOfStack = ( portINITIAL_FORMAT_VECTOR << 16UL ) | ( portINITIAL_STATUS_REGISTER );\r
        pxTopOfStack--;\r
 \r
-       *pxTopOfStack = ( portSTACK_TYPE ) 0x0; /*FP*/\r
+       *pxTopOfStack = ( StackType_t ) 0x0; /*FP*/\r
        pxTopOfStack -= 14; /* A5 to D0. */\r
 \r
        /* Parameter in A0. */\r
-       *( pxTopOfStack + 8 ) = ( portSTACK_TYPE ) pvParameters;\r
+       *( pxTopOfStack + 8 ) = ( StackType_t ) pvParameters;\r
 \r
        /* A5 must be maintained as it is resurved by the compiler. */\r
        *( pxTopOfStack + 13 ) = ulOriginalA5;\r
@@ -120,7 +81,7 @@ unsigned long ulOriginalA5;
 }\r
 /*-----------------------------------------------------------*/\r
 \r
-portBASE_TYPE xPortStartScheduler( void )\r
+BaseType_t xPortStartScheduler( void )\r
 {\r
 extern void vPortStartFirstTask( void );\r
 \r
@@ -190,7 +151,7 @@ void vPortExitCritical( void )
 \r
 void vPortYieldHandler( void )\r
 {\r
-unsigned long ulSavedInterruptMask;\r
+uint32_t ulSavedInterruptMask;\r
 \r
        ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();\r
        {\r
@@ -204,7 +165,7 @@ unsigned long ulSavedInterruptMask;
 \r
 void interrupt VectorNumber_Vrtc vPortTickISR( void )\r
 {\r
-unsigned long ulSavedInterruptMask;\r
+uint32_t ulSavedInterruptMask;\r
 \r
        /* Clear the interrupt. */\r
        RTCSC |= RTCSC_RTIF_MASK;\r
@@ -212,16 +173,11 @@ unsigned long ulSavedInterruptMask;
        /* Increment the RTOS tick. */\r
        ulSavedInterruptMask = portSET_INTERRUPT_MASK_FROM_ISR();\r
        {\r
-               vTaskIncrementTick();\r
+               if( xTaskIncrementTick() != pdFALSE )\r
+               {\r
+                       taskYIELD();\r
+               }\r
        }\r
        portCLEAR_INTERRUPT_MASK_FROM_ISR( ulSavedInterruptMask );\r
-\r
-       /* If we are using the pre-emptive scheduler then also request a\r
-       context switch as incrementing the tick could have unblocked a task. */\r
-       #if configUSE_PREEMPTION == 1\r
-       {\r
-               taskYIELD();\r
-       }\r
-       #endif\r
 }\r
 \r