X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fcore%2Fcgroup.h;fp=src%2Fcore%2Fcgroup.h;h=2a9e7034a8099bfa9ad6a2d68f01f9f17b52ec09;hp=4d9b52e1d1cbd1e296b3390ff693b7005620234c;hb=73ca6c4e5ef43b820dd6e643fe861b11cdb70a4c;hpb=a59143ddf77a64e2d13952606526dfb659b610b8 diff --git a/src/core/cgroup.h b/src/core/cgroup.h index 4d9b52e1d..2a9e7034a 100644 --- a/src/core/cgroup.h +++ b/src/core/cgroup.h @@ -22,12 +22,14 @@ #include //#include "list.h" -#include "logind.h" //#include "time-util.h" +#include "cgroup-util.h" #if 0 /// UNNEEDED by elogind typedef struct CGroupContext CGroupContext; typedef struct CGroupDeviceAllow CGroupDeviceAllow; +typedef struct CGroupIODeviceWeight CGroupIODeviceWeight; +typedef struct CGroupIODeviceLimit CGroupIODeviceLimit; typedef struct CGroupBlockIODeviceWeight CGroupBlockIODeviceWeight; typedef struct CGroupBlockIODeviceBandwidth CGroupBlockIODeviceBandwidth; @@ -55,6 +57,18 @@ struct CGroupDeviceAllow { bool m:1; }; +struct CGroupIODeviceWeight { + LIST_FIELDS(CGroupIODeviceWeight, device_weights); + char *path; + uint64_t weight; +}; + +struct CGroupIODeviceLimit { + LIST_FIELDS(CGroupIODeviceLimit, device_limits); + char *path; + uint64_t limits[_CGROUP_IO_LIMIT_TYPE_MAX]; +}; + struct CGroupBlockIODeviceWeight { LIST_FIELDS(CGroupBlockIODeviceWeight, device_weights); char *path; @@ -70,10 +84,18 @@ struct CGroupBlockIODeviceBandwidth { struct CGroupContext { bool cpu_accounting; + bool io_accounting; bool blockio_accounting; bool memory_accounting; bool tasks_accounting; + /* For unified hierarchy */ + uint64_t io_weight; + uint64_t startup_io_weight; + LIST_HEAD(CGroupIODeviceWeight, io_device_weights); + LIST_HEAD(CGroupIODeviceLimit, io_device_limits); + + /* For legacy hierarchies */ uint64_t cpu_shares; uint64_t startup_cpu_shares; usec_t cpu_quota_per_sec_usec; @@ -88,6 +110,7 @@ struct CGroupContext { CGroupDevicePolicy device_policy; LIST_HEAD(CGroupDeviceAllow, device_allow); + /* Common */ uint64_t tasks_max; bool delegate; @@ -104,6 +127,8 @@ void cgroup_context_apply(CGroupContext *c, CGroupMask mask, const char *path, M CGroupMask cgroup_context_get_mask(CGroupContext *c); void cgroup_context_free_device_allow(CGroupContext *c, CGroupDeviceAllow *a); +void cgroup_context_free_io_device_weight(CGroupContext *c, CGroupIODeviceWeight *w); +void cgroup_context_free_io_device_limit(CGroupContext *c, CGroupIODeviceLimit *l); void cgroup_context_free_blockio_device_weight(CGroupContext *c, CGroupBlockIODeviceWeight *w); void cgroup_context_free_blockio_device_bandwidth(CGroupContext *c, CGroupBlockIODeviceBandwidth *b); @@ -126,8 +151,11 @@ void unit_prune_cgroup(Unit *u); int unit_watch_cgroup(Unit *u); int unit_attach_pids_to_cgroup(Unit *u); - +#else +# include "logind.h" +# define MANAGER_IS_SYSTEM(m) (1) #endif // 0 + int manager_setup_cgroup(Manager *m); void manager_shutdown_cgroup(Manager *m, bool delete);