File indexing completed on 2025-05-11 08:24:26
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038 #ifdef HAVE_CONFIG_H
0039 #include "config.h"
0040 #endif
0041
0042 #include <rtems/score/objectimpl.h>
0043 #include <rtems/score/assert.h>
0044 #include <rtems/score/chainimpl.h>
0045 #include <rtems/score/wkspace.h>
0046
0047 void _Objects_Free_objects_block(
0048 Objects_Information *information,
0049 Objects_Maximum block
0050 )
0051 {
0052 Objects_Maximum objects_per_block;
0053 Objects_Maximum index_base;
0054 Objects_Maximum index_end;
0055 Chain_Node *node;
0056 const Chain_Node *tail;
0057
0058 objects_per_block = information->objects_per_block;
0059
0060 _Assert( _Objects_Allocator_is_owner() );
0061 _Assert( _Objects_Is_auto_extend( information ) );
0062 _Assert( block >= 1 );
0063 _Assert(
0064 block < _Objects_Get_maximum_index( information ) / objects_per_block
0065 );
0066
0067 index_base = block * objects_per_block;
0068 index_end = index_base + objects_per_block;
0069 node = _Chain_First( &information->Inactive );
0070 tail = _Chain_Immutable_tail( &information->Inactive );
0071
0072 while ( node != tail ) {
0073 Objects_Control *object;
0074 uint32_t index;
0075
0076 object = (Objects_Control *) node;
0077 index = _Objects_Get_index( object->id ) - OBJECTS_INDEX_MINIMUM;
0078
0079
0080
0081
0082 node = _Chain_Next( node );
0083
0084 if ( index >= index_base && index < index_end ) {
0085 _Chain_Extract_unprotected( &object->Node );
0086 }
0087 }
0088
0089
0090
0091
0092
0093 _Workspace_Free( information->object_blocks[ block ] );
0094 information->object_blocks[ block ] = NULL;
0095 information->inactive_per_block[ block ] = 0;
0096 information->inactive -= objects_per_block;
0097 }
0098
0099 void _Objects_Shrink_information(
0100 Objects_Information *information
0101 )
0102 {
0103 Objects_Maximum objects_per_block;
0104 Objects_Maximum block_count;
0105 Objects_Maximum block;
0106
0107 _Assert( _Objects_Allocator_is_owner() );
0108 _Assert( _Objects_Is_auto_extend( information ) );
0109
0110
0111
0112
0113
0114 objects_per_block = information->objects_per_block;
0115 block_count = _Objects_Get_maximum_index( information ) / objects_per_block;
0116
0117 for ( block = 1; block < block_count; block++ ) {
0118 if ( information->inactive_per_block[ block ] == objects_per_block ) {
0119 _Objects_Free_objects_block( information, block );
0120 return;
0121 }
0122 }
0123 }