diff options
author | Joel Sherrill <joel.sherrill@OARcorp.com> | 2004-11-29 22:45:43 +0000 |
---|---|---|
committer | Joel Sherrill <joel.sherrill@OARcorp.com> | 2004-11-29 22:45:43 +0000 |
commit | 9b3f187a02049d81a63bb85497c5a4ebb9d37a97 (patch) | |
tree | 7796f90657fdd839f998a88f2cc4d0688ffb29c9 /cpukit/score/src | |
parent | Add another module ID code. (diff) | |
download | rtems-9b3f187a02049d81a63bb85497c5a4ebb9d37a97.tar.bz2 |
2004-11-29 Joel Sherrill <joel@OARcorp.com>
* libcsupport/src/mallocfreespace.c, rtems/Makefile.am,
rtems/include/rtems/rtems/region.h, score/Makefile.am,
score/include/rtems/score/heap.h, score/src/heapgetinfo.c: Add
capability to return information about just the free blocks in a
region or heap. Also changed the semantics of free space available
to be the largest block of memory that can be allocated.
* rtems/src/regiongetfreeinfo.c, score/src/heapgetfreeinfo.c: New files.
: score/include/rtems/score/object.h,
score/src/objectinitializeinformation.c: Remove warning.
Diffstat (limited to 'cpukit/score/src')
-rw-r--r-- | cpukit/score/src/heapgetfreeinfo.c | 58 | ||||
-rw-r--r-- | cpukit/score/src/heapgetinfo.c | 24 | ||||
-rw-r--r-- | cpukit/score/src/objectinitializeinformation.c | 4 |
3 files changed, 76 insertions, 10 deletions
diff --git a/cpukit/score/src/heapgetfreeinfo.c b/cpukit/score/src/heapgetfreeinfo.c new file mode 100644 index 0000000000..8f7fddb059 --- /dev/null +++ b/cpukit/score/src/heapgetfreeinfo.c @@ -0,0 +1,58 @@ +/* + * Heap Handler + * + * COPYRIGHT (c) 1989-2004. + * On-Line Applications Research Corporation (OAR). + * + * The license and distribution terms for this file may be + * found in the file LICENSE in this distribution or at + * http://www.rtems.com/license/LICENSE. + * + * $Id$ + */ + + +#include <rtems/system.h> +#include <rtems/score/sysstate.h> +#include <rtems/score/heap.h> + +/*PAGE + * + * _Heap_Get_free_information + * + * This heap routine returns information about the free blocks + * in the specified heap. + * + * Input parameters: + * the_heap - pointer to heap header. + * info - pointer to the free block information. + * + * Output parameters: + * returns - free block information filled in. + */ + +void _Heap_Get_free_information( + Heap_Control *the_heap, + Heap_Information *info +) +{ + Heap_Block *the_block; + + info->number = 0; + info->largest = 0; + info->total = 0; + + for ( the_block = the_heap->first; + ; + the_block = the_block->next ) { + if ( the_block == _Heap_Tail( the_heap ) ) + return; + + info->number++; + info->largest = 0; + info->total += the_block->front_flag; + + if ( the_block->front_flag >= info->largest ) + info->largest = the_block->front_flag; + } +} diff --git a/cpukit/score/src/heapgetinfo.c b/cpukit/score/src/heapgetinfo.c index b3f878f5f2..9e71ea7e43 100644 --- a/cpukit/score/src/heapgetinfo.c +++ b/cpukit/score/src/heapgetinfo.c @@ -40,12 +40,15 @@ Heap_Get_information_status _Heap_Get_information( Heap_Block *the_block = 0; /* avoid warnings */ Heap_Block *next_block = 0; /* avoid warnings */ int notdone = 1; + uint32_t size; - the_info->free_blocks = 0; - the_info->free_size = 0; - the_info->used_blocks = 0; - the_info->used_size = 0; + the_info->Free.number = 0; + the_info->Free.total = 0; + the_info->Free.largest = 0; + the_info->Used.number = 0; + the_info->Used.total = 0; + the_info->Used.largest = 0; /* * We don't want to allow walking the heap until we have @@ -72,12 +75,17 @@ Heap_Get_information_status _Heap_Get_information( * Accumulate size */ + size = _Heap_Block_size(the_block); if ( _Heap_Is_block_free(the_block) ) { - the_info->free_blocks++; - the_info->free_size += _Heap_Block_size(the_block); + the_info->Free.number++; + the_info->Free.total += size; + if ( size > the_info->Free.largest ) + the_info->Free.largest = size; } else { - the_info->used_blocks++; - the_info->used_size += _Heap_Block_size(the_block); + the_info->Used.number++; + the_info->Used.total += size; + if ( size > the_info->Used.largest ) + the_info->Used.largest = size; } /* diff --git a/cpukit/score/src/objectinitializeinformation.c b/cpukit/score/src/objectinitializeinformation.c index bafc1d935d..ffaf91674a 100644 --- a/cpukit/score/src/objectinitializeinformation.c +++ b/cpukit/score/src/objectinitializeinformation.c @@ -38,7 +38,7 @@ * maximum_name_length - maximum length of each object's name * When multiprocessing is configured, * supports_global - TRUE if this is a global object class - * extract_callout - pointer to threadq extract callout if MP + * extract_callout - pointer to threadq extract callout * * Output parameters: NONE */ @@ -54,7 +54,7 @@ void _Objects_Initialize_information( #if defined(RTEMS_MULTIPROCESSING) , boolean supports_global, - Objects_Thread_queue_Extract_callout *extract + Objects_Thread_queue_Extract_callout extract #endif ) { |