summaryrefslogtreecommitdiffstats
path: root/cpukit/score
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
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')
-rw-r--r--cpukit/score/Makefile.am3
-rw-r--r--cpukit/score/include/rtems/score/heap.h43
-rw-r--r--cpukit/score/include/rtems/score/object.h4
-rw-r--r--cpukit/score/src/heapgetfreeinfo.c58
-rw-r--r--cpukit/score/src/heapgetinfo.c24
-rw-r--r--cpukit/score/src/objectinitializeinformation.c4
6 files changed, 115 insertions, 21 deletions
diff --git a/cpukit/score/Makefile.am b/cpukit/score/Makefile.am
index ab4af5f5ca..3188f22f9d 100644
--- a/cpukit/score/Makefile.am
+++ b/cpukit/score/Makefile.am
@@ -94,7 +94,8 @@ CORE_SEMAPHORE_C_FILES = src/coresem.c src/coresemflush.c src/coresemseize.c \
src/coresemsurrender.c
HEAP_C_FILES = src/heap.c src/heapallocate.c src/heapextend.c src/heapfree.c \
- src/heapsizeofuserarea.c src/heapwalk.c src/heapgetinfo.c
+ src/heapsizeofuserarea.c src/heapwalk.c src/heapgetinfo.c \
+ src/heapgetfreeinfo.c
OBJECT_C_FILES = src/object.c src/objectallocate.c \
src/objectallocatebyindex.c src/objectclearname.c \
diff --git a/cpukit/score/include/rtems/score/heap.h b/cpukit/score/include/rtems/score/heap.h
index 8b3f8f9a9b..c68bfd0fd1 100644
--- a/cpukit/score/include/rtems/score/heap.h
+++ b/cpukit/score/include/rtems/score/heap.h
@@ -55,17 +55,30 @@ typedef enum {
} Heap_Get_information_status;
/**
+ * Information block returned by the Heap routines used to
+ * obtain statistics. This information is returned about
+ * either free or used blocks.
+ */
+
+typedef struct {
+ /** Number of blocks of this type. */
+ uint32_t number;
+ /** Largest blocks of this type. */
+ uint32_t largest;
+ /** Total size of the blocks of this type. */
+ uint32_t total;
+
+} Heap_Information;
+
+
+/**
* Information block returned by _Heap_Get_information
*/
typedef struct {
- /** This field is the number of free blocks in this heap. */
- uint32_t free_blocks;
- /** This field is the amount of free memory in this heap. */
- uint32_t free_size;
- /** This field is the number of used blocks in this heap. */
- uint32_t used_blocks;
- /** This field is the amount of used memory in this heap. */
- uint32_t used_size;
+ /** This field is information on the used blocks in the heap. */
+ Heap_Information Free;
+ /** This field is information on the used blocks in the heap. */
+ Heap_Information Used;
} Heap_Information_block;
/**
@@ -278,6 +291,20 @@ Heap_Get_information_status _Heap_Get_information(
Heap_Information_block *the_info
);
+/**
+ * This heap routine returns information about the free blocks
+ * in the specified heap.
+ *
+ * @param the_heap (in) pointer to heap header.
+ * @param info (in) pointer to the free block information.
+ *
+ * @return free block information filled in.
+ */
+
+void _Heap_Get_free_information(
+ Heap_Control *the_heap,
+ Heap_Information *info
+);
#ifndef __RTEMS_APPLICATION__
#include <rtems/score/heap.inl>
diff --git a/cpukit/score/include/rtems/score/object.h b/cpukit/score/include/rtems/score/object.h
index 1be8f214d7..f56382887e 100644
--- a/cpukit/score/include/rtems/score/object.h
+++ b/cpukit/score/include/rtems/score/object.h
@@ -231,7 +231,7 @@ typedef struct {
void **object_blocks; /* the object memory to remove */
boolean is_string; /* TRUE if names are strings */
uint16_t name_length; /* maximum length of names */
- Objects_Thread_queue_Extract_callout *extract;
+ Objects_Thread_queue_Extract_callout extract;
#if defined(RTEMS_MULTIPROCESSING)
Chain_Control *global_table; /* pointer to global table */
#endif
@@ -351,7 +351,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
);
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
)
{