]> git.ipfire.org Git - thirdparty/systemd.git/blob - src/core/cgroup.h
Merge pull request #3258 from keszybz/small-networkd-cleanup
[thirdparty/systemd.git] / src / core / cgroup.h
1 #pragma once
2
3 /***
4 This file is part of systemd.
5
6 Copyright 2013 Lennart Poettering
7
8 systemd is free software; you can redistribute it and/or modify it
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
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
16 Lesser General Public License for more details.
17
18 You should have received a copy of the GNU Lesser General Public License
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
20 ***/
21
22 #include <stdbool.h>
23
24 #include "list.h"
25 #include "time-util.h"
26
27 typedef struct CGroupContext CGroupContext;
28 typedef struct CGroupDeviceAllow CGroupDeviceAllow;
29 typedef struct CGroupIODeviceWeight CGroupIODeviceWeight;
30 typedef struct CGroupIODeviceLimit CGroupIODeviceLimit;
31 typedef struct CGroupBlockIODeviceWeight CGroupBlockIODeviceWeight;
32 typedef struct CGroupBlockIODeviceBandwidth CGroupBlockIODeviceBandwidth;
33
34 typedef enum CGroupDevicePolicy {
35
36 /* When devices listed, will allow those, plus built-in ones,
37 if none are listed will allow everything. */
38 CGROUP_AUTO,
39
40 /* Everything forbidden, except built-in ones and listed ones. */
41 CGROUP_CLOSED,
42
43 /* Everythings forbidden, except for the listed devices */
44 CGROUP_STRICT,
45
46 _CGROUP_DEVICE_POLICY_MAX,
47 _CGROUP_DEVICE_POLICY_INVALID = -1
48 } CGroupDevicePolicy;
49
50 struct CGroupDeviceAllow {
51 LIST_FIELDS(CGroupDeviceAllow, device_allow);
52 char *path;
53 bool r:1;
54 bool w:1;
55 bool m:1;
56 };
57
58 struct CGroupIODeviceWeight {
59 LIST_FIELDS(CGroupIODeviceWeight, device_weights);
60 char *path;
61 uint64_t weight;
62 };
63
64 struct CGroupIODeviceLimit {
65 LIST_FIELDS(CGroupIODeviceLimit, device_limits);
66 char *path;
67 uint64_t rbps_max;
68 uint64_t wbps_max;
69 };
70
71 struct CGroupBlockIODeviceWeight {
72 LIST_FIELDS(CGroupBlockIODeviceWeight, device_weights);
73 char *path;
74 uint64_t weight;
75 };
76
77 struct CGroupBlockIODeviceBandwidth {
78 LIST_FIELDS(CGroupBlockIODeviceBandwidth, device_bandwidths);
79 char *path;
80 uint64_t bandwidth;
81 bool read;
82 };
83
84 struct CGroupContext {
85 bool cpu_accounting;
86 bool io_accounting;
87 bool blockio_accounting;
88 bool memory_accounting;
89 bool tasks_accounting;
90
91 /* For unified hierarchy */
92 uint64_t io_weight;
93 uint64_t startup_io_weight;
94 LIST_HEAD(CGroupIODeviceWeight, io_device_weights);
95 LIST_HEAD(CGroupIODeviceLimit, io_device_limits);
96
97 /* For legacy hierarchies */
98 uint64_t cpu_shares;
99 uint64_t startup_cpu_shares;
100 usec_t cpu_quota_per_sec_usec;
101
102 uint64_t blockio_weight;
103 uint64_t startup_blockio_weight;
104 LIST_HEAD(CGroupBlockIODeviceWeight, blockio_device_weights);
105 LIST_HEAD(CGroupBlockIODeviceBandwidth, blockio_device_bandwidths);
106
107 uint64_t memory_limit;
108
109 CGroupDevicePolicy device_policy;
110 LIST_HEAD(CGroupDeviceAllow, device_allow);
111
112 /* Common */
113 uint64_t tasks_max;
114
115 bool delegate;
116 };
117
118 #include "cgroup-util.h"
119 #include "unit.h"
120
121 void cgroup_context_init(CGroupContext *c);
122 void cgroup_context_done(CGroupContext *c);
123 void cgroup_context_dump(CGroupContext *c, FILE* f, const char *prefix);
124 void cgroup_context_apply(CGroupContext *c, CGroupMask mask, const char *path, ManagerState state);
125
126 CGroupMask cgroup_context_get_mask(CGroupContext *c);
127
128 void cgroup_context_free_device_allow(CGroupContext *c, CGroupDeviceAllow *a);
129 void cgroup_context_free_io_device_weight(CGroupContext *c, CGroupIODeviceWeight *w);
130 void cgroup_context_free_io_device_limit(CGroupContext *c, CGroupIODeviceLimit *l);
131 void cgroup_context_free_blockio_device_weight(CGroupContext *c, CGroupBlockIODeviceWeight *w);
132 void cgroup_context_free_blockio_device_bandwidth(CGroupContext *c, CGroupBlockIODeviceBandwidth *b);
133
134 CGroupMask unit_get_own_mask(Unit *u);
135 CGroupMask unit_get_siblings_mask(Unit *u);
136 CGroupMask unit_get_members_mask(Unit *u);
137 CGroupMask unit_get_subtree_mask(Unit *u);
138
139 CGroupMask unit_get_target_mask(Unit *u);
140 CGroupMask unit_get_enable_mask(Unit *u);
141
142 void unit_update_cgroup_members_masks(Unit *u);
143
144 char *unit_default_cgroup_path(Unit *u);
145 int unit_set_cgroup_path(Unit *u, const char *path);
146
147 int unit_realize_cgroup(Unit *u);
148 void unit_release_cgroup(Unit *u);
149 void unit_prune_cgroup(Unit *u);
150 int unit_watch_cgroup(Unit *u);
151
152 int unit_attach_pids_to_cgroup(Unit *u);
153
154 int manager_setup_cgroup(Manager *m);
155 void manager_shutdown_cgroup(Manager *m, bool delete);
156
157 unsigned manager_dispatch_cgroup_queue(Manager *m);
158
159 Unit *manager_get_unit_by_cgroup(Manager *m, const char *cgroup);
160 Unit *manager_get_unit_by_pid_cgroup(Manager *m, pid_t pid);
161 Unit* manager_get_unit_by_pid(Manager *m, pid_t pid);
162
163 int unit_search_main_pid(Unit *u, pid_t *ret);
164 int unit_watch_all_pids(Unit *u);
165
166 int unit_get_memory_current(Unit *u, uint64_t *ret);
167 int unit_get_tasks_current(Unit *u, uint64_t *ret);
168 int unit_get_cpu_usage(Unit *u, nsec_t *ret);
169 int unit_reset_cpu_usage(Unit *u);
170
171 bool unit_cgroup_delegate(Unit *u);
172
173 int unit_notify_cgroup_empty(Unit *u);
174 int manager_notify_cgroup_empty(Manager *m, const char *group);
175
176 void unit_invalidate_cgroup(Unit *u, CGroupMask m);
177
178 void manager_invalidate_startup_units(Manager *m);
179
180 const char* cgroup_device_policy_to_string(CGroupDevicePolicy i) _const_;
181 CGroupDevicePolicy cgroup_device_policy_from_string(const char *s) _pure_;