summaryrefslogtreecommitdiffstats
path: root/c/src/exec/score/inline/rtems/score/userext.inl
diff options
context:
space:
mode:
authorJoel Sherrill <joel.sherrill@OARcorp.com>2002-04-08 17:23:11 +0000
committerJoel Sherrill <joel.sherrill@OARcorp.com>2002-04-08 17:23:11 +0000
commit7af623bf688801ea93d2b57afa4861e7a9136fb4 (patch)
tree95a77c21a9e11972bf852b0a731898c380072eb5 /c/src/exec/score/inline/rtems/score/userext.inl
parent2002-04-08 Chris Johns <ccj@acm.org> (diff)
downloadrtems-7af623bf688801ea93d2b57afa4861e7a9136fb4.tar.bz2
2002-04-08 Chris Johns <ccj@acm.org>
* Per PR142, make task switch extension its own list. * include/rtems/score/userext.h: Reflect above by adding User_extensions_Switch_control and adding it to User_extenions_Control. * inline/rtems/score/userext.inl: Allocate all memory in one chunk to minimize overhead. Address processing dedicated switch chain.
Diffstat (limited to '')
-rw-r--r--c/src/exec/score/inline/rtems/score/userext.inl90
1 files changed, 57 insertions, 33 deletions
diff --git a/c/src/exec/score/inline/rtems/score/userext.inl b/c/src/exec/score/inline/rtems/score/userext.inl
index 06f1525680..9c8cb43731 100644
--- a/c/src/exec/score/inline/rtems/score/userext.inl
+++ b/c/src/exec/score/inline/rtems/score/userext.inl
@@ -20,56 +20,74 @@
/*PAGE
*
- * _User_extensions_Handler_initialization
+ * _User_extensions_Add_set
*
* DESCRIPTION:
*
- * This routine performs the initialization necessary for this handler.
+ * This routine is used to add a user extension set to the active list.
*/
-RTEMS_INLINE_ROUTINE void _User_extensions_Handler_initialization (
- unsigned32 number_of_extensions,
- User_extensions_Table *initial_extensions
+RTEMS_INLINE_ROUTINE void _User_extensions_Add_set (
+ User_extensions_Control *the_extension,
+ User_extensions_Table *extension_table
)
{
- User_extensions_Control *extension;
- unsigned32 i;
-
- _Chain_Initialize_empty( &_User_extensions_List );
+ the_extension->Callouts = *extension_table;
- if ( initial_extensions ) {
- for (i=0 ; i<number_of_extensions ; i++ ) {
- extension =
- _Workspace_Allocate_or_fatal_error( sizeof(User_extensions_Control) );
+ _Chain_Append( &_User_extensions_List, &the_extension->Node );
- extension->Callouts = initial_extensions[i];
- _Chain_Append( &_User_extensions_List, &extension->Node );
- }
+ /*
+ * If a switch handler is present, append it to the switch chain.
+ */
+ if ( extension_table->thread_switch != NULL ) {
+ the_extension->Switch.thread_switch = extension_table->thread_switch;
+ _Chain_Append( &_User_extensions_Switches_list, &the_extension->Switch.Node );
}
}
/*PAGE
*
- * _User_extensions_Add_set
+ * _User_extensions_Handler_initialization
*
* DESCRIPTION:
*
- * This routine is used to add a user extension set to the active list.
+ * This routine performs the initialization necessary for this handler.
*/
-RTEMS_INLINE_ROUTINE void _User_extensions_Add_set (
- User_extensions_Control *the_extension,
- User_extensions_Table *extension_table
+RTEMS_INLINE_ROUTINE void _User_extensions_Handler_initialization (
+ unsigned32 number_of_extensions,
+ User_extensions_Table *initial_extensions
)
{
- the_extension->Callouts = *extension_table;
+ User_extensions_Control *extension;
+ unsigned32 i;
- _Chain_Append( &_User_extensions_List, &the_extension->Node );
+ _Chain_Initialize_empty( &_User_extensions_List );
+ _Chain_Initialize_empty( &_User_extensions_Switches_list );
+
+ if ( initial_extensions ) {
+ extension =
+ _Workspace_Allocate_or_fatal_error(
+ number_of_extensions * sizeof( User_extensions_Control )
+ );
+
+ memset (
+ extension,
+ 0,
+ number_of_extensions * sizeof( User_extensions_Control )
+ );
+
+ for ( i = 0 ; i < number_of_extensions ; i++ ) {
+ _User_extensions_Add_set (extension, &initial_extensions[i]);
+ extension++;
+ }
+ }
}
/*PAGE
*
* _User_extensions_Add_API_set
+ *
* DESCRIPTION:
*
* This routine is used to add an API extension set to the active list.
@@ -79,9 +97,9 @@ RTEMS_INLINE_ROUTINE void _User_extensions_Add_API_set (
User_extensions_Control *the_extension
)
{
- _Chain_Prepend( &_User_extensions_List, &the_extension->Node );
+ _User_extensions_Add_set( the_extension );
}
-
+
/*PAGE
*
* _User_extensions_Remove_set
@@ -96,6 +114,13 @@ RTEMS_INLINE_ROUTINE void _User_extensions_Remove_set (
)
{
_Chain_Extract( &the_extension->Node );
+
+ /*
+ * If a switch handler is present, remove it.
+ */
+
+ if ( the_extension->Callouts.thread_switch != NULL )
+ _Chain_Extract( &the_extension->Switch.Node );
}
/*PAGE
@@ -113,17 +138,16 @@ RTEMS_INLINE_ROUTINE void _User_extensions_Thread_switch (
Thread_Control *heir
)
{
- Chain_Node *the_node;
- User_extensions_Control *the_extension;
-
- for ( the_node = _User_extensions_List.first ;
- !_Chain_Is_tail( &_User_extensions_List, the_node ) ;
+ Chain_Node *the_node;
+ User_extensions_Switch_control *the_extension_switch;
+
+ for ( the_node = _User_extensions_Switches_list.first ;
+ !_Chain_Is_tail( &_User_extensions_Switches_list, the_node ) ;
the_node = the_node->next ) {
- the_extension = (User_extensions_Control *) the_node;
+ the_extension_switch = (User_extensions_Switch_control *) the_node;
- if ( the_extension->Callouts.thread_switch != NULL )
- (*the_extension->Callouts.thread_switch)( executing, heir );
+ (*the_extension_switch->thread_switch)( executing, heir );
}
}