]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/basic/cgroup-util.h
cgroup: change cg_unified() to possibly return errors again
[thirdparty/systemd.git] / src / basic / cgroup-util.h
CommitLineData
c2f1db8f 1#pragma once
8c6db833
LP
2
3/***
4 This file is part of systemd.
5
6 Copyright 2010 Lennart Poettering
7
8 systemd is free software; you can redistribute it and/or modify it
5430f7f2
LP
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
8c6db833
LP
11 (at your option) any later version.
12
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
5430f7f2 16 Lesser General Public License for more details.
8c6db833 17
5430f7f2 18 You should have received a copy of the GNU Lesser General Public License
8c6db833
LP
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
20***/
21
35d2e7ec 22#include <dirent.h>
11c3a366
TA
23#include <stdbool.h>
24#include <stdint.h>
71d35b6b 25#include <stdio.h>
f0bef277 26#include <sys/statfs.h>
71d35b6b 27#include <sys/types.h>
c6c18be3 28
f6a6225e 29#include "def.h"
11c3a366
TA
30#include "hashmap.h"
31#include "macro.h"
93cc7779 32#include "set.h"
8c6db833 33
efdb0237
LP
34/* An enum of well known cgroup controllers */
35typedef enum CGroupController {
36 CGROUP_CONTROLLER_CPU,
37 CGROUP_CONTROLLER_CPUACCT,
13c31542 38 CGROUP_CONTROLLER_IO,
efdb0237
LP
39 CGROUP_CONTROLLER_BLKIO,
40 CGROUP_CONTROLLER_MEMORY,
3905f127 41 CGROUP_CONTROLLER_DEVICES,
03a7b521 42 CGROUP_CONTROLLER_PIDS,
efdb0237
LP
43 _CGROUP_CONTROLLER_MAX,
44 _CGROUP_CONTROLLER_INVALID = -1,
45} CGroupController;
46
47#define CGROUP_CONTROLLER_TO_MASK(c) (1 << (c))
48
4ad49000 49/* A bit mask of well known cgroup controllers */
efdb0237
LP
50typedef enum CGroupMask {
51 CGROUP_MASK_CPU = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_CPU),
52 CGROUP_MASK_CPUACCT = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_CPUACCT),
13c31542 53 CGROUP_MASK_IO = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_IO),
efdb0237
LP
54 CGROUP_MASK_BLKIO = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_BLKIO),
55 CGROUP_MASK_MEMORY = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_MEMORY),
3905f127 56 CGROUP_MASK_DEVICES = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_DEVICES),
03a7b521 57 CGROUP_MASK_PIDS = CGROUP_CONTROLLER_TO_MASK(CGROUP_CONTROLLER_PIDS),
efdb0237
LP
58 _CGROUP_MASK_ALL = CGROUP_CONTROLLER_TO_MASK(_CGROUP_CONTROLLER_MAX) - 1
59} CGroupMask;
4ad49000 60
13c31542
TH
61/* Special values for all weight knobs on unified hierarchy */
62#define CGROUP_WEIGHT_INVALID ((uint64_t) -1)
63#define CGROUP_WEIGHT_MIN UINT64_C(1)
64#define CGROUP_WEIGHT_MAX UINT64_C(10000)
65#define CGROUP_WEIGHT_DEFAULT UINT64_C(100)
66
67#define CGROUP_LIMIT_MIN UINT64_C(0)
68#define CGROUP_LIMIT_MAX ((uint64_t) -1)
69
70static inline bool CGROUP_WEIGHT_IS_OK(uint64_t x) {
71 return
72 x == CGROUP_WEIGHT_INVALID ||
73 (x >= CGROUP_WEIGHT_MIN && x <= CGROUP_WEIGHT_MAX);
74}
75
9be57249
TH
76/* IO limits on unified hierarchy */
77typedef enum CGroupIOLimitType {
78 CGROUP_IO_RBPS_MAX,
79 CGROUP_IO_WBPS_MAX,
ac06a0cf
TH
80 CGROUP_IO_RIOPS_MAX,
81 CGROUP_IO_WIOPS_MAX,
9be57249
TH
82
83 _CGROUP_IO_LIMIT_TYPE_MAX,
84 _CGROUP_IO_LIMIT_TYPE_INVALID = -1
85} CGroupIOLimitType;
86
87extern const uint64_t cgroup_io_limit_defaults[_CGROUP_IO_LIMIT_TYPE_MAX];
88
89const char* cgroup_io_limit_type_to_string(CGroupIOLimitType t) _const_;
90CGroupIOLimitType cgroup_io_limit_type_from_string(const char *s) _pure_;
91
d53d9474
LP
92/* Special values for the cpu.shares attribute */
93#define CGROUP_CPU_SHARES_INVALID ((uint64_t) -1)
94#define CGROUP_CPU_SHARES_MIN UINT64_C(2)
95#define CGROUP_CPU_SHARES_MAX UINT64_C(262144)
96#define CGROUP_CPU_SHARES_DEFAULT UINT64_C(1024)
97
98static inline bool CGROUP_CPU_SHARES_IS_OK(uint64_t x) {
99 return
100 x == CGROUP_CPU_SHARES_INVALID ||
101 (x >= CGROUP_CPU_SHARES_MIN && x <= CGROUP_CPU_SHARES_MAX);
102}
103
104/* Special values for the blkio.weight attribute */
105#define CGROUP_BLKIO_WEIGHT_INVALID ((uint64_t) -1)
106#define CGROUP_BLKIO_WEIGHT_MIN UINT64_C(10)
107#define CGROUP_BLKIO_WEIGHT_MAX UINT64_C(1000)
108#define CGROUP_BLKIO_WEIGHT_DEFAULT UINT64_C(500)
109
110static inline bool CGROUP_BLKIO_WEIGHT_IS_OK(uint64_t x) {
111 return
112 x == CGROUP_BLKIO_WEIGHT_INVALID ||
113 (x >= CGROUP_BLKIO_WEIGHT_MIN && x <= CGROUP_BLKIO_WEIGHT_MAX);
114}
115
f5058264
TH
116/* Default resource limits */
117#define DEFAULT_TASKS_MAX_PERCENTAGE 15U /* 15% of PIDs, 4915 on default settings */
118#define DEFAULT_USER_TASKS_MAX_PERCENTAGE 33U /* 33% of PIDs, 10813 on default settings */
119
5da38d07
TH
120typedef enum CGroupUnified {
121 CGROUP_UNIFIED_UNKNOWN = -1,
122 CGROUP_UNIFIED_NONE = 0, /* Both systemd and controllers on legacy */
123 CGROUP_UNIFIED_SYSTEMD = 1, /* Only systemd on unified */
124 CGROUP_UNIFIED_ALL = 2, /* Both systemd and controllers on unified */
125} CGroupUnified;
126
5954c074
LP
127/*
128 * General rules:
129 *
130 * We accept named hierarchies in the syntax "foo" and "name=foo".
131 *
132 * We expect that named hierarchies do not conflict in name with a
133 * kernel hierarchy, modulo the "name=" prefix.
134 *
135 * We always generate "normalized" controller names, i.e. without the
136 * "name=" prefix.
137 *
138 * We require absolute cgroup paths. When returning, we will always
139 * generate paths with multiple adjacent / removed.
140 */
141
c6c18be3 142int cg_enumerate_processes(const char *controller, const char *path, FILE **_f);
c6c18be3 143int cg_read_pid(FILE *f, pid_t *_pid);
ab2c3861
TH
144int cg_read_event(const char *controller, const char *path, const char *event,
145 char **val);
c6c18be3 146
35d2e7ec
LP
147int cg_enumerate_subgroups(const char *controller, const char *path, DIR **_d);
148int cg_read_subgroup(DIR *d, char **fn);
149
1d98fef1
LP
150typedef enum CGroupFlags {
151 CGROUP_SIGCONT = 1,
152 CGROUP_IGNORE_SELF = 2,
153 CGROUP_REMOVE = 4,
154} CGroupFlags;
8c6db833 155
1d98fef1
LP
156typedef void (*cg_kill_log_func_t)(pid_t pid, int sig, void *userdata);
157
158int cg_kill(const char *controller, const char *path, int sig, CGroupFlags flags, Set *s, cg_kill_log_func_t kill_log, void *userdata);
159int cg_kill_recursive(const char *controller, const char *path, int sig, CGroupFlags flags, Set *s, cg_kill_log_func_t kill_log, void *userdata);
160
161int cg_migrate(const char *cfrom, const char *pfrom, const char *cto, const char *pto, CGroupFlags flags);
162int cg_migrate_recursive(const char *cfrom, const char *pfrom, const char *cto, const char *pto, CGroupFlags flags);
163int cg_migrate_recursive_fallback(const char *cfrom, const char *pfrom, const char *cto, const char *pto, CGroupFlags flags);
35d2e7ec
LP
164
165int cg_split_spec(const char *spec, char **controller, char **path);
7027ff61 166int cg_mangle_path(const char *path, char **result);
8c6db833
LP
167
168int cg_get_path(const char *controller, const char *path, const char *suffix, char **fs);
3474ae3c 169int cg_get_path_and_check(const char *controller, const char *path, const char *suffix, char **fs);
7027ff61
LP
170
171int cg_pid_get_path(const char *controller, pid_t pid, char **path);
8c6db833
LP
172
173int cg_trim(const char *controller, const char *path, bool delete_root);
35d2e7ec 174
4ad49000 175int cg_rmdir(const char *controller, const char *path);
8c6db833 176
4ad49000 177int cg_create(const char *controller, const char *path);
8c6db833 178int cg_attach(const char *controller, const char *path, pid_t pid);
13b84ec7 179int cg_attach_fallback(const char *controller, const char *path, pid_t pid);
8c6db833
LP
180int cg_create_and_attach(const char *controller, const char *path, pid_t pid);
181
4ad49000 182int cg_set_attribute(const char *controller, const char *path, const char *attribute, const char *value);
934277fe 183int cg_get_attribute(const char *controller, const char *path, const char *attribute, char **ret);
66ebf6c0 184int cg_get_keyed_attribute(const char *controller, const char *path, const char *attribute, const char **keys, char **values);
4ad49000 185
8c6db833 186int cg_set_group_access(const char *controller, const char *path, mode_t mode, uid_t uid, gid_t gid);
4ad49000 187int cg_set_task_access(const char *controller, const char *path, mode_t mode, uid_t uid, gid_t gid);
8c6db833 188
4b58153d
LP
189int cg_set_xattr(const char *controller, const char *path, const char *name, const void *value, size_t size, int flags);
190int cg_get_xattr(const char *controller, const char *path, const char *name, void *value, size_t size);
191
8c6db833 192int cg_install_release_agent(const char *controller, const char *agent);
ad929bcc 193int cg_uninstall_release_agent(const char *controller);
8c6db833 194
6f883237
LP
195int cg_is_empty(const char *controller, const char *path);
196int cg_is_empty_recursive(const char *controller, const char *path);
8c6db833 197
7027ff61 198int cg_get_root_path(char **path);
6c03089c 199
7027ff61 200int cg_path_get_session(const char *path, char **session);
ae018d9b 201int cg_path_get_owner_uid(const char *path, uid_t *uid);
6c03089c
LP
202int cg_path_get_unit(const char *path, char **unit);
203int cg_path_get_user_unit(const char *path, char **unit);
7027ff61 204int cg_path_get_machine_name(const char *path, char **machine);
1021b21b 205int cg_path_get_slice(const char *path, char **slice);
329ac4bc 206int cg_path_get_user_slice(const char *path, char **slice);
7027ff61 207
751bc6ac 208int cg_shift_path(const char *cgroup, const char *cached_root, const char **shifted);
e9174f29 209int cg_pid_get_path_shifted(pid_t pid, const char *cached_root, char **cgroup);
6c03089c 210
7027ff61 211int cg_pid_get_session(pid_t pid, char **session);
ae018d9b 212int cg_pid_get_owner_uid(pid_t pid, uid_t *uid);
ba1261bc 213int cg_pid_get_unit(pid_t pid, char **unit);
ef1673d1 214int cg_pid_get_user_unit(pid_t pid, char **unit);
7027ff61 215int cg_pid_get_machine_name(pid_t pid, char **machine);
1021b21b 216int cg_pid_get_slice(pid_t pid, char **slice);
329ac4bc 217int cg_pid_get_user_slice(pid_t pid, char **slice);
1f73f0f1 218
7027ff61 219int cg_path_decode_unit(const char *cgroup, char **unit);
96cde13a 220
ae018d9b 221char *cg_escape(const char *p);
44a6b1b6 222char *cg_unescape(const char *p) _pure_;
78edb35a 223
185a0874 224bool cg_controller_is_valid(const char *p);
a016b922
LP
225
226int cg_slice_to_path(const char *unit, char **ret);
4ad49000 227
efdb0237 228typedef const char* (*cg_migrate_callback_t)(CGroupMask mask, void *userdata);
03b90d4b 229
efdb0237
LP
230int cg_create_everywhere(CGroupMask supported, CGroupMask mask, const char *path);
231int cg_attach_everywhere(CGroupMask supported, const char *path, pid_t pid, cg_migrate_callback_t callback, void *userdata);
232int cg_attach_many_everywhere(CGroupMask supported, const char *path, Set* pids, cg_migrate_callback_t callback, void *userdata);
233int cg_migrate_everywhere(CGroupMask supported, const char *from, const char *to, cg_migrate_callback_t callback, void *userdata);
234int cg_trim_everywhere(CGroupMask supported, const char *path, bool delete_root);
235int cg_enable_everywhere(CGroupMask supported, CGroupMask mask, const char *p);
4ad49000 236
efdb0237 237int cg_mask_supported(CGroupMask *ret);
b12afc8c
LP
238
239int cg_kernel_controllers(Set *controllers);
efdb0237 240
3228995c
CB
241bool cg_ns_supported(void);
242
b4cccbc1
LP
243int cg_all_unified(void);
244int cg_hybrid_unified(void);
245int cg_unified(const char *controller);
415fc41c 246int cg_unified_flush(void);
efdb0237
LP
247
248bool cg_is_unified_wanted(void);
249bool cg_is_legacy_wanted(void);
a4464b95 250bool cg_is_hybrid_wanted(void);
efdb0237
LP
251
252const char* cgroup_controller_to_string(CGroupController c) _const_;
253CGroupController cgroup_controller_from_string(const char *s) _pure_;
d53d9474 254
13c31542 255int cg_weight_parse(const char *s, uint64_t *ret);
d53d9474
LP
256int cg_cpu_shares_parse(const char *s, uint64_t *ret);
257int cg_blkio_weight_parse(const char *s, uint64_t *ret);
f0bef277
EV
258
259bool is_cgroup_fs(const struct statfs *s);
260bool fd_is_cgroup_fs(int fd);