source: rtems/c/src/exec/score/inline/tqdata.inl @ 1a8fde6c

4.104.114.84.95
Last change on this file since 1a8fde6c was 1a8fde6c, checked in by Joel Sherrill <joel.sherrill@…>, on 03/06/96 at 21:34:57

Removed prototyes for static inline routines and moved the comments into
the inline implementation. The impetus for this was twofold. First,
it is incorrect to have static inline prototypes when using the macro
implementation. Second, this reduced the number of lines in the include
files seen by rtems.h by about 2000 lines.

Next we restricted visibility for the inline routines to inside the
executive itself EXCEPT for a handful of objects. This reduced the
number of include files included by rtems.h by 40 files and reduced
the lines in the include files seen by rtems.h by about 6000 lines.

In total, these reduced the compile time of the entire RTEMS tree by 20%.
This results in about 8 minutes savings on the SparcStation? 10 morgana.

  • Property mode set to 100644
File size: 2.0 KB
Line 
1/*  tqdata.inl
2 *
3 *  This file contains the static inline implementation of the inlined
4 *  routines needed to support the Thread Queue Data.
5 *
6 *  COPYRIGHT (c) 1989, 1990, 1991, 1992, 1993, 1994.
7 *  On-Line Applications Research Corporation (OAR).
8 *  All rights assigned to U.S. Government, 1994.
9 *
10 *  This material may be reproduced by or for the U.S. Government pursuant
11 *  to the copyright license under the clause at DFARS 252.227-7013.  This
12 *  notice must appear in all copies of this file and its derivatives.
13 *
14 *  $Id$
15 */
16
17#ifndef __THREAD_QUEUE_DATA_inl
18#define __THREAD_QUEUE_DATA_inl
19
20/*PAGE
21 *
22 *  _Thread_queue_Header_number
23 *
24 *  DESCRIPTION:
25 *
26 *  This function returns the index of the priority chain on which
27 *  a thread of the_priority should be placed.
28 */
29
30STATIC INLINE unsigned32 _Thread_queue_Header_number (
31  Priority_Control the_priority
32)
33{
34  return (the_priority / TASK_QUEUE_DATA_PRIORITIES_PER_HEADER);
35}
36
37/*PAGE
38 *
39 *  _Thread_queue_Is_reverse_search
40 *
41 *  DESCRIPTION:
42 *
43 *  This function returns TRUE if the_priority indicates that the
44 *  enqueue search should start at the front of this priority
45 *  group chain, and FALSE if the search should start at the rear.
46 */
47
48STATIC INLINE boolean _Thread_queue_Is_reverse_search (
49  Priority_Control the_priority
50)
51{
52  return ( the_priority & TASK_QUEUE_DATA_REVERSE_SEARCH_MASK );
53}
54
55/*PAGE
56 *
57 *  _Thread_queue_Get_number_waiting
58 *
59 *  DESCRIPTION:
60 *
61 *  This function returns the number of threads waiting on this thread queue.
62 */
63 
64STATIC INLINE unsigned32 _Thread_queue_Get_number_waiting (
65  Thread_queue_Control *the_thread_queue
66)
67{
68  return ( the_thread_queue->count );
69}
70
71/*PAGE
72 *
73 *  _Thread_queue_Enter_critical_section
74 *
75 *  DESCRIPTION:
76 *
77 *  This routine is invoked to indicate that the specified thread queue is
78 *  entering a critical section.
79 */
80 
81STATIC INLINE void _Thread_queue_Enter_critical_section (
82  Thread_queue_Control *the_thread_queue
83)
84{
85  the_thread_queue->sync_state = THREAD_QUEUE_NOTHING_HAPPENED;
86}
87
88#endif
89/* end of include file */
Note: See TracBrowser for help on using the repository browser.