summaryrefslogtreecommitdiffstats
path: root/cpukit/score/src
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2004-11-29 22:45:43 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2004-11-29 22:45:43 +0000
commit9b3f187a02049d81a63bb85497c5a4ebb9d37a97 (patch)
tree7796f90657fdd839f998a88f2cc4d0688ffb29c9 /cpukit/score/src
parentAdd another module ID code. (diff)
downloadrtems-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.c58
-rw-r--r--cpukit/score/src/heapgetinfo.c24
-rw-r--r--cpukit/score/src/objectinitializeinformation.c4
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
)
{