blob: fba6514e9ec9af49b43dc905e5e9305a25297782 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
28#ifndef _SCHED_H_
29#define _SCHED_H_
30
31#include <sys/cdefs.h>
32#include <sys/time.h>
33
Elliott Hughes887e1142014-01-02 12:05:50 -080034#include <linux/sched.h>
35
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080036__BEGIN_DECLS
37
Elliott Hughes887e1142014-01-02 12:05:50 -080038/* This name is used by glibc, but not by the kernel. */
39#define SCHED_OTHER SCHED_NORMAL
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080040
41struct sched_param {
Elliott Hughes887e1142014-01-02 12:05:50 -080042 int sched_priority;
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080043};
44
Elliott Hughes887e1142014-01-02 12:05:50 -080045extern int sched_setscheduler(pid_t, int, const struct sched_param*);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080046extern int sched_getscheduler(pid_t);
47extern int sched_yield(void);
Elliott Hughes887e1142014-01-02 12:05:50 -080048extern int sched_get_priority_max(int);
49extern int sched_get_priority_min(int);
50extern int sched_setparam(pid_t, const struct sched_param*);
51extern int sched_getparam(pid_t, struct sched_param*);
52extern int sched_rr_get_interval(pid_t, struct timespec*);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080053
David 'Digit' Turnerbb5581a2010-10-09 17:56:55 +020054#ifdef _GNU_SOURCE
Elliott Hughes887e1142014-01-02 12:05:50 -080055
56extern int clone(int (*)(void*), void*, int, void*, ...);
Jeff Sharkey82393de2012-08-11 14:12:26 -070057extern int unshare(int);
David 'Digit' Turner72e6fd42010-12-03 18:04:01 +010058extern int sched_getcpu(void);
Elliott Hughes887e1142014-01-02 12:05:50 -080059extern int setns(int, int);
David 'Digit' Turner72e6fd42010-12-03 18:04:01 +010060
61/* Our implementation supports up to 32 independent CPUs, which is also
62 * the maximum supported by the kernel at the moment. GLibc uses 1024 by
63 * default.
64 *
65 * If you want to use more than that, you should use CPU_ALLOC() / CPU_FREE()
66 * and the CPU_XXX_S() macro variants.
67 */
68#define CPU_SETSIZE 32
69
70#define __CPU_BITTYPE unsigned long int /* mandated by the kernel */
71#define __CPU_BITSHIFT 5 /* should be log2(BITTYPE) */
72#define __CPU_BITS (1 << __CPU_BITSHIFT)
73#define __CPU_ELT(x) ((x) >> __CPU_BITSHIFT)
74#define __CPU_MASK(x) ((__CPU_BITTYPE)1 << ((x) & (__CPU_BITS-1)))
75
76typedef struct {
77 __CPU_BITTYPE __bits[ CPU_SETSIZE / __CPU_BITS ];
78} cpu_set_t;
79
80extern int sched_setaffinity(pid_t pid, size_t setsize, const cpu_set_t* set);
81
82extern int sched_getaffinity(pid_t pid, size_t setsize, cpu_set_t* set);
83
84/* Provide optimized implementation for 32-bit cpu_set_t */
85#if CPU_SETSIZE == __CPU_BITS
86
87# define CPU_ZERO(set_) \
88 do{ \
89 (set_)->__bits[0] = 0; \
90 }while(0)
91
92# define CPU_SET(cpu_,set_) \
93 do {\
94 size_t __cpu = (cpu_); \
95 if (__cpu < CPU_SETSIZE) \
96 (set_)->__bits[0] |= __CPU_MASK(__cpu); \
97 }while (0)
98
99# define CPU_CLR(cpu_,set_) \
100 do {\
101 size_t __cpu = (cpu_); \
102 if (__cpu < CPU_SETSIZE) \
103 (set_)->__bits[0] &= ~__CPU_MASK(__cpu); \
104 }while (0)
105
106# define CPU_ISSET(cpu_, set_) \
107 (__extension__({\
108 size_t __cpu = (cpu_); \
109 (cpu_ < CPU_SETSIZE) \
110 ? ((set_)->__bits[0] & __CPU_MASK(__cpu)) != 0 \
111 : 0; \
112 }))
113
114# define CPU_EQUAL(set1_, set2_) \
115 ((set1_)->__bits[0] == (set2_)->__bits[0])
116
117# define __CPU_OP(dst_, set1_, set2_, op_) \
118 do { \
119 (dst_)->__bits[0] = (set1_)->__bits[0] op_ (set2_)->__bits[0]; \
120 } while (0)
121
122# define CPU_COUNT(set_) __builtin_popcountl((set_)->__bits[0])
123
124#else /* CPU_SETSIZE != __CPU_BITS */
125
126# define CPU_ZERO(set_) CPU_ZERO_S(sizeof(cpu_set_t), set_)
127# define CPU_SET(cpu_,set_) CPU_SET_S(cpu_,sizeof(cpu_set_t),set_)
128# define CPU_CLR(cpu_,set_) CPU_CLR_S(cpu_,sizeof(cpu_set_t),set_)
129# define CPU_ISSET(cpu_,set_) CPU_ISSET_S(cpu_,sizeof(cpu_set_t),set_)
130# define CPU_COUNT(set_) CPU_COUNT_S(sizeof(cpu_set_t),set_)
131# define CPU_EQUAL(set1_,set2_) CPU_EQUAL_S(sizeof(cpu_set_t),set1_,set2_)
132
133# define __CPU_OP(dst_,set1_,set2_,op_) __CPU_OP_S(sizeof(cpu_set_t),dst_,set1_,set2_,op_)
134
135#endif /* CPU_SETSIZE != __CPU_BITS */
136
137#define CPU_AND(set1_,set2_) __CPU_OP(set1_,set2_,&)
138#define CPU_OR(set1_,set2_) __CPU_OP(set1_,set2_,|)
139#define CPU_XOR(set1_,set2_) __CPU_OP(set1_,set2_,^)
140
141/* Support for dynamically-allocated cpu_set_t */
142
143#define CPU_ALLOC_SIZE(count) \
144 __CPU_ELT((count) + (__CPU_BITS-1))*sizeof(__CPU_BITTYPE)
145
146#define CPU_ALLOC(count) __sched_cpualloc((count));
147#define CPU_FREE(set) __sched_cpufree((set))
148
149extern cpu_set_t* __sched_cpualloc(size_t count);
150extern void __sched_cpufree(cpu_set_t* set);
151
152#define CPU_ZERO_S(setsize_,set_) \
153 do { \
154 size_t __nn = 0; \
155 size_t __nn_max = (setsize_)/sizeof(__CPU_BITTYPE); \
156 for (; __nn < __nn_max; __nn++) \
157 (set_)->__bits[__nn] = 0; \
158 } while (0)
159
160#define CPU_SET_S(cpu_,setsize_,set_) \
161 do { \
162 size_t __cpu = (cpu_); \
163 if (__cpu < 8*(setsize_)) \
164 (set_)->__bits[__CPU_ELT(__cpu)] |= __CPU_MASK(__cpu); \
165 } while (0)
166
167#define CPU_CLR_S(cpu_,setsize_,set_) \
168 do { \
169 size_t __cpu = (cpu_); \
170 if (__cpu < 8*(setsize_)) \
171 (set_)->__bits[__CPU_ELT(__cpu)] &= ~__CPU_MASK(__cpu); \
172 } while (0)
173
174#define CPU_ISSET_S(cpu_, setsize_, set_) \
175 (__extension__ ({ \
176 size_t __cpu = (cpu_); \
177 (__cpu < 8*(setsize_)) \
178 ? ((set_)->__bits[__CPU_ELT(__cpu)] & __CPU_MASK(__cpu)) != 0 \
179 : 0; \
180 }))
181
182#define CPU_EQUAL_S(setsize_, set1_, set2_) \
183 (__extension__ ({ \
184 __const __CPU_BITTYPE* __src1 = (set1_)->__bits; \
185 __const __CPU_BITTYPE* __src2 = (set2_)->__bits; \
186 size_t __nn = 0, __nn_max = (setsize_)/sizeof(__CPU_BITTYPE); \
187 for (; __nn < __nn_max; __nn++) { \
188 if (__src1[__nn] != __src2[__nn]) \
189 break; \
190 } \
191 __nn == __nn_max; \
192 }))
193
194#define __CPU_OP_S(setsize_, dstset_, srcset1_, srcset2_, op) \
195 do { \
196 cpu_set_t* __dst = (dstset); \
197 const __CPU_BITTYPE* __src1 = (srcset1)->__bits; \
198 const __CPU_BITTYPE* __src2 = (srcset2)->__bits; \
199 size_t __nn = 0, __nn_max = (setsize_)/sizeof(__CPU_BITTYPE); \
200 for (; __nn < __nn_max; __nn++) \
201 (__dst)->__bits[__nn] = __src1[__nn] op __src2[__nn]; \
202 } while (0)
203
204#define CPU_COUNT_S(setsize_, set_) \
205 __sched_cpucount((setsize_), (set_))
206
207extern int __sched_cpucount(size_t setsize, cpu_set_t* set);
208
209#endif /* _GNU_SOURCE */
210
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800211__END_DECLS
212
213#endif /* _SCHED_H_ */