source: rtems/cpukit/score/inline/rtems/score/userext.inl @ dd687d97

4.104.114.84.95
Last change on this file since dd687d97 was dd687d97, checked in by Joel Sherrill <joel.sherrill@…>, on 09/04/03 at 18:56:05

2003-09-04 Joel Sherrill <joel@…>

  • include/rtems/debug.h, include/rtems/seterr.h, include/rtems/system.h, include/rtems/score/address.h, include/rtems/score/apiext.h, include/rtems/score/apimutex.h, include/rtems/score/bitfield.h, include/rtems/score/chain.h, include/rtems/score/context.h, include/rtems/score/copyrt.h, include/rtems/score/coremsg.h, include/rtems/score/coremutex.h, include/rtems/score/coresem.h, include/rtems/score/heap.h, include/rtems/score/interr.h, include/rtems/score/isr.h, include/rtems/score/mpci.h, include/rtems/score/mppkt.h, include/rtems/score/object.h, include/rtems/score/objectmp.h, include/rtems/score/priority.h, include/rtems/score/stack.h, include/rtems/score/states.h, include/rtems/score/sysstate.h, include/rtems/score/thread.h, include/rtems/score/threadmp.h, include/rtems/score/threadq.h, include/rtems/score/tod.h, include/rtems/score/tqdata.h, include/rtems/score/userext.h, include/rtems/score/watchdog.h, include/rtems/score/wkspace.h, inline/rtems/score/address.inl, inline/rtems/score/chain.inl, inline/rtems/score/coremsg.inl, inline/rtems/score/coremutex.inl, inline/rtems/score/coresem.inl, inline/rtems/score/heap.inl, inline/rtems/score/isr.inl, inline/rtems/score/mppkt.inl, inline/rtems/score/object.inl, inline/rtems/score/objectmp.inl, inline/rtems/score/priority.inl, inline/rtems/score/stack.inl, inline/rtems/score/states.inl, inline/rtems/score/sysstate.inl, inline/rtems/score/thread.inl, inline/rtems/score/threadmp.inl, inline/rtems/score/tod.inl, inline/rtems/score/tqdata.inl, inline/rtems/score/userext.inl, inline/rtems/score/watchdog.inl, inline/rtems/score/wkspace.inl, macros/rtems/score/address.inl, macros/rtems/score/chain.inl, macros/rtems/score/coremsg.inl, macros/rtems/score/coremutex.inl, macros/rtems/score/coresem.inl, macros/rtems/score/heap.inl, macros/rtems/score/isr.inl, macros/rtems/score/mppkt.inl, macros/rtems/score/object.inl, macros/rtems/score/objectmp.inl, macros/rtems/score/priority.inl, macros/rtems/score/stack.inl, macros/rtems/score/states.inl, macros/rtems/score/sysstate.inl, macros/rtems/score/thread.inl, macros/rtems/score/threadmp.inl, macros/rtems/score/tod.inl, macros/rtems/score/tqdata.inl, macros/rtems/score/userext.inl, macros/rtems/score/watchdog.inl, macros/rtems/score/wkspace.inl, src/apiext.c, src/chain.c, src/coremsg.c, src/coremsgbroadcast.c, src/coremsgclose.c, src/coremsgflush.c, src/coremsgflushsupp.c, src/coremsgflushwait.c, src/coremsginsert.c, src/coremsgseize.c, src/coremsgsubmit.c, src/coremutex.c, src/coremutexflush.c, src/coremutexseize.c, src/coremutexsurrender.c, src/coresem.c, src/coresemflush.c, src/coresemseize.c, src/coresemsurrender.c, src/coretod.c, src/coretodset.c, src/coretodtickle.c, src/coretodtoseconds.c, src/coretodvalidate.c, src/heap.c, src/heapallocate.c, src/heapextend.c, src/heapfree.c, src/heapgetinfo.c, src/heapsizeofuserarea.c, src/heapwalk.c, src/interr.c, src/isr.c, src/iterateoverthreads.c, src/mpci.c, src/object.c, src/objectallocate.c, src/objectallocatebyindex.c, src/objectclearname.c, src/objectcomparenameraw.c, src/objectcomparenamestring.c, src/objectcopynameraw.c, src/objectcopynamestring.c, src/objectextendinformation.c, src/objectfree.c, src/objectget.c, src/objectgetbyindex.c, src/objectgetisr.c, src/objectgetnext.c, src/objectgetnoprotection.c, src/objectidtoname.c, src/objectinitializeinformation.c, src/objectmp.c, src/objectnametoid.c, src/objectshrinkinformation.c, src/thread.c, src/threadchangepriority.c, src/threadclearstate.c, src/threadclose.c, src/threadcreateidle.c, src/threaddelayended.c, src/threaddispatch.c, src/threadevaluatemode.c, src/threadget.c, src/threadhandler.c, src/threadidlebody.c, src/threadinitialize.c, src/threadloadenv.c, src/threadmp.c, src/threadq.c, src/threadqdequeue.c, src/threadqdequeuefifo.c, src/threadqdequeuepriority.c, src/threadqenqueue.c, src/threadqenqueuefifo.c, src/threadqenqueuepriority.c, src/threadqextract.c, src/threadqextractfifo.c, src/threadqextractpriority.c, src/threadqextractwithproxy.c, src/threadqfirst.c, src/threadqfirstfifo.c, src/threadqfirstpriority.c, src/threadqflush.c, src/threadqtimeout.c, src/threadready.c, src/threadreset.c, src/threadresettimeslice.c, src/threadrestart.c, src/threadresume.c, src/threadrotatequeue.c, src/threadsetpriority.c, src/threadsetstate.c, src/threadsettransient.c, src/threadstackallocate.c, src/threadstackfree.c, src/threadstart.c, src/threadstartmultitasking.c, src/threadsuspend.c, src/threadtickletimeslice.c, src/threadyieldprocessor.c, src/userext.c, src/watchdog.c, src/watchdogadjust.c, src/watchdoginsert.c, src/watchdogremove.c, src/watchdogtickle.c, src/wkspace.c: URL for license changed.
  • Property mode set to 100644
File size: 4.0 KB
Line 
1/*  userext.inl
2 *
3 *  This file contains the macro implementation of the inlined routines
4 *  from the User Extension Handler
5 *
6 *  COPYRIGHT (c) 1989-1999.
7 *  On-Line Applications Research Corporation (OAR).
8 *
9 *  The license and distribution terms for this file may be
10 *  found in the file LICENSE in this distribution or at
11 *  http://www.rtems.com/license/LICENSE.
12 *
13 *  $Id$
14 */
15
16#ifndef __USER_EXTENSIONS_inl
17#define __USER_EXTENSIONS_inl
18
19#include <rtems/score/wkspace.h>
20
21/*PAGE
22 *
23 *  _User_extensions_Add_set
24 *
25 *  DESCRIPTION:
26 *
27 *  This routine is used to add a user extension set to the active list.
28 *
29 *  NOTE: Must be before _User_extensions_Handler_initialization to
30 *        ensure proper inlining.
31 */
32
33RTEMS_INLINE_ROUTINE void _User_extensions_Add_set (
34  User_extensions_Control *the_extension,
35  User_extensions_Table   *extension_table
36)
37{
38  the_extension->Callouts = *extension_table;
39
40  _Chain_Append( &_User_extensions_List, &the_extension->Node );
41
42  /*
43   * If a switch handler is present, append it to the switch chain.
44   */
45
46  if ( extension_table->thread_switch != NULL ) {
47    the_extension->Switch.thread_switch = extension_table->thread_switch;
48    _Chain_Append( &_User_extensions_Switches_list, &the_extension->Switch.Node );
49  }
50}
51
52/*PAGE
53 *
54 *  _User_extensions_Handler_initialization
55 *
56 *  DESCRIPTION:
57 *
58 *  This routine performs the initialization necessary for this handler.
59 */
60
61RTEMS_INLINE_ROUTINE void _User_extensions_Handler_initialization (
62    unsigned32              number_of_extensions,
63    User_extensions_Table  *initial_extensions
64)
65{
66  User_extensions_Control *extension;
67  unsigned32               i;
68
69  _Chain_Initialize_empty( &_User_extensions_List );
70  _Chain_Initialize_empty( &_User_extensions_Switches_list );
71
72  if ( initial_extensions ) {
73    extension =
74      _Workspace_Allocate_or_fatal_error(
75        number_of_extensions * sizeof( User_extensions_Control )
76      );
77 
78    memset (
79      extension,
80      0,
81      number_of_extensions * sizeof( User_extensions_Control )
82    );
83 
84    for ( i = 0 ; i < number_of_extensions ; i++ ) {
85      _User_extensions_Add_set (extension, &initial_extensions[i]);
86      extension++;
87    }
88  }
89}
90
91/*PAGE
92 *
93 *  _User_extensions_Add_API_set
94 *
95 *  DESCRIPTION:
96 *
97 *  This routine is used to add an API extension set to the active list.
98 */
99 
100RTEMS_INLINE_ROUTINE void _User_extensions_Add_API_set (
101  User_extensions_Control *the_extension
102)
103{
104  _Chain_Append( &_User_extensions_List, &the_extension->Node );
105
106  /*
107   *  If a switch handler is present, append it to the switch chain.
108   */
109
110  if ( the_extension->Callouts.thread_switch != NULL ) {
111    the_extension->Switch.thread_switch = the_extension->Callouts.thread_switch;
112    _Chain_Append(
113      &_User_extensions_Switches_list, &the_extension->Switch.Node );
114  }
115}
116
117/*PAGE
118 *
119 *  _User_extensions_Remove_set
120 *
121 *  DESCRIPTION:
122 *
123 *  This routine is used to remove a user extension set from the active list.
124 */
125
126RTEMS_INLINE_ROUTINE void _User_extensions_Remove_set (
127  User_extensions_Control  *the_extension
128)
129{
130  _Chain_Extract( &the_extension->Node );
131 
132  /*
133   * If a switch handler is present, remove it.
134   */
135
136  if ( the_extension->Callouts.thread_switch != NULL )
137    _Chain_Extract( &the_extension->Switch.Node );
138}
139
140/*PAGE
141 *
142 *  _User_extensions_Thread_switch
143 *
144 *  DESCRIPTION:
145 *
146 *  This routine is used to invoke the user extension which
147 *  is invoked when a context switch occurs.
148 */
149
150RTEMS_INLINE_ROUTINE void _User_extensions_Thread_switch (
151  Thread_Control *executing,
152  Thread_Control *heir
153)
154{
155  Chain_Node                     *the_node;
156  User_extensions_Switch_control *the_extension_switch;
157 
158  for ( the_node = _User_extensions_Switches_list.first ;
159        !_Chain_Is_tail( &_User_extensions_Switches_list, the_node ) ;
160        the_node = the_node->next ) {
161
162    the_extension_switch = (User_extensions_Switch_control *) the_node;
163
164    (*the_extension_switch->thread_switch)( executing, heir );
165  }
166}
167
168#endif
169/* end of include file */
Note: See TracBrowser for help on using the repository browser.