/* * Object Handler * * * COPYRIGHT (c) 1989-1998. * On-Line Applications Research Corporation (OAR). * Copyright assigned to U.S. Government, 1994. * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.OARcorp.com/rtems/license.html. * * $Id$ */ #include #include #include #include #if defined(RTEMS_MULTIPROCESSING) #include #endif #include #include #include #include /*PAGE * * _Objects_Allocate_by_index * * DESCRIPTION: * * This function allocates the object control block * specified by the index from the inactive chain of * free object control blocks. */ Objects_Control *_Objects_Allocate_by_index( Objects_Information *information, unsigned32 index, unsigned32 sizeof_control ) { Objects_Control *the_object; if ( index && information->maximum >= index ) { /* * If the object is already in the local table, then * it has already been allocated/created by a previous * create call. */ the_object = _Objects_Get_local_object( information, index ); if ( the_object ) return NULL; /* XXX * This whole section of code needs to be addressed. * + The use of the index 0 for object_blocks should be dealt * with more properly so we can autoextend. * + etc. */ the_object = (Objects_Control *) information->object_blocks[ 0 ]; _Chain_Extract( &the_object->Node ); return the_object; } /* * Autoextend will have to be thought out as it applies * to user assigned indices. */ return NULL; }