URL
https://opencores.org/ocsvn/openrisc/openrisc/trunk
Subversion Repositories openrisc
[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [exec/] [score/] [inline/] [rtems/] [score/] [userext.inl] - Rev 173
Compare with Previous | Blame | View Log
/* userext.inl
*
* This file contains the macro implementation of the inlined routines
* from the User Extension Handler
*
* COPYRIGHT (c) 1989-1999.
* On-Line Applications Research Corporation (OAR).
*
* 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: userext.inl,v 1.2 2001-09-27 11:59:34 chris Exp $
*/
#ifndef __USER_EXTENSIONS_inl
#define __USER_EXTENSIONS_inl
#include <rtems/score/wkspace.h>
/*PAGE
*
* _User_extensions_Handler_initialization
*
* DESCRIPTION:
*
* This routine performs the initialization necessary for this handler.
*/
RTEMS_INLINE_ROUTINE void _User_extensions_Handler_initialization (
unsigned32 number_of_extensions,
User_extensions_Table *initial_extensions
)
{
User_extensions_Control *extension;
unsigned32 i;
_Chain_Initialize_empty( &_User_extensions_List );
if ( initial_extensions ) {
for (i=0 ; i<number_of_extensions ; i++ ) {
extension =
_Workspace_Allocate_or_fatal_error( sizeof(User_extensions_Control) );
extension->Callouts = initial_extensions[i];
_Chain_Append( &_User_extensions_List, &extension->Node );
}
}
}
/*PAGE
*
* _User_extensions_Add_set
*
* DESCRIPTION:
*
* This routine is used to add a user extension set to the active list.
*/
RTEMS_INLINE_ROUTINE void _User_extensions_Add_set (
User_extensions_Control *the_extension,
User_extensions_Table *extension_table
)
{
the_extension->Callouts = *extension_table;
_Chain_Append( &_User_extensions_List, &the_extension->Node );
}
/*PAGE
*
* _User_extensions_Add_API_set
* DESCRIPTION:
*
* This routine is used to add an API extension set to the active list.
*/
RTEMS_INLINE_ROUTINE void _User_extensions_Add_API_set (
User_extensions_Control *the_extension
)
{
_Chain_Prepend( &_User_extensions_List, &the_extension->Node );
}
/*PAGE
*
* _User_extensions_Remove_set
*
* DESCRIPTION:
*
* This routine is used to remove a user extension set from the active list.
*/
RTEMS_INLINE_ROUTINE void _User_extensions_Remove_set (
User_extensions_Control *the_extension
)
{
_Chain_Extract( &the_extension->Node );
}
/*PAGE
*
* _User_extensions_Thread_switch
*
* DESCRIPTION:
*
* This routine is used to invoke the user extension which
* is invoked when a context switch occurs.
*/
RTEMS_INLINE_ROUTINE void _User_extensions_Thread_switch (
Thread_Control *executing,
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 ) ;
the_node = the_node->next ) {
the_extension = (User_extensions_Control *) the_node;
if ( the_extension->Callouts.thread_switch != NULL )
(*the_extension->Callouts.thread_switch)( executing, heir );
}
}
#endif
/* end of include file */