RTEMS
|
Files | |
file | object.h |
Constants and Structures Associated with the Object Handler. | |
file | objectdata.h |
Object Handler Data Structures. | |
file | objectimpl.h |
Inlined Routines in the Object Handler. | |
file | objectallocate.c |
Allocate Object. | |
file | objectallocatenone.c |
file | objectallocatestatic.c |
file | objectapimaximumclass.c |
Object API Maximum Class. | |
file | objectclose.c |
Close Object. | |
file | objectfree.c |
Free Object. | |
file | objectfreestatic.c |
file | objectgetinfo.c |
Get Object Information. | |
file | objectgetlocal.c |
Object Get Local. | |
file | objectgetnoprotection.c |
Get Object without Dispatching Protection. | |
file | objectinitializeinformation.c |
Initialize Object Information. | |
Classes | |
union | Objects_Name |
struct | Objects_Control |
struct | Objects_Information |
The information structure used to manage each API class of objects. More... | |
Macros | |
#define | OBJECTS_INDEX_START_BIT 0U |
#define | OBJECTS_NODE_START_BIT 16U |
#define | OBJECTS_API_START_BIT 24U |
#define | OBJECTS_CLASS_START_BIT 27U |
#define | OBJECTS_INDEX_MASK (Objects_Id)0x0000ffffU |
#define | OBJECTS_NODE_MASK (Objects_Id)0x00ff0000U |
#define | OBJECTS_API_MASK (Objects_Id)0x07000000U |
#define | OBJECTS_CLASS_MASK (Objects_Id)0xf8000000U |
#define | OBJECTS_INDEX_VALID_BITS (Objects_Id)0x0000ffffU |
#define | OBJECTS_NODE_VALID_BITS (Objects_Id)0x000000ffU |
#define | OBJECTS_API_VALID_BITS (Objects_Id)0x00000007U |
#define | OBJECTS_CLASS_VALID_BITS (Objects_Id)0x0000001fU |
#define | OBJECTS_UNLIMITED_OBJECTS 0x80000000U |
#define | OBJECTS_ID_INITIAL_INDEX (0) |
#define | OBJECTS_ID_FINAL_INDEX (0xffffU) |
#define | OBJECTS_APIS_LAST OBJECTS_POSIX_API |
#define | OBJECTS_ID_NONE 0 |
#define | OBJECTS_ID_OF_SELF ((Objects_Id) 0) |
#define | OBJECTS_SEARCH_ALL_NODES 0 |
#define | OBJECTS_SEARCH_OTHER_NODES 0x7FFFFFFE |
#define | OBJECTS_SEARCH_LOCAL_NODE 0x7FFFFFFF |
#define | OBJECTS_WHO_AM_I 0 |
#define | OBJECTS_ID_INITIAL(_api, _class, _node) _Objects_Build_id( (_api), (_class), (_node), OBJECTS_ID_INITIAL_INDEX ) |
#define | OBJECTS_ID_FINAL ((Objects_Id)~0) |
#define | _Objects_Build_name(_C1, _C2, _C3, _C4) |
#define | _Objects_Build_id(the_api, the_class, node, index) |
Builds an object ID from its components. More... | |
#define | _Objects_Is_unlimited(maximum) ( ( ( maximum ) & OBJECTS_UNLIMITED_OBJECTS ) != 0 ) |
#define | _Objects_Maximum_per_allocation(maximum) ((Objects_Maximum) ((maximum) & ~OBJECTS_UNLIMITED_OBJECTS)) |
#define | _Objects_Local_node ((uint16_t) 1) |
The local MPCI node number. | |
#define | OBJECTS_NO_STRING_NAME 0 |
Constant for the object information string name length to indicate that this object class has no string names. | |
#define | OBJECTS_INFORMATION_MP(name, extract) |
#define | OBJECTS_INFORMATION_DEFINE_ZERO(name, api, cls, nl) |
Statically initializes an objects information. More... | |
#define | OBJECTS_INFORMATION_DEFINE(name, api, cls, type, max, nl, ex) |
Statically initializes an objects information. More... | |
#define | OBJECTS_INTERNAL_CLASSES_LAST OBJECTS_INTERNAL_THREADS |
#define | OBJECTS_RTEMS_CLASSES_LAST OBJECTS_RTEMS_BARRIERS |
#define | OBJECTS_POSIX_CLASSES_LAST OBJECTS_POSIX_SHMS |
#define | _Objects_Maximum_nodes 1 |
#define | OBJECTS_INDEX_MINIMUM 1U |
#define | OBJECTS_NAME_ERRORS_FIRST OBJECTS_NAME_OR_ID_LOOKUP_SUCCESSFUL |
#define | OBJECTS_NAME_ERRORS_LAST OBJECTS_INVALID_NODE |
Typedefs | |
typedef uint32_t | Objects_Id |
typedef uint16_t | Objects_Maximum |
typedef struct Objects_Information | Objects_Information |
typedef bool(* | Objects_Name_comparators) (void *, void *, uint16_t) |
Enumerations | |
enum | Objects_APIs { OBJECTS_NO_API = 0, OBJECTS_INTERNAL_API = 1, OBJECTS_CLASSIC_API = 2, OBJECTS_POSIX_API = 3, OBJECTS_FAKE_OBJECTS_API = 7 } |
enum | Objects_Internal_API { OBJECTS_INTERNAL_NO_CLASS = 0, OBJECTS_INTERNAL_THREADS = 1 } |
enum | Objects_Classic_API { OBJECTS_CLASSIC_NO_CLASS = 0, OBJECTS_RTEMS_TASKS = 1, OBJECTS_RTEMS_TIMERS, OBJECTS_RTEMS_SEMAPHORES, OBJECTS_RTEMS_MESSAGE_QUEUES, OBJECTS_RTEMS_PARTITIONS, OBJECTS_RTEMS_REGIONS, OBJECTS_RTEMS_PORTS, OBJECTS_RTEMS_PERIODS, OBJECTS_RTEMS_EXTENSIONS, OBJECTS_RTEMS_BARRIERS } |
enum | Objects_POSIX_API { OBJECTS_POSIX_NO_CLASS = 0, OBJECTS_POSIX_THREADS = 1, OBJECTS_POSIX_KEYS, OBJECTS_POSIX_MESSAGE_QUEUES, OBJECTS_POSIX_SEMAPHORES, OBJECTS_POSIX_TIMERS, OBJECTS_POSIX_SHMS } |
enum | Objects_Fake_objects_API { OBJECTS_FAKE_OBJECTS_NO_CLASS = 0, OBJECTS_FAKE_OBJECTS_SCHEDULERS = 1 } |
enum | Objects_Name_or_id_lookup_errors { OBJECTS_NAME_OR_ID_LOOKUP_SUCCESSFUL, OBJECTS_INVALID_NAME, OBJECTS_INVALID_ADDRESS, OBJECTS_INVALID_ID, OBJECTS_INVALID_NODE } |
enum | Objects_Get_by_name_error { OBJECTS_GET_BY_NAME_INVALID_NAME, OBJECTS_GET_BY_NAME_NAME_TOO_LONG, OBJECTS_GET_BY_NAME_NO_OBJECT } |
Functions | |
static __inline__ Objects_APIs | _Objects_Get_API (Objects_Id id) |
Returns the API portion of the ID. More... | |
static __inline__ uint32_t | _Objects_Get_class (Objects_Id id) |
Returns the class portion of the ID. More... | |
static __inline__ uint32_t | _Objects_Get_node (Objects_Id id) |
Returns the node portion of the ID. More... | |
static __inline__ Objects_Maximum | _Objects_Get_index (Objects_Id id) |
Returns the index portion of the ID. More... | |
Objects_Control * | _Objects_Allocate_none (Objects_Information *information) |
Always return NULL. More... | |
Objects_Control * | _Objects_Allocate_static (Objects_Information *information) |
Return an inactive object or NULL. More... | |
Objects_Control * | _Objects_Allocate_unlimited (Objects_Information *information) |
Return an inactive object or NULL. More... | |
void | _Objects_Free_static (Objects_Information *information, Objects_Control *the_object) |
Free the object. More... | |
void | _Objects_Free_unlimited (Objects_Information *information, Objects_Control *the_object) |
Free the object. More... | |
Objects_Maximum | _Objects_Extend_information (Objects_Information *information) |
Extends an object class information record. More... | |
void | _Objects_Free_objects_block (Objects_Information *information, Objects_Maximum block) |
Free the objects block with the specified index. More... | |
void | _Objects_Shrink_information (Objects_Information *information) |
Shrinks an object class information record. More... | |
void | _Objects_Initialize_information (Objects_Information *information) |
Initializes the specified objects information. More... | |
unsigned int | _Objects_API_maximum_class (uint32_t api) |
Returns highest numeric value of a valid API for the specified API. More... | |
Objects_Control * | _Objects_Allocate (Objects_Information *information) |
Allocates an object. More... | |
Objects_Name_or_id_lookup_errors | _Objects_Name_to_id_u32 (uint32_t name, uint32_t node, Objects_Id *id, const Objects_Information *information) |
Searches an object of the specified class with the specified name on the specified set of nodes. More... | |
Objects_Control * | _Objects_Get_by_name (const Objects_Information *information, const char *name, size_t *name_length_p, Objects_Get_by_name_error *error) |
Gets an object control block identified by its name. More... | |
Objects_Name_or_id_lookup_errors | _Objects_Id_to_name (Objects_Id id, Objects_Name *name) |
Returns the name associated with object id. More... | |
Objects_Control * | _Objects_Get (Objects_Id id, ISR_lock_Context *lock_context, const Objects_Information *information) |
Maps the specified object identifier to the associated local object control block. More... | |
Objects_Control * | _Objects_Get_no_protection (Objects_Id id, const Objects_Information *information) |
Maps object ids to object control blocks. More... | |
Objects_Control * | _Objects_Get_next (Objects_Id id, const Objects_Information *information, Objects_Id *next_id_p) |
Gets the next open object after the specified object identifier. More... | |
Objects_Information * | _Objects_Get_information (Objects_APIs the_api, uint16_t the_class) |
Gets object information. More... | |
Objects_Information * | _Objects_Get_information_id (Objects_Id id) |
Gets information of an object from an ID. More... | |
static __inline__ bool | _Objects_Has_string_name (const Objects_Information *information) |
Returns if the object has a string name. More... | |
char * | _Objects_Get_name_as_string (Objects_Id id, size_t length, char *name) |
Gets object name in the form of a C string. More... | |
size_t | _Objects_Name_to_string (Objects_Name name, bool is_string, char *buffer, size_t buffer_size) |
Converts the specified object name to a text representation. More... | |
bool | _Objects_Set_name (const Objects_Information *information, Objects_Control *the_object, const char *name) |
Sets objects name. More... | |
static __inline__ void | _Objects_Namespace_remove_u32 (const Objects_Information *information, Objects_Control *the_object) |
Removes object with a 32-bit integer name from its namespace. More... | |
void | _Objects_Namespace_remove_string (const Objects_Information *information, Objects_Control *the_object) |
Removes object with a string name from its namespace. More... | |
void | _Objects_Close (const Objects_Information *information, Objects_Control *the_object) |
Closes object. More... | |
Objects_Maximum | _Objects_Active_count (const Objects_Information *information) |
Returns the count of active objects. More... | |
static __inline__ Objects_Maximum | _Objects_Extend_size (const Objects_Information *information) |
Returns the object's objects per block. More... | |
static __inline__ bool | _Objects_Is_api_valid (uint32_t the_api) |
Checks if the api is valid. More... | |
static __inline__ bool | _Objects_Is_local_node (uint32_t node) |
Checks if the node is of the local object. More... | |
static __inline__ bool | _Objects_Is_local_id (Objects_Id id RTEMS_UNUSED) |
Checks if the id is of a local object. More... | |
static __inline__ bool | _Objects_Are_ids_equal (Objects_Id left, Objects_Id right) |
Checks if two object IDs are equal. More... | |
static __inline__ Objects_Id | _Objects_Get_minimum_id (Objects_Id id) |
Returns the identifier with the minimum index for the specified identifier. More... | |
static __inline__ Objects_Maximum | _Objects_Get_maximum_index (const Objects_Information *information) |
Returns the maximum index of the specified object class. More... | |
static __inline__ Objects_Control * | _Objects_Get_inactive (Objects_Information *information) |
Get an inactive object or NULL. More... | |
static __inline__ Objects_Maximum | _Objects_Is_auto_extend (const Objects_Information *information) |
Checks if the automatic object extension (unlimited objects) is enabled. More... | |
static __inline__ void | _Objects_Set_local_object (const Objects_Information *information, uint32_t index, Objects_Control *the_object) |
Sets the pointer to the local_table object referenced by the index. More... | |
static __inline__ void | _Objects_Invalidate_Id (const Objects_Information *information, Objects_Control *the_object) |
Invalidates an object Id. More... | |
static __inline__ void | _Objects_Open (Objects_Information *information, Objects_Control *the_object, Objects_Name name) |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively. More... | |
static __inline__ void | _Objects_Open_u32 (const Objects_Information *information, Objects_Control *the_object, uint32_t name) |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively. More... | |
static __inline__ void | _Objects_Open_string (const Objects_Information *information, Objects_Control *the_object, const char *name) |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively. More... | |
static __inline__ void | _Objects_Allocator_lock (void) |
Locks the object allocator mutex. More... | |
static __inline__ void | _Objects_Allocator_unlock (void) |
Unlocks the object allocator mutex. More... | |
static __inline__ bool | _Objects_Allocator_is_owner (void) |
Checks if the allocator is the owner of the object allocator mutex. More... | |
static __inline__ Objects_Control * | _Objects_Allocate_unprotected (Objects_Information *information) |
Allocates an object without locking the allocator mutex. More... | |
static __inline__ void | _Objects_Free (Objects_Information *information, Objects_Control *the_object) |
Frees an object. More... | |
static __inline__ void | _Objects_Activate_unlimited (Objects_Information *information, Objects_Control *the_object) |
Activate the object. More... | |
static __inline__ Objects_Control * | _Objects_Allocate_with_extend (Objects_Information *information, void(*extend)(Objects_Information *)) |
Allocate an object and extend the objects information on demand. More... | |
Variables | |
Objects_Information **const | _Objects_Information_table [OBJECTS_APIS_LAST+1] |
#define _Objects_Build_id | ( | the_api, | |
the_class, | |||
node, | |||
index | |||
) |
Builds an object ID from its components.
the_api | The object API. |
the_class | The object API class. |
node | The object node. |
index | The object index. |
#define _Objects_Build_name | ( | _C1, | |
_C2, | |||
_C3, | |||
_C4 | |||
) |
This macro is used to build a thirty-two bit style name from four characters. The most significant byte will be the character _C1.
[in] | _C1 | is the first character of the name |
[in] | _C2 | is the second character of the name |
[in] | _C3 | is the third character of the name |
[in] | _C4 | is the fourth character of the name |
#define _Objects_Is_unlimited | ( | maximum | ) | ( ( ( maximum ) & OBJECTS_UNLIMITED_OBJECTS ) != 0 ) |
#define _Objects_Maximum_nodes 1 |
The following is referenced to the number of nodes in the system.
Definition at line 74 of file objectimpl.h.
#define OBJECTS_API_MASK (Objects_Id)0x07000000U |
#define OBJECTS_API_START_BIT 24U |
#define OBJECTS_API_VALID_BITS (Objects_Id)0x00000007U |
#define OBJECTS_APIS_LAST OBJECTS_POSIX_API |
#define OBJECTS_CLASS_MASK (Objects_Id)0xf8000000U |
#define OBJECTS_CLASS_START_BIT 27U |
#define OBJECTS_CLASS_VALID_BITS (Objects_Id)0x0000001fU |
#define OBJECTS_ID_FINAL ((Objects_Id)~0) |
#define OBJECTS_ID_FINAL_INDEX (0xffffU) |
#define OBJECTS_ID_INITIAL | ( | _api, | |
_class, | |||
_node | |||
) | _Objects_Build_id( (_api), (_class), (_node), OBJECTS_ID_INITIAL_INDEX ) |
#define OBJECTS_ID_INITIAL_INDEX (0) |
#define OBJECTS_ID_OF_SELF ((Objects_Id) 0) |
#define OBJECTS_INDEX_MASK (Objects_Id)0x0000ffffU |
#define OBJECTS_INDEX_MINIMUM 1U |
This is the minimum object ID index associated with an object.
Definition at line 80 of file objectimpl.h.
#define OBJECTS_INDEX_START_BIT 0U |
#define OBJECTS_INDEX_VALID_BITS (Objects_Id)0x0000ffffU |
#define OBJECTS_INFORMATION_DEFINE | ( | name, | |
api, | |||
cls, | |||
type, | |||
max, | |||
nl, | |||
ex | |||
) |
Statically initializes an objects information.
The initialized objects information references a table with statically allocated objects as specified by the object maximum parameter. These objects must be registered via a call to _Objects_Information().
name | The object class C designator namespace prefix, e.g. _Semaphore. |
api | The object API number, e.g. OBJECTS_CLASSIC_API. |
cls | The object class number, e.g. OBJECTS_RTEMS_SEMAPHORES. |
type | The object class type. |
max | The configured object maximum (the OBJECTS_UNLIMITED_OBJECTS flag may be set). |
nl | The object name string length, use OBJECTS_NO_STRING_NAME for objects without a string name. |
ex | The optional object extraction method. Used only if multiprocessing (RTEMS_MULTIPROCESSING) is enabled. |
Definition at line 427 of file objectdata.h.
#define OBJECTS_INFORMATION_DEFINE_ZERO | ( | name, | |
api, | |||
cls, | |||
nl | |||
) |
Statically initializes an objects information.
The initialized objects information contains no objects.
name | The object class C designator namespace prefix, e.g. _Semaphore. |
api | The object API number, e.g. OBJECTS_CLASSIC_API. |
cls | The object class number, e.g. OBJECTS_RTEMS_SEMAPHORES. |
nl | The object name string length, use OBJECTS_NO_STRING_NAME for objects without a string name. |
Definition at line 392 of file objectdata.h.
#define OBJECTS_INTERNAL_CLASSES_LAST OBJECTS_INTERNAL_THREADS |
This macro is used to generically specify the last API index.
Definition at line 51 of file objectimpl.h.
#define OBJECTS_NAME_ERRORS_FIRST OBJECTS_NAME_OR_ID_LOOKUP_SUCCESSFUL |
This macro defines the first entry in the Objects_Name_or_id_lookup_errors enumerated list.
Definition at line 215 of file objectimpl.h.
#define OBJECTS_NAME_ERRORS_LAST OBJECTS_INVALID_NODE |
This macro defines the last entry in the Objects_Name_or_id_lookup_errors enumerated list.
Definition at line 221 of file objectimpl.h.
#define OBJECTS_NODE_MASK (Objects_Id)0x00ff0000U |
#define OBJECTS_NODE_START_BIT 16U |
#define OBJECTS_NODE_VALID_BITS (Objects_Id)0x000000ffU |
#define OBJECTS_POSIX_CLASSES_LAST OBJECTS_POSIX_SHMS |
This macro is used to generically specify the last API index.
Definition at line 57 of file objectimpl.h.
#define OBJECTS_RTEMS_CLASSES_LAST OBJECTS_RTEMS_BARRIERS |
This macro is used to generically specify the last API index.
Definition at line 54 of file objectimpl.h.
#define OBJECTS_SEARCH_ALL_NODES 0 |
#define OBJECTS_SEARCH_LOCAL_NODE 0x7FFFFFFF |
#define OBJECTS_SEARCH_OTHER_NODES 0x7FFFFFFE |
#define OBJECTS_UNLIMITED_OBJECTS 0x80000000U |
#define OBJECTS_WHO_AM_I 0 |
typedef uint32_t Objects_Id |
The following type defines the control block used to manage object IDs. The format is as follows (0=LSB):
Bits 0 .. 15 = index (up to 65535 objects of a type) Bits 16 .. 23 = node (up to 255 nodes) Bits 24 .. 26 = API (up to 7 API classes) Bits 27 .. 31 = class (up to 31 object types per API)
typedef uint16_t Objects_Maximum |
typedef bool(* Objects_Name_comparators) (void *, void *, uint16_t) |
Functions which compare names are prototyped like this.
Definition at line 44 of file objectimpl.h.
enum Objects_APIs |
enum Objects_Classic_API |
This enumerated type is used in the class field of the object ID for the RTEMS Classic API.
Definition at line 63 of file objectdata.h.
enum Objects_Internal_API |
This enumerated type is used in the class field of the object ID for RTEMS internal object classes.
Definition at line 52 of file objectdata.h.
This function implements the common portion of the object identification directives. This directive returns the object id associated with name. If more than one object of this class is named name, then the object to which the id belongs is arbitrary. Node indicates the extent of the search for the id of the object named name. If the object class supports global objects, then the search can be limited to a particular node or allowed to encompass all nodes.
Definition at line 203 of file objectimpl.h.
enum Objects_POSIX_API |
This enumerated type is used in the class field of the object ID for the POSIX API.
Definition at line 84 of file objectdata.h.
|
static |
Activate the object.
This function must be only used in case this objects information supports unlimited objects.
information | The object information block. |
the_object | The object to activate. |
Definition at line 952 of file objectimpl.h.
Objects_Maximum _Objects_Active_count | ( | const Objects_Information * | information | ) |
Returns the count of active objects.
information | The object information table. |
Definition at line 23 of file objectactivecount.c.
Objects_Control* _Objects_Allocate | ( | Objects_Information * | information | ) |
Allocates an object.
This function locks the object allocator mutex via _Objects_Allocator_lock(). The caller must later unlock the object allocator mutex via _Objects_Allocator_unlock(). The caller must unlock the mutex in any case, even if the allocation failed due to resource shortage.
A typical object allocation code looks like this:
[in,out] | information | The object information block. |
object | The allocated object. |
NULL | No object available. |
Definition at line 42 of file objectallocate.c.
Objects_Control* _Objects_Allocate_none | ( | Objects_Information * | information | ) |
Always return NULL.
information | The objects information. |
NULL | Always. |
Definition at line 40 of file objectallocatenone.c.
Objects_Control* _Objects_Allocate_static | ( | Objects_Information * | information | ) |
Return an inactive object or NULL.
information | The objects information. |
NULL | No inactive object is available. |
object | An inactive object. |
Definition at line 41 of file objectallocatestatic.c.
Objects_Control* _Objects_Allocate_unlimited | ( | Objects_Information * | information | ) |
Return an inactive object or NULL.
Try to extend the objects information if necessary.
information | The objects information. |
NULL | No inactive object is available. |
object | An inactive object. |
|
static |
Allocates an object without locking the allocator mutex.
This function can be called in two contexts
[in,out] | information | The object information block. |
object | The allocated object. |
NULL | No object available. |
Definition at line 877 of file objectimpl.h.
|
static |
Allocate an object and extend the objects information on demand.
This function must be only used in case this objects information supports unlimited objects.
information | The object information block. |
extend | The object information extend handler. |
Definition at line 982 of file objectimpl.h.
|
static |
Checks if the allocator is the owner of the object allocator mutex.
true | The allocator is the owner of the object allocator mutex. |
false | The allocato is not the owner of the object allocator mutex. |
Definition at line 857 of file objectimpl.h.
|
static |
Locks the object allocator mutex.
While holding the allocator mutex the executing thread is protected from asynchronous thread restart and deletion.
The usage of the object allocator mutex with the thread life protection makes it possible to allocate and free objects without thread dispatching disabled. The usage of a unified workspace and unlimited objects may lead to heap fragmentation. Thus the execution time of the _Objects_Allocate() function may increase during system run-time.
Definition at line 834 of file objectimpl.h.
|
static |
Unlocks the object allocator mutex.
In case the mutex is fully unlocked, then this function restores the previous thread life protection state and thus may not return if the executing thread was restarted or deleted in the mean-time.
Definition at line 846 of file objectimpl.h.
unsigned int _Objects_API_maximum_class | ( | uint32_t | api | ) |
Returns highest numeric value of a valid API for the specified API.
This function returns the highest numeric value of a valid API for the specified api.
api | The API of interest. |
some_value | Positive integer on success. |
0 | The method failed. |
Definition at line 23 of file objectapimaximumclass.c.
|
static |
Checks if two object IDs are equal.
left | The Id on the left hand side of the comparison. |
right | The Id on the right hand side of the comparison. |
true | The specified object IDs are equal. |
false | The specified object IDs are not equal. |
Definition at line 611 of file objectimpl.h.
void _Objects_Close | ( | const Objects_Information * | information, |
Objects_Control * | the_object | ||
) |
Closes object.
This function removes the_object control pointer and object name in the Local Pointer and Local Name Tables.
information | Points to an Object Information Table. | |
[out] | the_object | A pointer to an object. |
Definition at line 23 of file objectclose.c.
Objects_Maximum _Objects_Extend_information | ( | Objects_Information * | information | ) |
Extends an object class information record.
information | Points to an object class information block. |
0 | The extend operation failed. |
block | The block index of the new objects block. |
|
static |
Returns the object's objects per block.
information | The object information table. |
Definition at line 537 of file objectimpl.h.
|
static |
Frees an object.
Appends the object to the chain of inactive objects.
information | The object information block. | |
[out] | the_object | The object to free. |
A typical object deletion code looks like this:
Definition at line 933 of file objectimpl.h.
void _Objects_Free_objects_block | ( | Objects_Information * | information, |
Objects_Maximum | block | ||
) |
Free the objects block with the specified index.
information | The objects information. |
block | The block index. |
void _Objects_Free_static | ( | Objects_Information * | information, |
Objects_Control * | the_object | ||
) |
Free the object.
Append the object to the inactive chain of the objects information.
information | The objects information. |
the_object | The object to free. |
Definition at line 41 of file objectfreestatic.c.
void _Objects_Free_unlimited | ( | Objects_Information * | information, |
Objects_Control * | the_object | ||
) |
Free the object.
Append the object to the inactive chain of the objects information and shrink the objects information if necessary.
information | The objects information. |
the_object | The object to free. |
Definition at line 24 of file objectfree.c.
Objects_Control* _Objects_Get | ( | Objects_Id | id, |
ISR_lock_Context * | lock_context, | ||
const Objects_Information * | information | ||
) |
Maps the specified object identifier to the associated local object control block.
In this function interrupts are disabled during the object lookup. In case an associated object exists, then interrupts remain disabled, otherwise the previous interrupt state is restored.
id | The object identifier. This is the first parameter since usual callers get the object identifier as the first parameter themself. |
lock_context | The interrupt lock context. This is the second parameter since usual callers get the interrupt lock context as the second parameter themself. |
information | The object class information block. |
pointer | The pointer to the associated object control block. Interrupts are now disabled and must be restored using the specified lock context via _ISR_lock_ISR_enable() or _ISR_lock_Release_and_ISR_enable(). |
NULL | No associated object exists. |
Definition at line 28 of file objectgetlocal.c.
|
static |
Objects_Control* _Objects_Get_by_name | ( | const Objects_Information * | information, |
const char * | name, | ||
size_t * | name_length_p, | ||
Objects_Get_by_name_error * | error | ||
) |
Gets an object control block identified by its name.
The object information must use string names.
information | The object information. Must not be NULL. | |
name | The object name. | |
[out] | name_length_p | Optional parameter to return the name length. |
[out] | error | The error indication in case of failure. Must not be NULL. |
pointer | The first object according to object index associated with this name. |
NULL | No object exists for this name or invalid parameters. |
|
static |
|
static |
Get an inactive object or NULL.
NULL | No inactive object is available. |
object | An inactive object. |
Definition at line 655 of file objectimpl.h.
|
static |
Objects_Information* _Objects_Get_information | ( | Objects_APIs | the_api, |
uint16_t | the_class | ||
) |
Gets object information.
This function returns the information structure given an API and Class. This can be done independent of the existence of any objects created by the API.
the_api | Indicates the API for the information we want |
the_class | Indicates the Class for the information we want |
pointer | Pointer to the Object Information Table for the class of objects which corresponds to this object ID. |
NULL | An error occured. |
Definition at line 23 of file objectgetinfo.c.
Objects_Information* _Objects_Get_information_id | ( | Objects_Id | id | ) |
Gets information of an object from an ID.
This function returns the information structure given an id of an object.
id | The object ID to get the information from. |
pointer | Pointer to the Object Information Table for the class of objects which corresponds to this object ID. |
NULL | An error occured. |
Definition at line 24 of file objectgetinfoid.c.
|
static |
Returns the maximum index of the specified object class.
information | The object information. |
Definition at line 642 of file objectimpl.h.
|
static |
Returns the identifier with the minimum index for the specified identifier.
The specified identifier must have valid API, class and node fields.
id | The identifier to be processed. |
Definition at line 628 of file objectimpl.h.
char* _Objects_Get_name_as_string | ( | Objects_Id | id, |
size_t | length, | ||
char * | name | ||
) |
Gets object name in the form of a C string.
This method gets the name of an object and returns its name in the form of a C string. It attempts to be careful about overflowing the user's string and about returning unprintable characters.
id | The object to obtain the name of. | |
length | Indicates the length of the caller's buffer. | |
[out] | name | A string which will be filled in. |
Definition at line 87 of file objectgetnameasstring.c.
Objects_Control* _Objects_Get_next | ( | Objects_Id | id, |
const Objects_Information * | information, | ||
Objects_Id * | next_id_p | ||
) |
Gets the next open object after the specified object identifier.
Locks the object allocator mutex in case a next object exists.
id | The Id of the object whose name we are locating. This is the first parameter since usual callers get the object identifier as the first parameter themself. | |
information | Points to an object class information block. | |
[in,out] | next_id_p | The Id of the next object we will look at. |
pointer | Pointer to the located object. |
NULL | An error occured. |
Objects_Control* _Objects_Get_no_protection | ( | Objects_Id | id, |
const Objects_Information * | information | ||
) |
Maps object ids to object control blocks.
This function maps object ids to object control blocks. If id corresponds to a local object, then it returns the_object control pointer which maps to id and location is set to OBJECTS_LOCAL. If the object class supports global objects and the object id is global and resides on a remote node, then location is set to OBJECTS_REMOTE, and the_object is undefined. Otherwise, location is set to OBJECTS_ERROR and the_object is undefined.
id | The Id of the object whose name we are locating. This is the first parameter since usual callers get the object identifier as the first parameter themself. |
information | Points to an object class information block. |
pointer | The local object corresponding to the given id. |
NULL | The object to the given id was not found locally. |
Definition at line 23 of file objectgetnoprotection.c.
|
static |
|
static |
Returns if the object has a string name.
information | The object information table. |
true | The object has a string name. |
false | The object does not have a string name. |
Definition at line 411 of file objectimpl.h.
Objects_Name_or_id_lookup_errors _Objects_Id_to_name | ( | Objects_Id | id, |
Objects_Name * | name | ||
) |
Returns the name associated with object id.
This function implements the common portion of the object Id to name directives. This function returns the name associated with object id.
id | is the Id of the object whose name we are locating. | |
[out] | name | will contain the name of the object, if found. |
OBJECTS_NAME_OR_ID_LOOKUP_SUCCESSFUL | The operation succeeded. name contains the name of the object. |
OBJECTS_INVALID_ID | The id is invalid, the operation failed. |
void _Objects_Initialize_information | ( | Objects_Information * | information | ) |
Initializes the specified objects information.
The objects information must be statically pre-initialized with the OBJECTS_INFORMATION_DEFINE() macro before this function is called.
information | The object information to be initialized. |
Definition at line 29 of file objectinitializeinformation.c.
|
static |
Invalidates an object Id.
This function sets the pointer to the local_table object referenced by the index to NULL so the object Id is invalid after this call.
[in,out] | information | points to an Object Information Table. |
the_object | The local object pointer. |
Definition at line 725 of file objectimpl.h.
|
static |
Checks if the api is valid.
the_api | is the api portion of an object ID. |
true | The specified api value is valid. |
false | The specified api value is not valid. |
Definition at line 552 of file objectimpl.h.
|
static |
Checks if the automatic object extension (unlimited objects) is enabled.
information | The object information. |
true | The automatic object extension (unlimited objects) is enabled. |
false | The automatic object extension (unlimited objects) is not enabled. |
Definition at line 671 of file objectimpl.h.
|
static |
Checks if the id is of a local object.
id | The object ID. |
true | The specified object Id is local. |
false | The specified object Id is not local. |
Definition at line 587 of file objectimpl.h.
|
static |
Checks if the node is of the local object.
node | The node number and corresponds to the node number portion of an object ID. |
true | The specified node is the local node. |
false | The specified node is not the local node. |
Definition at line 570 of file objectimpl.h.
Objects_Name_or_id_lookup_errors _Objects_Name_to_id_u32 | ( | uint32_t | name, |
uint32_t | node, | ||
Objects_Id * | id, | ||
const Objects_Information * | information | ||
) |
Searches an object of the specified class with the specified name on the specified set of nodes.
This method converts an object name to an identifier. It performs a look up using the object information block for this object class.
name | is the name of the object to find. | |
node | is the set of nodes to search. | |
[out] | id | is the pointer to an object identifier variable or NULL. The object identifier will be stored in the referenced variable, if the operation was successful. |
information | is the pointer to an object class information block. |
OBJECTS_NAME_OR_ID_LOOKUP_SUCCESSFUL | The operations was successful. |
OBJECTS_INVALID_ADDRESS | The id parameter was NULL. |
OBJECTS_INVALID_NAME | No object exists with the specified name on the specified node set. |
Definition at line 23 of file objectnametoid.c.
size_t _Objects_Name_to_string | ( | Objects_Name | name, |
bool | is_string, | ||
char * | buffer, | ||
size_t | buffer_size | ||
) |
Converts the specified object name to a text representation.
Non-printable characters according to isprint() are converted to '*'.
name | The object name. | |
is_string | Indicates if the object name is a string or a four character array (32-bit unsigned integer). | |
[out] | buffer | The string buffer for the text representation. |
buffer_size | The buffer size in characters. |
Definition at line 36 of file objectgetnameasstring.c.
void _Objects_Namespace_remove_string | ( | const Objects_Information * | information, |
Objects_Control * | the_object | ||
) |
Removes object with a string name from its namespace.
information | The corresponding object information table. | |
[out] | the_object | The object the object to operate upon. |
Definition at line 25 of file objectnamespaceremove.c.
|
static |
Removes object with a 32-bit integer name from its namespace.
information | The corresponding object information table. | |
[out] | the_object | The object to operate upon. |
Definition at line 485 of file objectimpl.h.
|
static |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively.
This method uses Objects_Name for the object name.
[in,out] | information | Points to an Object Information Table. |
the_object | Pointer to an object. | |
name | The name of the object to make accessible. |
Definition at line 750 of file objectimpl.h.
|
static |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively.
This method uses a String for the object name.
[in,out] | information | Points to an Object Information Table. |
the_object | Pointer to an object. | |
name | The name of the object to make accessible. |
Definition at line 804 of file objectimpl.h.
|
static |
Places the_object control pointer and object name in the Local Pointer and Local Name Tables, respectively.
This method uses uint32_t for the object name.
[in,out] | information | Points to an Object Information Table. |
the_object | Pointer to an object. | |
name | The name of the object to make accessible. |
Definition at line 778 of file objectimpl.h.
|
static |
Sets the pointer to the local_table object referenced by the index.
[in,out] | information | Points to an Object Information Table. |
index | The index of the object the caller wants to access. | |
the_object | The local object pointer. |
Definition at line 692 of file objectimpl.h.
bool _Objects_Set_name | ( | const Objects_Information * | information, |
Objects_Control * | the_object, | ||
const char * | name | ||
) |
Sets objects name.
This method sets the object name to either a copy of a string or up to the first four characters of the string based upon whether this object class uses strings for names.
information | points to the object information structure | |
[out] | the_object | is the object to operate upon |
name | is a pointer to the name to use |
true | The operation succeeded. |
false | The operation failed. |
void _Objects_Shrink_information | ( | Objects_Information * | information | ) |
Shrinks an object class information record.
This function shrinks an object class information record. The object's name and object space are released. The local_table etc block does not shrink. The InActive list needs to be scanned to find the objects are remove them.
information | Points to an object class information block. |
Objects_Information** const _Objects_Information_table[OBJECTS_APIS_LAST+1] |
The following is the list of information blocks per API for each object class. From the ID, we can go to one of these information blocks, and obtain a pointer to the appropriate object control block.