RTEMS 6.1-rc7
|
The User Extensions Manager allows the application developer to augment the executive by allowing them to supply extension routines which are invoked at critical system events. More...
Typedefs | |
typedef User_extensions_fatal_extension | rtems_fatal_extension |
Fatal extensions are invoked when the system should terminate. | |
typedef Internal_errors_t | rtems_fatal_code |
This integer type represents system termination codes. | |
typedef Internal_errors_Source | rtems_fatal_source |
This enumeration represents system termination sources. | |
typedef User_extensions_Table | rtems_extensions_table |
The extensions table contains a set of extensions which may be registered in the system through the CONFIGURE_INITIAL_EXTENSIONS application configuration option or the rtems_extension_create() directive. | |
typedef User_extensions_thread_begin_extension | rtems_task_begin_extension |
Task begin extensions are invoked when a task begins execution. | |
typedef User_extensions_thread_create_extension | rtems_task_create_extension |
Task create extensions are invoked when a task is created. | |
typedef User_extensions_thread_delete_extension | rtems_task_delete_extension |
Task delete extensions are invoked when a task is deleted. | |
typedef User_extensions_thread_exitted_extension | rtems_task_exitted_extension |
Task exitted extensions are invoked when a task entry returns. | |
typedef User_extensions_thread_restart_extension | rtems_task_restart_extension |
Task restart extensions are invoked when a task restarts. | |
typedef User_extensions_thread_start_extension | rtems_task_start_extension |
Task start extensions are invoked when a task was made ready for the first time. | |
typedef User_extensions_thread_switch_extension | rtems_task_switch_extension |
Task switch extensions are invoked when a thread switch from an executing thread to a heir thread takes place. | |
typedef User_extensions_thread_terminate_extension | rtems_task_terminate_extension |
Task terminate extensions are invoked when a task terminates. | |
Functions | |
rtems_status_code | rtems_extension_delete (rtems_id id) |
Deletes the extension set. | |
rtems_status_code | rtems_extension_ident (rtems_name name, rtems_id *id) |
Identifies an extension set by the object name. | |
rtems_status_code | rtems_extension_create (rtems_name name, const rtems_extensions_table *extension_table, rtems_id *id) |
Creates an extension set. | |
The User Extensions Manager allows the application developer to augment the executive by allowing them to supply extension routines which are invoked at critical system events.
typedef Internal_errors_t rtems_fatal_code |
This integer type represents system termination codes.
This integer type is large enough to store a 32-bit integer or a pointer.
Fatal extensions are invoked when the system should terminate.
source | is the system termination source. The source indicates the component which caused the system termination request, see rtems_fatal_source. The system termination code may provide additional information related to the system termination request. |
always_set_to_false | is a value equal to false. |
code | is the system termination code. This value must be interpreted with respect to the source. |
The fatal extensions are invoked in extension forward order and with maskable interrupts disabled.
The fatal extension should be extremely careful with respect to the RTEMS directives it calls. Depending on the system termination source, the system may be in an undefined and corrupt state.
It is recommended to register fatal extensions through initial extension sets, see CONFIGURE_INITIAL_EXTENSIONS.
This enumeration represents system termination sources.
Task begin extensions are invoked when a task begins execution.
executing | is the TCB of the executing thread. |
The task begin extensions are invoked in extension forward order.
Task begin extensions are invoked with thread dispatching enabled. This allows the use of dynamic memory allocation, creation of POSIX keys, and use of C++ thread-local storage. Blocking synchronization primitives are allowed also.
The task begin extensions are invoked before the global construction.
The task begin extensions may be called as a result of a task restart through rtems_task_restart().
The following constraints apply to functions of this type:
Task create extensions are invoked when a task is created.
executing | is the TCB of the executing thread. When the idle thread is created, the executing thread is equal to NULL. |
created | is the TCB of the created thread. |
The task create extensions are invoked in extension forward order.
The task create extensions are invoked after a new task has been completely initialized, but before it is started.
While normal tasks are created, the executing thread is the owner of the object allocator mutex. The object allocator mutex allows nesting, so the normal memory allocation routines can be used allocate memory for the created thread.
If the task create extension returns false, then the task create operation stops immediately and the entire task create operation will fail. In this case, all task delete extensions are invoked, see rtems_task_delete_extension.
The following constraints apply to functions of this type:
Task delete extensions are invoked when a task is deleted.
executing | is the TCB of the executing thread. If the idle thread is created and one of the initial task create extension fails, then the executing thread is equal to NULL. |
created | is the TCB of the deleted thread. The executing and deleted arguments are never equal. |
The task delete extensions are invoked in extension reverse order.
The task delete extensions are invoked by task create directives before an attempt to allocate a TCB is made.
If a task create extension failed, then a task delete extension may be invoked without a previous invocation of the corresponding task create extension of the extension set.
The following constraints apply to functions of this type:
Task exitted extensions are invoked when a task entry returns.
executing | is the TCB of the executing thread. |
The following constraints apply to functions of this type:
Task restart extensions are invoked when a task restarts.
executing | is the TCB of the executing thread. |
restarted | is the TCB of the executing thread. Yes, the executing thread. |
The task restart extensions are invoked in extension forward order.
The task restart extensions are invoked in the context of the restarted thread right before the execution context is reloaded. The thread stack reflects the previous execution context.
Thread restart and delete requests issued by restart extensions lead to recursion.
The following constraints apply to functions of this type:
Task start extensions are invoked when a task was made ready for the first time.
executing | is the TCB of the executing thread. |
started | is the TCB of the started thread. |
The task start extensions are invoked in extension forward order.
In SMP configurations, the thread may already run on another processor before the task start extensions are actually invoked. Task switch and task begin extensions may run before or in parallel with the thread start extension in SMP configurations, see rtems_task_switch_extension and rtems_task_begin_extension.
The following constraints apply to functions of this type:
Task switch extensions are invoked when a thread switch from an executing thread to a heir thread takes place.
executing | is the TCB of the executing thread. In SMP configurations, this is the previously executing thread also known as the ancestor thread. |
heir | is the TCB of the heir thread. In SMP configurations, this is the executing thread. |
The task switch extensions are invoked in extension forward order.
The invocation conditions of the task switch extensions depend on whether RTEMS was built with SMP support enabled or disabled. A user must pay attention to the differences to correctly implement a task switch extension.
Where the system was built with SMP support disabled, the task switch extensions are invoked before the context switch from the currently executing thread to the heir thread. The executing
is a pointer to the TCB of the currently executing thread. The heir
is a pointer to the TCB of the heir thread. The context switch initiated through the multitasking start is not covered by the task switch extensions.
Where the system was built with SMP support enabled, the task switch extensions are invoked after the context switch to the heir thread. The executing
is a pointer to the TCB of the previously executing thread. Despite the name, this is not the currently executing thread. The heir
is a pointer to the TCB of the newly executing thread. This is the currently executing thread. The context switches initiated through the multitasking start are covered by the task switch extensions. The reason for the differences to uniprocessor configurations is that the context switch may update the heir thread of the processor. The task switch extensions are invoked with maskable interrupts disabled and with ownership of a processor-specific SMP lock. Task switch extensions may run in parallel on multiple processors. It is recommended to use thread-local or processor-specific data structures for task switch extensions. A global SMP lock should be avoided for performance reasons, see rtems_interrupt_lock_initialize().
The following constraints apply to functions of this type:
Task terminate extensions are invoked when a task terminates.
executing | is the TCB of the executing thread. This is the terminating thread. |
The task terminate extensions are invoked in extension reverse order.
The task terminate extensions are invoked in the context of the terminating thread right before the thread dispatch to the heir thread should take place. The thread stack reflects the previous execution context. The POSIX cleanup and key destructors execute in this context.
Thread restart and delete requests issued by terminate extensions lead to recursion.
The following constraints apply to functions of this type:
rtems_status_code rtems_extension_create | ( | rtems_name | name, |
const rtems_extensions_table * | extension_table, | ||
rtems_id * | id | ||
) |
Creates an extension set.
name | is the object name of the extension set. | |
extension_table | is the table with the extensions to be used by the extension set. | |
[out] | id | is the pointer to an rtems_id object. When the directive call is successful, the identifier of the created extension set will be stored in this object. |
This directive creates an extension set which resides on the local node. The extension set has the user-defined object name specified in name
. The assigned object identifier is returned in id
. This identifier is used to access the extension set with other extension set related directives.
The extension set is initialized using the extension table specified in extension_table
.
RTEMS_SUCCESSFUL | The requested operation was successful. |
RTEMS_INVALID_NAME | The name parameter was invalid. |
RTEMS_INVALID_ADDRESS | The extension_table parameter was NULL. |
RTEMS_INVALID_ADDRESS | The id parameter was NULL. |
RTEMS_TOO_MANY | There was no inactive object available to create an extension set. The number of extension sets available to the application is configured through the CONFIGURE_MAXIMUM_USER_EXTENSIONS application configuration option. |
The user-provided extension table is not used after the return of the directive.
Each extension of the extension table is optional and may be NULL. All extensions except the task switch extension of the extension table are atomically and immediately installed. A task switch extension is separately installed after the other extensions. The extensions of the extension table are invoked upon the next system event supporting an extension.
An alternative to dynamically created extension sets are initial extensions, see CONFIGURE_INITIAL_EXTENSIONS. Initial extensions are recommended for extension sets which provide a fatal error extension.
For control and maintenance of the extension set, RTEMS allocates a ESCB from the local ESCB free pool and initializes it.
The following constraints apply to this directive:
rtems_status_code rtems_extension_delete | ( | rtems_id | id | ) |
Deletes the extension set.
id | is the extension set identifier. |
This directive deletes the extension set specified by id
.
RTEMS_SUCCESSFUL | The requested operation was successful. |
RTEMS_INVALID_ID | There was no extension set associated with the identifier specified by id . |
The following constraints apply to this directive:
rtems_status_code rtems_extension_ident | ( | rtems_name | name, |
rtems_id * | id | ||
) |
Identifies an extension set by the object name.
name | is the object name to look up. | |
[out] | id | is the pointer to an rtems_id object. When the directive call is successful, the object identifier of an object with the specified name will be stored in this object. |
This directive obtains an extension set identifier associated with the extension set name specified in name
.
RTEMS_SUCCESSFUL | The requested operation was successful. |
RTEMS_INVALID_ADDRESS | The id parameter was NULL. |
RTEMS_INVALID_NAME | The name parameter was 0. |
RTEMS_INVALID_NAME | There was no object with the specified name on the local node. |
If the extension set name is not unique, then the extension set identifier will match the first extension set with that name in the search order. However, this extension set identifier is not guaranteed to correspond to the desired extension set.
The objects are searched from lowest to the highest index. Only the local node is searched.
The extension set identifier is used with other extension related directives to access the extension set.
The following constraints apply to this directive: