Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependents: frdm_k64f_freertos_lib
src/list.c@0:62cd296ba2a7, 2017-05-31 (annotated)
- Committer:
- fep
- Date:
- Wed May 31 02:27:10 2017 +0000
- Revision:
- 0:62cd296ba2a7
FreeRTOS v9.0.0 for Cortex-M4F (FRDM-K64F and others...)
Who changed what in which revision?
| User | Revision | Line number | New contents of line |
|---|---|---|---|
| fep | 0:62cd296ba2a7 | 1 | /* |
| fep | 0:62cd296ba2a7 | 2 | FreeRTOS V9.0.0 - Copyright (C) 2016 Real Time Engineers Ltd. |
| fep | 0:62cd296ba2a7 | 3 | All rights reserved |
| fep | 0:62cd296ba2a7 | 4 | |
| fep | 0:62cd296ba2a7 | 5 | VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION. |
| fep | 0:62cd296ba2a7 | 6 | |
| fep | 0:62cd296ba2a7 | 7 | This file is part of the FreeRTOS distribution. |
| fep | 0:62cd296ba2a7 | 8 | |
| fep | 0:62cd296ba2a7 | 9 | FreeRTOS is free software; you can redistribute it and/or modify it under |
| fep | 0:62cd296ba2a7 | 10 | the terms of the GNU General Public License (version 2) as published by the |
| fep | 0:62cd296ba2a7 | 11 | Free Software Foundation >>>> AND MODIFIED BY <<<< the FreeRTOS exception. |
| fep | 0:62cd296ba2a7 | 12 | |
| fep | 0:62cd296ba2a7 | 13 | *************************************************************************** |
| fep | 0:62cd296ba2a7 | 14 | >>! NOTE: The modification to the GPL is included to allow you to !<< |
| fep | 0:62cd296ba2a7 | 15 | >>! distribute a combined work that includes FreeRTOS without being !<< |
| fep | 0:62cd296ba2a7 | 16 | >>! obliged to provide the source code for proprietary components !<< |
| fep | 0:62cd296ba2a7 | 17 | >>! outside of the FreeRTOS kernel. !<< |
| fep | 0:62cd296ba2a7 | 18 | *************************************************************************** |
| fep | 0:62cd296ba2a7 | 19 | |
| fep | 0:62cd296ba2a7 | 20 | FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY |
| fep | 0:62cd296ba2a7 | 21 | WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS |
| fep | 0:62cd296ba2a7 | 22 | FOR A PARTICULAR PURPOSE. Full license text is available on the following |
| fep | 0:62cd296ba2a7 | 23 | link: http://www.freertos.org/a00114.html |
| fep | 0:62cd296ba2a7 | 24 | |
| fep | 0:62cd296ba2a7 | 25 | *************************************************************************** |
| fep | 0:62cd296ba2a7 | 26 | * * |
| fep | 0:62cd296ba2a7 | 27 | * FreeRTOS provides completely free yet professionally developed, * |
| fep | 0:62cd296ba2a7 | 28 | * robust, strictly quality controlled, supported, and cross * |
| fep | 0:62cd296ba2a7 | 29 | * platform software that is more than just the market leader, it * |
| fep | 0:62cd296ba2a7 | 30 | * is the industry's de facto standard. * |
| fep | 0:62cd296ba2a7 | 31 | * * |
| fep | 0:62cd296ba2a7 | 32 | * Help yourself get started quickly while simultaneously helping * |
| fep | 0:62cd296ba2a7 | 33 | * to support the FreeRTOS project by purchasing a FreeRTOS * |
| fep | 0:62cd296ba2a7 | 34 | * tutorial book, reference manual, or both: * |
| fep | 0:62cd296ba2a7 | 35 | * http://www.FreeRTOS.org/Documentation * |
| fep | 0:62cd296ba2a7 | 36 | * * |
| fep | 0:62cd296ba2a7 | 37 | *************************************************************************** |
| fep | 0:62cd296ba2a7 | 38 | |
| fep | 0:62cd296ba2a7 | 39 | http://www.FreeRTOS.org/FAQHelp.html - Having a problem? Start by reading |
| fep | 0:62cd296ba2a7 | 40 | the FAQ page "My application does not run, what could be wrong?". Have you |
| fep | 0:62cd296ba2a7 | 41 | defined configASSERT()? |
| fep | 0:62cd296ba2a7 | 42 | |
| fep | 0:62cd296ba2a7 | 43 | http://www.FreeRTOS.org/support - In return for receiving this top quality |
| fep | 0:62cd296ba2a7 | 44 | embedded software for free we request you assist our global community by |
| fep | 0:62cd296ba2a7 | 45 | participating in the support forum. |
| fep | 0:62cd296ba2a7 | 46 | |
| fep | 0:62cd296ba2a7 | 47 | http://www.FreeRTOS.org/training - Investing in training allows your team to |
| fep | 0:62cd296ba2a7 | 48 | be as productive as possible as early as possible. Now you can receive |
| fep | 0:62cd296ba2a7 | 49 | FreeRTOS training directly from Richard Barry, CEO of Real Time Engineers |
| fep | 0:62cd296ba2a7 | 50 | Ltd, and the world's leading authority on the world's leading RTOS. |
| fep | 0:62cd296ba2a7 | 51 | |
| fep | 0:62cd296ba2a7 | 52 | http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products, |
| fep | 0:62cd296ba2a7 | 53 | including FreeRTOS+Trace - an indispensable productivity tool, a DOS |
| fep | 0:62cd296ba2a7 | 54 | compatible FAT file system, and our tiny thread aware UDP/IP stack. |
| fep | 0:62cd296ba2a7 | 55 | |
| fep | 0:62cd296ba2a7 | 56 | http://www.FreeRTOS.org/labs - Where new FreeRTOS products go to incubate. |
| fep | 0:62cd296ba2a7 | 57 | Come and try FreeRTOS+TCP, our new open source TCP/IP stack for FreeRTOS. |
| fep | 0:62cd296ba2a7 | 58 | |
| fep | 0:62cd296ba2a7 | 59 | http://www.OpenRTOS.com - Real Time Engineers ltd. license FreeRTOS to High |
| fep | 0:62cd296ba2a7 | 60 | Integrity Systems ltd. to sell under the OpenRTOS brand. Low cost OpenRTOS |
| fep | 0:62cd296ba2a7 | 61 | licenses offer ticketed support, indemnification and commercial middleware. |
| fep | 0:62cd296ba2a7 | 62 | |
| fep | 0:62cd296ba2a7 | 63 | http://www.SafeRTOS.com - High Integrity Systems also provide a safety |
| fep | 0:62cd296ba2a7 | 64 | engineered and independently SIL3 certified version for use in safety and |
| fep | 0:62cd296ba2a7 | 65 | mission critical applications that require provable dependability. |
| fep | 0:62cd296ba2a7 | 66 | |
| fep | 0:62cd296ba2a7 | 67 | 1 tab == 4 spaces! |
| fep | 0:62cd296ba2a7 | 68 | */ |
| fep | 0:62cd296ba2a7 | 69 | |
| fep | 0:62cd296ba2a7 | 70 | |
| fep | 0:62cd296ba2a7 | 71 | #include <stdlib.h> |
| fep | 0:62cd296ba2a7 | 72 | #include "FreeRTOS.h" |
| fep | 0:62cd296ba2a7 | 73 | #include "list.h" |
| fep | 0:62cd296ba2a7 | 74 | |
| fep | 0:62cd296ba2a7 | 75 | /*----------------------------------------------------------- |
| fep | 0:62cd296ba2a7 | 76 | * PUBLIC LIST API documented in list.h |
| fep | 0:62cd296ba2a7 | 77 | *----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 78 | |
| fep | 0:62cd296ba2a7 | 79 | void vListInitialise( List_t * const pxList ) |
| fep | 0:62cd296ba2a7 | 80 | { |
| fep | 0:62cd296ba2a7 | 81 | /* The list structure contains a list item which is used to mark the |
| fep | 0:62cd296ba2a7 | 82 | end of the list. To initialise the list the list end is inserted |
| fep | 0:62cd296ba2a7 | 83 | as the only list entry. */ |
| fep | 0:62cd296ba2a7 | 84 | pxList->pxIndex = ( ListItem_t * ) &( pxList->xListEnd ); /*lint !e826 !e740 The mini list structure is used as the list end to save RAM. This is checked and valid. */ |
| fep | 0:62cd296ba2a7 | 85 | |
| fep | 0:62cd296ba2a7 | 86 | /* The list end value is the highest possible value in the list to |
| fep | 0:62cd296ba2a7 | 87 | ensure it remains at the end of the list. */ |
| fep | 0:62cd296ba2a7 | 88 | pxList->xListEnd.xItemValue = portMAX_DELAY; |
| fep | 0:62cd296ba2a7 | 89 | |
| fep | 0:62cd296ba2a7 | 90 | /* The list end next and previous pointers point to itself so we know |
| fep | 0:62cd296ba2a7 | 91 | when the list is empty. */ |
| fep | 0:62cd296ba2a7 | 92 | pxList->xListEnd.pxNext = ( ListItem_t * ) &( pxList->xListEnd ); /*lint !e826 !e740 The mini list structure is used as the list end to save RAM. This is checked and valid. */ |
| fep | 0:62cd296ba2a7 | 93 | pxList->xListEnd.pxPrevious = ( ListItem_t * ) &( pxList->xListEnd );/*lint !e826 !e740 The mini list structure is used as the list end to save RAM. This is checked and valid. */ |
| fep | 0:62cd296ba2a7 | 94 | |
| fep | 0:62cd296ba2a7 | 95 | pxList->uxNumberOfItems = ( UBaseType_t ) 0U; |
| fep | 0:62cd296ba2a7 | 96 | |
| fep | 0:62cd296ba2a7 | 97 | /* Write known values into the list if |
| fep | 0:62cd296ba2a7 | 98 | configUSE_LIST_DATA_INTEGRITY_CHECK_BYTES is set to 1. */ |
| fep | 0:62cd296ba2a7 | 99 | listSET_LIST_INTEGRITY_CHECK_1_VALUE( pxList ); |
| fep | 0:62cd296ba2a7 | 100 | listSET_LIST_INTEGRITY_CHECK_2_VALUE( pxList ); |
| fep | 0:62cd296ba2a7 | 101 | } |
| fep | 0:62cd296ba2a7 | 102 | /*-----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 103 | |
| fep | 0:62cd296ba2a7 | 104 | void vListInitialiseItem( ListItem_t * const pxItem ) |
| fep | 0:62cd296ba2a7 | 105 | { |
| fep | 0:62cd296ba2a7 | 106 | /* Make sure the list item is not recorded as being on a list. */ |
| fep | 0:62cd296ba2a7 | 107 | pxItem->pvContainer = NULL; |
| fep | 0:62cd296ba2a7 | 108 | |
| fep | 0:62cd296ba2a7 | 109 | /* Write known values into the list item if |
| fep | 0:62cd296ba2a7 | 110 | configUSE_LIST_DATA_INTEGRITY_CHECK_BYTES is set to 1. */ |
| fep | 0:62cd296ba2a7 | 111 | listSET_FIRST_LIST_ITEM_INTEGRITY_CHECK_VALUE( pxItem ); |
| fep | 0:62cd296ba2a7 | 112 | listSET_SECOND_LIST_ITEM_INTEGRITY_CHECK_VALUE( pxItem ); |
| fep | 0:62cd296ba2a7 | 113 | } |
| fep | 0:62cd296ba2a7 | 114 | /*-----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 115 | |
| fep | 0:62cd296ba2a7 | 116 | void vListInsertEnd( List_t * const pxList, ListItem_t * const pxNewListItem ) |
| fep | 0:62cd296ba2a7 | 117 | { |
| fep | 0:62cd296ba2a7 | 118 | ListItem_t * const pxIndex = pxList->pxIndex; |
| fep | 0:62cd296ba2a7 | 119 | |
| fep | 0:62cd296ba2a7 | 120 | /* Only effective when configASSERT() is also defined, these tests may catch |
| fep | 0:62cd296ba2a7 | 121 | the list data structures being overwritten in memory. They will not catch |
| fep | 0:62cd296ba2a7 | 122 | data errors caused by incorrect configuration or use of FreeRTOS. */ |
| fep | 0:62cd296ba2a7 | 123 | listTEST_LIST_INTEGRITY( pxList ); |
| fep | 0:62cd296ba2a7 | 124 | listTEST_LIST_ITEM_INTEGRITY( pxNewListItem ); |
| fep | 0:62cd296ba2a7 | 125 | |
| fep | 0:62cd296ba2a7 | 126 | /* Insert a new list item into pxList, but rather than sort the list, |
| fep | 0:62cd296ba2a7 | 127 | makes the new list item the last item to be removed by a call to |
| fep | 0:62cd296ba2a7 | 128 | listGET_OWNER_OF_NEXT_ENTRY(). */ |
| fep | 0:62cd296ba2a7 | 129 | pxNewListItem->pxNext = pxIndex; |
| fep | 0:62cd296ba2a7 | 130 | pxNewListItem->pxPrevious = pxIndex->pxPrevious; |
| fep | 0:62cd296ba2a7 | 131 | |
| fep | 0:62cd296ba2a7 | 132 | /* Only used during decision coverage testing. */ |
| fep | 0:62cd296ba2a7 | 133 | mtCOVERAGE_TEST_DELAY(); |
| fep | 0:62cd296ba2a7 | 134 | |
| fep | 0:62cd296ba2a7 | 135 | pxIndex->pxPrevious->pxNext = pxNewListItem; |
| fep | 0:62cd296ba2a7 | 136 | pxIndex->pxPrevious = pxNewListItem; |
| fep | 0:62cd296ba2a7 | 137 | |
| fep | 0:62cd296ba2a7 | 138 | /* Remember which list the item is in. */ |
| fep | 0:62cd296ba2a7 | 139 | pxNewListItem->pvContainer = ( void * ) pxList; |
| fep | 0:62cd296ba2a7 | 140 | |
| fep | 0:62cd296ba2a7 | 141 | ( pxList->uxNumberOfItems )++; |
| fep | 0:62cd296ba2a7 | 142 | } |
| fep | 0:62cd296ba2a7 | 143 | /*-----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 144 | |
| fep | 0:62cd296ba2a7 | 145 | void vListInsert( List_t * const pxList, ListItem_t * const pxNewListItem ) |
| fep | 0:62cd296ba2a7 | 146 | { |
| fep | 0:62cd296ba2a7 | 147 | ListItem_t *pxIterator; |
| fep | 0:62cd296ba2a7 | 148 | const TickType_t xValueOfInsertion = pxNewListItem->xItemValue; |
| fep | 0:62cd296ba2a7 | 149 | |
| fep | 0:62cd296ba2a7 | 150 | /* Only effective when configASSERT() is also defined, these tests may catch |
| fep | 0:62cd296ba2a7 | 151 | the list data structures being overwritten in memory. They will not catch |
| fep | 0:62cd296ba2a7 | 152 | data errors caused by incorrect configuration or use of FreeRTOS. */ |
| fep | 0:62cd296ba2a7 | 153 | listTEST_LIST_INTEGRITY( pxList ); |
| fep | 0:62cd296ba2a7 | 154 | listTEST_LIST_ITEM_INTEGRITY( pxNewListItem ); |
| fep | 0:62cd296ba2a7 | 155 | |
| fep | 0:62cd296ba2a7 | 156 | /* Insert the new list item into the list, sorted in xItemValue order. |
| fep | 0:62cd296ba2a7 | 157 | |
| fep | 0:62cd296ba2a7 | 158 | If the list already contains a list item with the same item value then the |
| fep | 0:62cd296ba2a7 | 159 | new list item should be placed after it. This ensures that TCB's which are |
| fep | 0:62cd296ba2a7 | 160 | stored in ready lists (all of which have the same xItemValue value) get a |
| fep | 0:62cd296ba2a7 | 161 | share of the CPU. However, if the xItemValue is the same as the back marker |
| fep | 0:62cd296ba2a7 | 162 | the iteration loop below will not end. Therefore the value is checked |
| fep | 0:62cd296ba2a7 | 163 | first, and the algorithm slightly modified if necessary. */ |
| fep | 0:62cd296ba2a7 | 164 | if( xValueOfInsertion == portMAX_DELAY ) |
| fep | 0:62cd296ba2a7 | 165 | { |
| fep | 0:62cd296ba2a7 | 166 | pxIterator = pxList->xListEnd.pxPrevious; |
| fep | 0:62cd296ba2a7 | 167 | } |
| fep | 0:62cd296ba2a7 | 168 | else |
| fep | 0:62cd296ba2a7 | 169 | { |
| fep | 0:62cd296ba2a7 | 170 | /* *** NOTE *********************************************************** |
| fep | 0:62cd296ba2a7 | 171 | If you find your application is crashing here then likely causes are |
| fep | 0:62cd296ba2a7 | 172 | listed below. In addition see http://www.freertos.org/FAQHelp.html for |
| fep | 0:62cd296ba2a7 | 173 | more tips, and ensure configASSERT() is defined! |
| fep | 0:62cd296ba2a7 | 174 | http://www.freertos.org/a00110.html#configASSERT |
| fep | 0:62cd296ba2a7 | 175 | |
| fep | 0:62cd296ba2a7 | 176 | 1) Stack overflow - |
| fep | 0:62cd296ba2a7 | 177 | see http://www.freertos.org/Stacks-and-stack-overflow-checking.html |
| fep | 0:62cd296ba2a7 | 178 | 2) Incorrect interrupt priority assignment, especially on Cortex-M |
| fep | 0:62cd296ba2a7 | 179 | parts where numerically high priority values denote low actual |
| fep | 0:62cd296ba2a7 | 180 | interrupt priorities, which can seem counter intuitive. See |
| fep | 0:62cd296ba2a7 | 181 | http://www.freertos.org/RTOS-Cortex-M3-M4.html and the definition |
| fep | 0:62cd296ba2a7 | 182 | of configMAX_SYSCALL_INTERRUPT_PRIORITY on |
| fep | 0:62cd296ba2a7 | 183 | http://www.freertos.org/a00110.html |
| fep | 0:62cd296ba2a7 | 184 | 3) Calling an API function from within a critical section or when |
| fep | 0:62cd296ba2a7 | 185 | the scheduler is suspended, or calling an API function that does |
| fep | 0:62cd296ba2a7 | 186 | not end in "FromISR" from an interrupt. |
| fep | 0:62cd296ba2a7 | 187 | 4) Using a queue or semaphore before it has been initialised or |
| fep | 0:62cd296ba2a7 | 188 | before the scheduler has been started (are interrupts firing |
| fep | 0:62cd296ba2a7 | 189 | before vTaskStartScheduler() has been called?). |
| fep | 0:62cd296ba2a7 | 190 | **********************************************************************/ |
| fep | 0:62cd296ba2a7 | 191 | |
| fep | 0:62cd296ba2a7 | 192 | for( pxIterator = ( ListItem_t * ) &( pxList->xListEnd ); pxIterator->pxNext->xItemValue <= xValueOfInsertion; pxIterator = pxIterator->pxNext ) /*lint !e826 !e740 The mini list structure is used as the list end to save RAM. This is checked and valid. */ |
| fep | 0:62cd296ba2a7 | 193 | { |
| fep | 0:62cd296ba2a7 | 194 | /* There is nothing to do here, just iterating to the wanted |
| fep | 0:62cd296ba2a7 | 195 | insertion position. */ |
| fep | 0:62cd296ba2a7 | 196 | } |
| fep | 0:62cd296ba2a7 | 197 | } |
| fep | 0:62cd296ba2a7 | 198 | |
| fep | 0:62cd296ba2a7 | 199 | pxNewListItem->pxNext = pxIterator->pxNext; |
| fep | 0:62cd296ba2a7 | 200 | pxNewListItem->pxNext->pxPrevious = pxNewListItem; |
| fep | 0:62cd296ba2a7 | 201 | pxNewListItem->pxPrevious = pxIterator; |
| fep | 0:62cd296ba2a7 | 202 | pxIterator->pxNext = pxNewListItem; |
| fep | 0:62cd296ba2a7 | 203 | |
| fep | 0:62cd296ba2a7 | 204 | /* Remember which list the item is in. This allows fast removal of the |
| fep | 0:62cd296ba2a7 | 205 | item later. */ |
| fep | 0:62cd296ba2a7 | 206 | pxNewListItem->pvContainer = ( void * ) pxList; |
| fep | 0:62cd296ba2a7 | 207 | |
| fep | 0:62cd296ba2a7 | 208 | ( pxList->uxNumberOfItems )++; |
| fep | 0:62cd296ba2a7 | 209 | } |
| fep | 0:62cd296ba2a7 | 210 | /*-----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 211 | |
| fep | 0:62cd296ba2a7 | 212 | UBaseType_t uxListRemove( ListItem_t * const pxItemToRemove ) |
| fep | 0:62cd296ba2a7 | 213 | { |
| fep | 0:62cd296ba2a7 | 214 | /* The list item knows which list it is in. Obtain the list from the list |
| fep | 0:62cd296ba2a7 | 215 | item. */ |
| fep | 0:62cd296ba2a7 | 216 | List_t * const pxList = ( List_t * ) pxItemToRemove->pvContainer; |
| fep | 0:62cd296ba2a7 | 217 | |
| fep | 0:62cd296ba2a7 | 218 | pxItemToRemove->pxNext->pxPrevious = pxItemToRemove->pxPrevious; |
| fep | 0:62cd296ba2a7 | 219 | pxItemToRemove->pxPrevious->pxNext = pxItemToRemove->pxNext; |
| fep | 0:62cd296ba2a7 | 220 | |
| fep | 0:62cd296ba2a7 | 221 | /* Only used during decision coverage testing. */ |
| fep | 0:62cd296ba2a7 | 222 | mtCOVERAGE_TEST_DELAY(); |
| fep | 0:62cd296ba2a7 | 223 | |
| fep | 0:62cd296ba2a7 | 224 | /* Make sure the index is left pointing to a valid item. */ |
| fep | 0:62cd296ba2a7 | 225 | if( pxList->pxIndex == pxItemToRemove ) |
| fep | 0:62cd296ba2a7 | 226 | { |
| fep | 0:62cd296ba2a7 | 227 | pxList->pxIndex = pxItemToRemove->pxPrevious; |
| fep | 0:62cd296ba2a7 | 228 | } |
| fep | 0:62cd296ba2a7 | 229 | else |
| fep | 0:62cd296ba2a7 | 230 | { |
| fep | 0:62cd296ba2a7 | 231 | mtCOVERAGE_TEST_MARKER(); |
| fep | 0:62cd296ba2a7 | 232 | } |
| fep | 0:62cd296ba2a7 | 233 | |
| fep | 0:62cd296ba2a7 | 234 | pxItemToRemove->pvContainer = NULL; |
| fep | 0:62cd296ba2a7 | 235 | ( pxList->uxNumberOfItems )--; |
| fep | 0:62cd296ba2a7 | 236 | |
| fep | 0:62cd296ba2a7 | 237 | return pxList->uxNumberOfItems; |
| fep | 0:62cd296ba2a7 | 238 | } |
| fep | 0:62cd296ba2a7 | 239 | /*-----------------------------------------------------------*/ |
| fep | 0:62cd296ba2a7 | 240 | |
| fep | 0:62cd296ba2a7 | 241 |