hc
2024-05-10 61598093bbdd283a7edc367d900f223070ead8d2
kernel/include/uapi/linux/sched.h
....@@ -2,6 +2,8 @@
22 #ifndef _UAPI_LINUX_SCHED_H
33 #define _UAPI_LINUX_SCHED_H
44
5
+#include <linux/types.h>
6
+
57 /*
68 * cloning flags:
79 */
....@@ -31,6 +33,81 @@
3133 #define CLONE_NEWNET 0x40000000 /* New network namespace */
3234 #define CLONE_IO 0x80000000 /* Clone io context */
3335
36
+/* Flags for the clone3() syscall. */
37
+#define CLONE_CLEAR_SIGHAND 0x100000000ULL /* Clear any signal handler and reset to SIG_DFL. */
38
+#define CLONE_INTO_CGROUP 0x200000000ULL /* Clone into a specific cgroup given the right permissions. */
39
+
40
+/*
41
+ * cloning flags intersect with CSIGNAL so can be used with unshare and clone3
42
+ * syscalls only:
43
+ */
44
+#define CLONE_NEWTIME 0x00000080 /* New time namespace */
45
+
46
+#ifndef __ASSEMBLY__
47
+/**
48
+ * struct clone_args - arguments for the clone3 syscall
49
+ * @flags: Flags for the new process as listed above.
50
+ * All flags are valid except for CSIGNAL and
51
+ * CLONE_DETACHED.
52
+ * @pidfd: If CLONE_PIDFD is set, a pidfd will be
53
+ * returned in this argument.
54
+ * @child_tid: If CLONE_CHILD_SETTID is set, the TID of the
55
+ * child process will be returned in the child's
56
+ * memory.
57
+ * @parent_tid: If CLONE_PARENT_SETTID is set, the TID of
58
+ * the child process will be returned in the
59
+ * parent's memory.
60
+ * @exit_signal: The exit_signal the parent process will be
61
+ * sent when the child exits.
62
+ * @stack: Specify the location of the stack for the
63
+ * child process.
64
+ * Note, @stack is expected to point to the
65
+ * lowest address. The stack direction will be
66
+ * determined by the kernel and set up
67
+ * appropriately based on @stack_size.
68
+ * @stack_size: The size of the stack for the child process.
69
+ * @tls: If CLONE_SETTLS is set, the tls descriptor
70
+ * is set to tls.
71
+ * @set_tid: Pointer to an array of type *pid_t. The size
72
+ * of the array is defined using @set_tid_size.
73
+ * This array is used to select PIDs/TIDs for
74
+ * newly created processes. The first element in
75
+ * this defines the PID in the most nested PID
76
+ * namespace. Each additional element in the array
77
+ * defines the PID in the parent PID namespace of
78
+ * the original PID namespace. If the array has
79
+ * less entries than the number of currently
80
+ * nested PID namespaces only the PIDs in the
81
+ * corresponding namespaces are set.
82
+ * @set_tid_size: This defines the size of the array referenced
83
+ * in @set_tid. This cannot be larger than the
84
+ * kernel's limit of nested PID namespaces.
85
+ * @cgroup: If CLONE_INTO_CGROUP is specified set this to
86
+ * a file descriptor for the cgroup.
87
+ *
88
+ * The structure is versioned by size and thus extensible.
89
+ * New struct members must go at the end of the struct and
90
+ * must be properly 64bit aligned.
91
+ */
92
+struct clone_args {
93
+ __aligned_u64 flags;
94
+ __aligned_u64 pidfd;
95
+ __aligned_u64 child_tid;
96
+ __aligned_u64 parent_tid;
97
+ __aligned_u64 exit_signal;
98
+ __aligned_u64 stack;
99
+ __aligned_u64 stack_size;
100
+ __aligned_u64 tls;
101
+ __aligned_u64 set_tid;
102
+ __aligned_u64 set_tid_size;
103
+ __aligned_u64 cgroup;
104
+};
105
+#endif
106
+
107
+#define CLONE_ARGS_SIZE_VER0 64 /* sizeof first published struct */
108
+#define CLONE_ARGS_SIZE_VER1 80 /* sizeof second published struct */
109
+#define CLONE_ARGS_SIZE_VER2 88 /* sizeof third published struct */
110
+
34111 /*
35112 * Scheduling policies
36113 */