uc-sdk
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
heap_1.c
Go to the documentation of this file.
1 /*
2  FreeRTOS V7.5.3 - Copyright (C) 2013 Real Time Engineers Ltd.
3  All rights reserved
4 
5  VISIT http://www.FreeRTOS.org TO ENSURE YOU ARE USING THE LATEST VERSION.
6 
7  ***************************************************************************
8  * *
9  * FreeRTOS provides completely free yet professionally developed, *
10  * robust, strictly quality controlled, supported, and cross *
11  * platform software that has become a de facto standard. *
12  * *
13  * Help yourself get started quickly and support the FreeRTOS *
14  * project by purchasing a FreeRTOS tutorial book, reference *
15  * manual, or both from: http://www.FreeRTOS.org/Documentation *
16  * *
17  * Thank you! *
18  * *
19  ***************************************************************************
20 
21  This file is part of the FreeRTOS distribution.
22 
23  FreeRTOS is free software; you can redistribute it and/or modify it under
24  the terms of the GNU General Public License (version 2) as published by the
25  Free Software Foundation >>!AND MODIFIED BY!<< the FreeRTOS exception.
26 
27  >>! NOTE: The modification to the GPL is included to allow you to distribute
28  >>! a combined work that includes FreeRTOS without being obliged to provide
29  >>! the source code for proprietary components outside of the FreeRTOS
30  >>! kernel.
31 
32  FreeRTOS is distributed in the hope that it will be useful, but WITHOUT ANY
33  WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
34  FOR A PARTICULAR PURPOSE. Full license text is available from the following
35  link: http://www.freertos.org/a00114.html
36 
37  1 tab == 4 spaces!
38 
39  ***************************************************************************
40  * *
41  * Having a problem? Start by reading the FAQ "My application does *
42  * not run, what could be wrong?" *
43  * *
44  * http://www.FreeRTOS.org/FAQHelp.html *
45  * *
46  ***************************************************************************
47 
48  http://www.FreeRTOS.org - Documentation, books, training, latest versions,
49  license and Real Time Engineers Ltd. contact details.
50 
51  http://www.FreeRTOS.org/plus - A selection of FreeRTOS ecosystem products,
52  including FreeRTOS+Trace - an indispensable productivity tool, a DOS
53  compatible FAT file system, and our tiny thread aware UDP/IP stack.
54 
55  http://www.OpenRTOS.com - Real Time Engineers ltd license FreeRTOS to High
56  Integrity Systems to sell under the OpenRTOS brand. Low cost OpenRTOS
57  licenses offer ticketed support, indemnification and middleware.
58 
59  http://www.SafeRTOS.com - High Integrity Systems also provide a safety
60  engineered and independently SIL3 certified version for use in safety and
61  mission critical applications that require provable dependability.
62 
63  1 tab == 4 spaces!
64 */
65 
66 
67 /*
68  * The simplest possible implementation of pvPortMalloc(). Note that this
69  * implementation does NOT allow allocated memory to be freed again.
70  *
71  * See heap_2.c, heap_3.c and heap_4.c for alternative implementations, and the
72  * memory management pages of http://www.FreeRTOS.org for more information.
73  */
74 #include <stdlib.h>
75 
76 /* Defining MPU_WRAPPERS_INCLUDED_FROM_API_FILE prevents task.h from redefining
77 all the API functions to use the MPU wrappers. That should only be done when
78 task.h is included from an application file. */
79 #define MPU_WRAPPERS_INCLUDED_FROM_API_FILE
80 
81 #include "FreeRTOS.h"
82 #include "task.h"
83 
84 #undef MPU_WRAPPERS_INCLUDED_FROM_API_FILE
85 
86 /* A few bytes might be lost to byte aligning the heap start address. */
87 #define configADJUSTED_HEAP_SIZE ( configTOTAL_HEAP_SIZE - portBYTE_ALIGNMENT )
88 
89 /* Allocate the memory for the heap. */
90 static unsigned char ucHeap[ configTOTAL_HEAP_SIZE ];
91 static size_t xNextFreeByte = ( size_t ) 0;
92 
93 /*-----------------------------------------------------------*/
94 
95 void *pvPortMalloc( size_t xWantedSize )
96 {
97 void *pvReturn = NULL;
98 static unsigned char *pucAlignedHeap = NULL;
99 
100  /* Ensure that blocks are always aligned to the required number of bytes. */
101  #if portBYTE_ALIGNMENT != 1
102  if( xWantedSize & portBYTE_ALIGNMENT_MASK )
103  {
104  /* Byte alignment required. */
105  xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );
106  }
107  #endif
108 
109  vTaskSuspendAll();
110  {
111  if( pucAlignedHeap == NULL )
112  {
113  /* Ensure the heap starts on a correctly aligned boundary. */
114  pucAlignedHeap = ( unsigned char * ) ( ( ( portPOINTER_SIZE_TYPE ) &ucHeap[ portBYTE_ALIGNMENT ] ) & ( ( portPOINTER_SIZE_TYPE ) ~portBYTE_ALIGNMENT_MASK ) );
115  }
116 
117  /* Check there is enough room left for the allocation. */
118  if( ( ( xNextFreeByte + xWantedSize ) < configADJUSTED_HEAP_SIZE ) &&
119  ( ( xNextFreeByte + xWantedSize ) > xNextFreeByte ) )/* Check for overflow. */
120  {
121  /* Return the next free byte then increment the index past this
122  block. */
123  pvReturn = pucAlignedHeap + xNextFreeByte;
124  xNextFreeByte += xWantedSize;
125  }
126 
127  traceMALLOC( pvReturn, xWantedSize );
128  }
129  xTaskResumeAll();
130 
131  #if( configUSE_MALLOC_FAILED_HOOK == 1 )
132  {
133  if( pvReturn == NULL )
134  {
135  extern void vApplicationMallocFailedHook( void );
136  vApplicationMallocFailedHook();
137  }
138  }
139  #endif
140 
141  return pvReturn;
142 }
143 /*-----------------------------------------------------------*/
144 
145 void vPortFree( void *pv )
146 {
147  /* Memory cannot be freed using this scheme. See heap_2.c, heap_3.c and
148  heap_4.c for alternative implementations, and the memory management pages of
149  http://www.FreeRTOS.org for more information. */
150  ( void ) pv;
151 
152  /* Force an assert as it is invalid to call this function. */
153  configASSERT( pv == NULL );
154 }
155 /*-----------------------------------------------------------*/
156 
158 {
159  /* Only required when static memory is not cleared. */
160  xNextFreeByte = ( size_t ) 0;
161 }
162 /*-----------------------------------------------------------*/
163 
164 size_t xPortGetFreeHeapSize( void )
165 {
166  return ( configADJUSTED_HEAP_SIZE - xNextFreeByte );
167 }
168 
169 
170