userext.inl

来自「开放源码的嵌入式开发环境」· INL 代码 · 共 157 行

INL
157
字号
/**  *  @file  rtems/score/userext.inl * *  This file contains the macro implementation of the inlined routines *  from the User Extension Handler *//* *  COPYRIGHT (c) 1989-2004. *  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.rtems.com/license/LICENSE. * *  $Id: userext.inl,v 1.24 2005/02/21 07:53:52 ralf Exp $ */#ifndef _RTEMS_SCORE_USEREXT_INL#define _RTEMS_SCORE_USEREXT_INL#include <rtems/score/wkspace.h>#include <string.h> /* memset *//** *  @addtogroup ScoreUserExt  *  @{ *//** *  This routine is used to add a user extension set to the active list. * *  @note Must be before _User_extensions_Handler_initialization to *        ensure proper inlining. */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 );  /*   * 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 );  }}/** *  This routine performs the initialization necessary for this handler. */RTEMS_INLINE_ROUTINE void _User_extensions_Handler_initialization (    uint32_t                number_of_extensions,    User_extensions_Table  *initial_extensions){  User_extensions_Control *extension;  uint32_t                 i;  _Chain_Initialize_empty( &_User_extensions_List );  _Chain_Initialize_empty( &_User_extensions_Switches_list );  if ( initial_extensions ) {    extension = (User_extensions_Control *)      _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++;    }  }}/** *  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_Append( &_User_extensions_List, &the_extension->Node );  /*   *  If a switch handler is present, append it to the switch chain.   */  if ( the_extension->Callouts.thread_switch != NULL ) {    the_extension->Switch.thread_switch = the_extension->Callouts.thread_switch;    _Chain_Append(       &_User_extensions_Switches_list, &the_extension->Switch.Node );  }}/** *  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 );    /*   * If a switch handler is present, remove it.   */  if ( the_extension->Callouts.thread_switch != NULL )    _Chain_Extract( &the_extension->Switch.Node );}/** *  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_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_switch = (User_extensions_Switch_control *) the_node;    (*the_extension_switch->thread_switch)( executing, heir );  }}/**@}*/#endif/* end of include file */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?