summaryrefslogtreecommitdiffstats
path: root/cpukit/libcsupport/src/rtems_heap_greedy.c
diff options
context:
space:
mode:
authorChris Johns <chrisj@rtems.org>2021-02-09 12:48:07 +1100
committerChris Johns <chrisj@rtems.org>2021-02-10 17:28:32 +1100
commit03dff2019f6972f9b202b15d57ab295d706d86cd (patch)
tree6e05487294aa5950f24ad7a17dc319ec7d19df0c /cpukit/libcsupport/src/rtems_heap_greedy.c
parentbsp/riscv: Re-license to BSD-2-Clause (diff)
downloadrtems-03dff2019f6972f9b202b15d57ab295d706d86cd.tar.bz2
libcsupport: Add sbrk greedy support to consume all sbrk memory
- Move the heap sbrk code into a separate routnine. - Update heap and workspace greedy allocators to use the common sbrk greedy support. Closes #3982
Diffstat (limited to 'cpukit/libcsupport/src/rtems_heap_greedy.c')
-rw-r--r--cpukit/libcsupport/src/rtems_heap_greedy.c19
1 files changed, 7 insertions, 12 deletions
diff --git a/cpukit/libcsupport/src/rtems_heap_greedy.c b/cpukit/libcsupport/src/rtems_heap_greedy.c
index c02e48d962..94c28d7f16 100644
--- a/cpukit/libcsupport/src/rtems_heap_greedy.c
+++ b/cpukit/libcsupport/src/rtems_heap_greedy.c
@@ -25,25 +25,17 @@
#include "malloc_p.h"
+#define SBRK_ALLOC_SIZE (128 * 1024UL * 1024UL)
+
void *rtems_heap_greedy_allocate(
const uintptr_t *block_sizes,
size_t block_count
)
{
Heap_Control *heap = RTEMS_Malloc_Heap;
- size_t size = 128 * 1024 * 1024;
void *opaque;
- while ( size > 0 ) {
- opaque = (*rtems_malloc_extend_handler)( heap, size );
- if ( opaque == NULL ) {
- size >>= 1;
- } else {
- if ( rtems_malloc_dirty_helper != NULL ) {
- (*rtems_malloc_dirty_helper)( opaque, size );
- }
- }
- }
+ rtems_heap_sbrk_greedy_allocate( heap, SBRK_ALLOC_SIZE );
_RTEMS_Lock_allocator();
opaque = _Heap_Greedy_allocate( RTEMS_Malloc_Heap, block_sizes, block_count );
@@ -56,11 +48,14 @@ void *rtems_heap_greedy_allocate_all_except_largest(
uintptr_t *allocatable_size
)
{
+ Heap_Control *heap = RTEMS_Malloc_Heap;
void *opaque;
+ rtems_heap_sbrk_greedy_allocate( heap, SBRK_ALLOC_SIZE );
+
_RTEMS_Lock_allocator();
opaque = _Heap_Greedy_allocate_all_except_largest(
- RTEMS_Malloc_Heap,
+ heap,
allocatable_size
);
_RTEMS_Unlock_allocator();