1 |
2 |
drasko |
/* Definitions of constants and data structure for POSIX 1003.1b-1993
|
2 |
|
|
scheduling interface.
|
3 |
|
|
Copyright (C) 1996-1999,2001-2003,2005,2006 Free Software Foundation, Inc.
|
4 |
|
|
This file is part of the GNU C Library.
|
5 |
|
|
|
6 |
|
|
The GNU C Library is free software; you can redistribute it and/or
|
7 |
|
|
modify it under the terms of the GNU Lesser General Public
|
8 |
|
|
License as published by the Free Software Foundation; either
|
9 |
|
|
version 2.1 of the License, or (at your option) any later version.
|
10 |
|
|
|
11 |
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
12 |
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
13 |
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
14 |
|
|
Lesser General Public License for more details.
|
15 |
|
|
|
16 |
|
|
You should have received a copy of the GNU Lesser General Public
|
17 |
|
|
License along with the GNU C Library; if not, write to the Free
|
18 |
|
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
19 |
|
|
02111-1307 USA. */
|
20 |
|
|
|
21 |
|
|
#ifndef __need_schedparam
|
22 |
|
|
|
23 |
|
|
//#ifndef _SCHED_H
|
24 |
|
|
//# error "Never include <bits/sched.h> directly; use <sched.h> instead."
|
25 |
|
|
//#endif
|
26 |
|
|
|
27 |
|
|
|
28 |
|
|
/* Scheduling algorithms. */
|
29 |
|
|
#define SCHED_OTHER 0
|
30 |
|
|
#define SCHED_FIFO 1
|
31 |
|
|
#define SCHED_RR 2
|
32 |
|
|
#ifdef __USE_GNU
|
33 |
|
|
# define SCHED_BATCH 3
|
34 |
|
|
#endif
|
35 |
|
|
|
36 |
|
|
#ifdef __USE_MISC
|
37 |
|
|
/* Cloning flags. */
|
38 |
|
|
# define CSIGNAL 0x000000ff /* Signal mask to be sent at exit. */
|
39 |
|
|
# define CLONE_VM 0x00000100 /* Set if VM shared between processes. */
|
40 |
|
|
# define CLONE_FS 0x00000200 /* Set if fs info shared between processes. */
|
41 |
|
|
# define CLONE_FILES 0x00000400 /* Set if open files shared between processes. */
|
42 |
|
|
# define CLONE_SIGHAND 0x00000800 /* Set if signal handlers shared. */
|
43 |
|
|
# define CLONE_PTRACE 0x00002000 /* Set if tracing continues on the child. */
|
44 |
|
|
# define CLONE_VFORK 0x00004000 /* Set if the parent wants the child to
|
45 |
|
|
wake it up on mm_release. */
|
46 |
|
|
# define CLONE_PARENT 0x00008000 /* Set if we want to have the same
|
47 |
|
|
parent as the cloner. */
|
48 |
|
|
# define CLONE_THREAD 0x00010000 /* Set to add to same thread group. */
|
49 |
|
|
# define CLONE_NEWNS 0x00020000 /* Set to create new namespace. */
|
50 |
|
|
# define CLONE_SYSVSEM 0x00040000 /* Set to shared SVID SEM_UNDO semantics. */
|
51 |
|
|
# define CLONE_SETTLS 0x00080000 /* Set TLS info. */
|
52 |
|
|
# define CLONE_PARENT_SETTID 0x00100000 /* Store TID in userlevel buffer
|
53 |
|
|
before MM copy. */
|
54 |
|
|
# define CLONE_CHILD_CLEARTID 0x00200000 /* Register exit futex and memory
|
55 |
|
|
location to clear. */
|
56 |
|
|
# define CLONE_DETACHED 0x00400000 /* Create clone detached. */
|
57 |
|
|
# define CLONE_UNTRACED 0x00800000 /* Set if the tracing process can't
|
58 |
|
|
force CLONE_PTRACE on this clone. */
|
59 |
|
|
# define CLONE_CHILD_SETTID 0x01000000 /* Store TID in userlevel buffer in
|
60 |
|
|
the child. */
|
61 |
|
|
# define CLONE_STOPPED 0x02000000 /* Start in stopped state. */
|
62 |
|
|
#endif
|
63 |
|
|
|
64 |
|
|
/* The official definition. */
|
65 |
|
|
struct sched_param
|
66 |
|
|
{
|
67 |
|
|
int __sched_priority;
|
68 |
|
|
};
|
69 |
|
|
|
70 |
|
|
__BEGIN_DECLS
|
71 |
|
|
|
72 |
|
|
#ifdef __USE_MISC
|
73 |
|
|
/* Clone current process. */
|
74 |
|
|
extern int clone (int (*__fn) (void *__arg), void *__child_stack,
|
75 |
|
|
int __flags, void *__arg, ...) __THROW;
|
76 |
|
|
|
77 |
|
|
#if 0
|
78 |
|
|
/* Unshare the specified resources. */
|
79 |
|
|
extern int unshare (int __flags) __THROW;
|
80 |
|
|
#endif
|
81 |
|
|
#endif
|
82 |
|
|
|
83 |
|
|
__END_DECLS
|
84 |
|
|
|
85 |
|
|
#endif /* need schedparam */
|
86 |
|
|
|
87 |
|
|
#if !defined __defined_schedparam \
|
88 |
|
|
&& (defined __need_schedparam || defined _SCHED_H)
|
89 |
|
|
# define __defined_schedparam 1
|
90 |
|
|
/* Data structure to describe a process' schedulability. */
|
91 |
|
|
struct __sched_param
|
92 |
|
|
{
|
93 |
|
|
int __sched_priority;
|
94 |
|
|
};
|
95 |
|
|
# undef __need_schedparam
|
96 |
|
|
#endif
|
97 |
|
|
|
98 |
|
|
|
99 |
|
|
#if defined _SCHED_H && !defined __cpu_set_t_defined
|
100 |
|
|
# define __cpu_set_t_defined
|
101 |
|
|
/* Size definition for CPU sets. */
|
102 |
|
|
# define __CPU_SETSIZE 1024
|
103 |
|
|
# define __NCPUBITS (8 * sizeof (__cpu_mask))
|
104 |
|
|
|
105 |
|
|
/* Type for array elements in 'cpu_set'. */
|
106 |
|
|
typedef unsigned long int __cpu_mask;
|
107 |
|
|
|
108 |
|
|
/* Basic access functions. */
|
109 |
|
|
# define __CPUELT(cpu) ((cpu) / __NCPUBITS)
|
110 |
|
|
# define __CPUMASK(cpu) ((__cpu_mask) 1 << ((cpu) % __NCPUBITS))
|
111 |
|
|
|
112 |
|
|
/* Data structure to describe CPU mask. */
|
113 |
|
|
typedef struct
|
114 |
|
|
{
|
115 |
|
|
__cpu_mask __bits[__CPU_SETSIZE / __NCPUBITS];
|
116 |
|
|
} cpu_set_t;
|
117 |
|
|
|
118 |
|
|
/* Access functions for CPU masks. */
|
119 |
|
|
# define __CPU_ZERO(cpusetp) \
|
120 |
|
|
do { \
|
121 |
|
|
unsigned int __i; \
|
122 |
|
|
cpu_set_t *__arr = (cpusetp); \
|
123 |
|
|
for (__i = 0; __i < sizeof (cpu_set_t) / sizeof (__cpu_mask); ++__i) \
|
124 |
|
|
__arr->__bits[__i] = 0; \
|
125 |
|
|
} while (0)
|
126 |
|
|
# define __CPU_SET(cpu, cpusetp) \
|
127 |
|
|
((cpusetp)->__bits[__CPUELT (cpu)] |= __CPUMASK (cpu))
|
128 |
|
|
# define __CPU_CLR(cpu, cpusetp) \
|
129 |
|
|
((cpusetp)->__bits[__CPUELT (cpu)] &= ~__CPUMASK (cpu))
|
130 |
|
|
# define __CPU_ISSET(cpu, cpusetp) \
|
131 |
|
|
(((cpusetp)->__bits[__CPUELT (cpu)] & __CPUMASK (cpu)) != 0)
|
132 |
|
|
#endif
|