diff options
author | Glenn Humphrey <glenn.humphrey@oarcorp.com> | 2007-11-27 17:38:11 +0000 |
---|---|---|
committer | Glenn Humphrey <glenn.humphrey@oarcorp.com> | 2007-11-27 17:38:11 +0000 |
commit | 5700b804e2443135a07c6ff5f65a024e7be412fd (patch) | |
tree | 8177dd1b95bd7698eac495c8403c6bf7828e2cf3 /cpukit/rtems/src/regionreturnsegment.c | |
parent | 2007-11-27 Joel Sherrill <joel.sherrill@oarcorp.com> (diff) | |
download | rtems-5700b804e2443135a07c6ff5f65a024e7be412fd.tar.bz2 |
2007-11-27 Glenn Humphrey <glenn.humphrey@OARcorp.com>
* rtems/src/regioncreate.c, rtems/src/regiondelete.c,
rtems/src/regionextend.c, rtems/src/regiongetfreeinfo.c,
rtems/src/regiongetinfo.c, rtems/src/regiongetsegment.c,
rtems/src/regiongetsegmentsize.c, rtems/src/regionresizesegment.c,
rtems/src/regionreturnsegment.c: Restructed to move the OBJECTS_LOCAL
case to the top of the switch statement, have a single exit with one
call to _RTEMS_Unlock_allocator and eliminate the fall-through return
of RTEMS_INTERNAL_ERROR. These changes produced simplier assembly
code and allowed for complete test coverage.
Diffstat (limited to 'cpukit/rtems/src/regionreturnsegment.c')
-rw-r--r-- | cpukit/rtems/src/regionreturnsegment.c | 65 |
1 files changed, 34 insertions, 31 deletions
diff --git a/cpukit/rtems/src/regionreturnsegment.c b/cpukit/rtems/src/regionreturnsegment.c index 4c08b44d59..0da5f1ca79 100644 --- a/cpukit/rtems/src/regionreturnsegment.c +++ b/cpukit/rtems/src/regionreturnsegment.c @@ -54,55 +54,58 @@ rtems_status_code rtems_region_return_segment( void *segment ) { - register Region_Control *the_region; Objects_Locations location; + rtems_status_code return_status = RTEMS_INTERNAL_ERROR; #ifdef RTEMS_REGION_FREE_SHRED_PATTERN uint32_t size; #endif int status; + register Region_Control *the_region; _RTEMS_Lock_allocator(); - the_region = _Region_Get( id, &location ); - switch ( location ) { - -#if defined(RTEMS_MULTIPROCESSING) - case OBJECTS_REMOTE: /* this error cannot be returned */ - _RTEMS_Unlock_allocator(); - return RTEMS_INTERNAL_ERROR; -#endif - case OBJECTS_ERROR: - _RTEMS_Unlock_allocator(); - return RTEMS_INVALID_ID; + the_region = _Region_Get( id, &location ); + switch ( location ) { - case OBJECTS_LOCAL: + case OBJECTS_LOCAL: - _Region_Debug_Walk( the_region, 3 ); + _Region_Debug_Walk( the_region, 3 ); #ifdef RTEMS_REGION_FREE_SHRED_PATTERN - if ( _Heap_Size_of_user_area( &the_region->Memory, segment, &size ) ) { - memset( segment, (RTEMS_REGION_FREE_SHRED_PATTERN & 0xFF), size ); - } else { - _RTEMS_Unlock_allocator(); - return RTEMS_INVALID_ADDRESS; - } + if ( !_Heap_Size_of_user_area( &the_region->Memory, segment, &size ) ) + return_status = RTEMS_INVALID_ADDRESS; + else { + memset( segment, (RTEMS_REGION_FREE_SHRED_PATTERN & 0xFF), size ); #endif + status = _Region_Free_segment( the_region, segment ); - status = _Region_Free_segment( the_region, segment ); + _Region_Debug_Walk( the_region, 4 ); - _Region_Debug_Walk( the_region, 4 ); + if ( !status ) + return_status = RTEMS_INVALID_ADDRESS; - if ( !status ) { - _RTEMS_Unlock_allocator(); - return RTEMS_INVALID_ADDRESS; - } + else { + the_region->number_of_used_blocks -= 1; - the_region->number_of_used_blocks -= 1; + _Region_Process_queue(the_region); /* unlocks allocator */ - _Region_Process_queue(the_region); /* unlocks allocator internally */ + return RTEMS_SUCCESSFUL; + } +#ifdef RTEMS_REGION_FREE_SHRED_PATTERN + } +#endif + break; + +#if defined(RTEMS_MULTIPROCESSING) + case OBJECTS_REMOTE: /* this error cannot be returned */ + break; +#endif - return RTEMS_SUCCESSFUL; - } + case OBJECTS_ERROR: + return_status = RTEMS_INVALID_ID; + break; + } - return RTEMS_INTERNAL_ERROR; /* unreached - only to remove warnings */ + _RTEMS_Unlock_allocator(); + return return_status; } |