blob: ed6e31d9c1959f204fedfda881e177678fd4687b [file] [log] [blame]
David Howells607ca462012-10-13 10:46:48 +01001#ifndef _UAPI_LINUX_SCHED_H
2#define _UAPI_LINUX_SCHED_H
3
4/*
5 * cloning flags:
6 */
7#define CSIGNAL 0x000000ff /* signal mask to be sent at exit */
8#define CLONE_VM 0x00000100 /* set if VM shared between processes */
9#define CLONE_FS 0x00000200 /* set if fs info shared between processes */
10#define CLONE_FILES 0x00000400 /* set if open files shared between processes */
11#define CLONE_SIGHAND 0x00000800 /* set if signal handlers and blocked signals shared */
Christian Brauner20c96e02019-03-27 13:04:15 +010012#define CLONE_PIDFD 0x00001000 /* set if a pidfd should be placed in parent */
David Howells607ca462012-10-13 10:46:48 +010013#define CLONE_PTRACE 0x00002000 /* set if we want to let tracing continue on the child too */
14#define CLONE_VFORK 0x00004000 /* set if the parent wants the child to wake it up on mm_release */
15#define CLONE_PARENT 0x00008000 /* set if we want to have the same parent as the cloner */
16#define CLONE_THREAD 0x00010000 /* Same thread group? */
Chen Hanxiaofcd964d2014-10-07 17:29:07 +080017#define CLONE_NEWNS 0x00020000 /* New mount namespace group */
David Howells607ca462012-10-13 10:46:48 +010018#define CLONE_SYSVSEM 0x00040000 /* share system V SEM_UNDO semantics */
19#define CLONE_SETTLS 0x00080000 /* create a new TLS for the child */
20#define CLONE_PARENT_SETTID 0x00100000 /* set the TID in the parent */
21#define CLONE_CHILD_CLEARTID 0x00200000 /* clear the TID in the child */
22#define CLONE_DETACHED 0x00400000 /* Unused, ignored */
23#define CLONE_UNTRACED 0x00800000 /* set if the tracing process can't force CLONE_PTRACE on this clone */
24#define CLONE_CHILD_SETTID 0x01000000 /* set the TID in the child */
Aditya Kali5e2bec72016-01-29 02:54:05 -060025#define CLONE_NEWCGROUP 0x02000000 /* New cgroup namespace */
Chen Hanxiaof622b422014-11-04 16:51:22 +080026#define CLONE_NEWUTS 0x04000000 /* New utsname namespace */
27#define CLONE_NEWIPC 0x08000000 /* New ipc namespace */
David Howells607ca462012-10-13 10:46:48 +010028#define CLONE_NEWUSER 0x10000000 /* New user namespace */
29#define CLONE_NEWPID 0x20000000 /* New pid namespace */
30#define CLONE_NEWNET 0x40000000 /* New network namespace */
31#define CLONE_IO 0x80000000 /* Clone io context */
32
33/*
34 * Scheduling policies
35 */
36#define SCHED_NORMAL 0
37#define SCHED_FIFO 1
38#define SCHED_RR 2
39#define SCHED_BATCH 3
40/* SCHED_ISO: reserved but not implemented yet */
41#define SCHED_IDLE 5
Dario Faggioliaab03e02013-11-28 11:14:43 +010042#define SCHED_DEADLINE 6
Peter Zijlstra7479f3c2014-01-15 17:05:04 +010043
David Howells607ca462012-10-13 10:46:48 +010044/* Can be ORed in to make sure the process is reverted back to SCHED_NORMAL on fork */
45#define SCHED_RESET_ON_FORK 0x40000000
46
Peter Zijlstra7479f3c2014-01-15 17:05:04 +010047/*
48 * For the sched_{set,get}attr() calls
49 */
50#define SCHED_FLAG_RESET_ON_FORK 0x01
David Howells607ca462012-10-13 10:46:48 +010051
52#endif /* _UAPI_LINUX_SCHED_H */