[rtems commit] score: Fix _Objects_Shrink_information()

Sebastian Huber sebh at rtems.org
Mon Jan 7 14:05:03 UTC 2013


Module:    rtems
Branch:    master
Commit:    b41f2e226b4b76961a65d6e4cffafb76217c6b82
Changeset: http://git.rtems.org/rtems/commit/?id=b41f2e226b4b76961a65d6e4cffafb76217c6b82

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Thu Jan  3 17:07:14 2013 +0100

score: Fix _Objects_Shrink_information()

The chain iteration was wrong.  The chain tail is not an object.

---

 cpukit/score/src/objectshrinkinformation.c |   36 ++++++++++++---------------
 1 files changed, 16 insertions(+), 20 deletions(-)

diff --git a/cpukit/score/src/objectshrinkinformation.c b/cpukit/score/src/objectshrinkinformation.c
index de32f24..466a85d 100644
--- a/cpukit/score/src/objectshrinkinformation.c
+++ b/cpukit/score/src/objectshrinkinformation.c
@@ -34,12 +34,9 @@ void _Objects_Shrink_information(
   Objects_Information *information
 )
 {
-  Objects_Control  *the_object;
-  Objects_Control  *extract_me;
   uint32_t          block_count;
   uint32_t          block;
   uint32_t          index_base;
-  uint32_t          index;
 
   /*
    * Search the list to find block or chunk with all objects inactive.
@@ -52,25 +49,24 @@ void _Objects_Shrink_information(
   for ( block = 0; block < block_count; block++ ) {
     if ( information->inactive_per_block[ block ] ==
          information->allocation_size ) {
+      Chain_Node       *node = _Chain_First( &information->Inactive );
+      const Chain_Node *tail = _Chain_Immutable_tail( &information->Inactive );
+      uint32_t          index_end = index_base + information->allocation_size;
 
-      /*
-       *  Assume the Inactive chain is never empty at this point
-       */
-      the_object = (Objects_Control *) _Chain_First( &information->Inactive );
+      while ( node != tail ) {
+        Objects_Control *object = (Objects_Control *) node;
+        uint32_t         index = _Objects_Get_index( object->id );
+
+        /*
+         *  Get the next node before the node is extracted
+         */
+        node = _Chain_Next( node );
+
+        if ( index >= index_base && index < index_end ) {
+          _Chain_Extract( &object->Node );
+        }
+      }
 
-      do {
-         index = _Objects_Get_index( the_object->id );
-         /*
-          *  Get the next node before the node is extracted
-          */
-         extract_me = the_object;
-         the_object = (Objects_Control *) the_object->Node.next;
-         if ((index >= index_base) &&
-             (index < (index_base + information->allocation_size))) {
-           _Chain_Extract( &extract_me->Node );
-         }
-       }
-       while ( the_object );
       /*
        *  Free the memory and reset the structures in the object' information
        */




More information about the vc mailing list