[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