source: rtems/c/src/exec/score/headers/tqdata.h @ 3a4ae6c

4.104.114.84.95
Last change on this file since 3a4ae6c was 3a4ae6c, checked in by Joel Sherrill <joel.sherrill@…>, on 09/11/95 at 19:35:39

The word "RTEMS" almost completely removed from the core.

Configuration Table Template file added and all tests
modified to use this. All gvar.h and conftbl.h files
removed from test directories.

Configuration parameter maximum_devices added.

Core semaphore and mutex handlers added and RTEMS API Semaphore
Manager updated to reflect this.

Initialization sequence changed to invoke API specific initialization
routines. Initialization tasks table now owned by RTEMS Tasks Manager.

Added user extension for post-switch.

Utilized user extensions to implement API specific functionality
like signal dispatching.

Added extensions to the System Initialization Thread so that an
API can register a function to be invoked while the system
is being initialized. These are largely equivalent to the
pre-driver and post-driver hooks.

Added the Modules file oar-go32_p5, modified oar-go32, and modified
the file make/custom/go32.cfg to look at an environment varable which
determines what CPU model is being used.

All BSPs updated to reflect named devices and clock driver's IOCTL
used by the Shared Memory Driver. Also merged clock isr into
main file and removed ckisr.c where possible.

Updated spsize to reflect new and moved variables.

Makefiles for the executive source and include files updated to show
break down of files into Core, RTEMS API, and Neither.

Header and inline files installed into subdirectory based on whether
logically in the Core or a part of the RTEMS API.

  • Property mode set to 100644
File size: 2.4 KB
Line 
1/*  tqdata.h
2 *
3 *  This include file contains all the constants and structures
4 *  needed to declare a thread queue.
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_h
18#define __THREAD_QUEUE_DATA_h
19
20#ifdef __cplusplus
21extern "C" {
22#endif
23
24#include <rtems/core/chain.h>
25#include <rtems/core/priority.h>
26#include <rtems/core/states.h>
27
28/*
29 *  The following enumerated type details all of the disciplines
30 *  supported by the Thread Queue Handler.
31 */
32
33typedef enum {
34  THREAD_QUEUE_DISCIPLINE_FIFO,     /* FIFO queue discipline */
35  THREAD_QUEUE_DISCIPLINE_PRIORITY  /* PRIORITY queue discipline */
36}   Thread_queue_Disciplines;
37
38/*
39 *  The following record defines the control block used
40 *  to manage each thread.
41 */
42
43#define TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS 4   /* # of pri groups */
44
45typedef struct {
46  union {
47    Chain_Control Fifo;                /* FIFO discipline list           */
48    Chain_Control Priority[TASK_QUEUE_DATA_NUMBER_OF_PRIORITY_HEADERS];
49                                       /* priority discipline list       */
50  } Queues;
51  boolean                  sync;       /* alloc/dealloc critical section */
52  Thread_queue_Disciplines discipline; /* queue discipline               */
53  States_Control           state;      /* state of threads on Thread_q   */
54  unsigned32               timeout_status;
55}   Thread_queue_Control;
56
57/*
58 *  _Thread_queue_Header_number
59 *
60 *  DESCRIPTION:
61 *
62 *  This function returns the index of the priority chain on which
63 *  a thread of the_priority should be placed.
64 */
65
66STATIC INLINE unsigned32 _Thread_queue_Header_number (
67  Priority_Control the_priority
68);
69
70/*
71 *  _Thread_queue_Is_reverse_search
72 *
73 *  DESCRIPTION:
74 *
75 *  This function returns TRUE if the_priority indicates that the
76 *  enqueue search should start at the front of this priority
77 *  group chain, and FALSE if the search should start at the rear.
78 */
79
80STATIC INLINE boolean _Thread_queue_Is_reverse_search (
81  Priority_Control the_priority
82);
83
84#include <rtems/core/tqdata.inl>
85
86#ifdef __cplusplus
87}
88#endif
89
90#endif
91/* end of include file */
Note: See TracBrowser for help on using the repository browser.