2008-10-03 17:58:02 +00:00
|
|
|
/*
|
2012-12-03 15:03:47 +00:00
|
|
|
* vircgroup.h: methods for managing control cgroups
|
2008-10-03 17:58:02 +00:00
|
|
|
*
|
2015-03-11 11:15:29 +01:00
|
|
|
* Copyright (C) 2011-2015 Red Hat, Inc.
|
2008-10-03 17:58:02 +00:00
|
|
|
* Copyright IBM Corp. 2008
|
|
|
|
*
|
2012-07-27 17:39:53 +08:00
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-27 17:39:53 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
2008-10-03 17:58:02 +00:00
|
|
|
*/
|
|
|
|
|
2019-06-18 11:12:54 -05:00
|
|
|
#pragma once
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2019-06-18 11:12:54 -05:00
|
|
|
#include "virbitmap.h"
|
|
|
|
#include "virenum.h"
|
2013-01-16 10:53:04 +08:00
|
|
|
|
2018-06-12 13:46:04 +02:00
|
|
|
struct _virCgroup;
|
2018-06-12 13:47:10 +02:00
|
|
|
typedef struct _virCgroup virCgroup;
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2009-07-22 16:08:04 +01:00
|
|
|
enum {
|
|
|
|
VIR_CGROUP_CONTROLLER_CPU,
|
|
|
|
VIR_CGROUP_CONTROLLER_CPUACCT,
|
|
|
|
VIR_CGROUP_CONTROLLER_CPUSET,
|
|
|
|
VIR_CGROUP_CONTROLLER_MEMORY,
|
|
|
|
VIR_CGROUP_CONTROLLER_DEVICES,
|
2009-09-21 23:31:22 +09:00
|
|
|
VIR_CGROUP_CONTROLLER_FREEZER,
|
2011-02-08 10:41:17 -07:00
|
|
|
VIR_CGROUP_CONTROLLER_BLKIO,
|
2013-04-15 15:17:33 +01:00
|
|
|
VIR_CGROUP_CONTROLLER_NET_CLS,
|
|
|
|
VIR_CGROUP_CONTROLLER_PERF_EVENT,
|
2013-07-25 19:13:44 +01:00
|
|
|
VIR_CGROUP_CONTROLLER_SYSTEMD,
|
2009-07-22 16:08:04 +01:00
|
|
|
|
|
|
|
VIR_CGROUP_CONTROLLER_LAST
|
|
|
|
};
|
|
|
|
|
|
|
|
VIR_ENUM_DECL(virCgroupController);
|
2015-03-27 13:45:33 +01:00
|
|
|
/* Items of this enum are used later in virCgroupNew to create
|
|
|
|
* bit array stored in int. Like this:
|
|
|
|
* 1 << VIR_CGROUP_CONTROLLER_CPU
|
|
|
|
* Make sure we will not overflow */
|
2020-01-09 10:39:55 +00:00
|
|
|
G_STATIC_ASSERT(VIR_CGROUP_CONTROLLER_LAST < 8 * sizeof(int));
|
2009-07-22 16:08:04 +01:00
|
|
|
|
2015-04-07 08:28:05 -04:00
|
|
|
typedef enum {
|
|
|
|
VIR_CGROUP_THREAD_VCPU = 0,
|
|
|
|
VIR_CGROUP_THREAD_EMULATOR,
|
|
|
|
VIR_CGROUP_THREAD_IOTHREAD,
|
|
|
|
|
|
|
|
VIR_CGROUP_THREAD_LAST
|
|
|
|
} virCgroupThreadName;
|
|
|
|
|
2013-07-04 16:49:24 +01:00
|
|
|
bool virCgroupAvailable(void);
|
|
|
|
|
2020-11-18 13:08:22 +01:00
|
|
|
int virCgroupNew(const char *path,
|
|
|
|
int controllers,
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroup **group);
|
2020-11-18 13:08:22 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupNewSelf(virCgroup **group)
|
2013-03-28 16:33:22 +00:00
|
|
|
ATTRIBUTE_NONNULL(1);
|
2012-11-12 15:02:26 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupNewThread(virCgroup *domain,
|
2015-04-07 08:28:05 -04:00
|
|
|
virCgroupThreadName nameval,
|
|
|
|
int id,
|
|
|
|
bool create,
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroup **group)
|
2015-04-07 08:28:05 -04:00
|
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(5);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupDelThread(virCgroup *cgroup,
|
2016-08-04 23:36:38 +02:00
|
|
|
virCgroupThreadName nameval,
|
|
|
|
int idx);
|
|
|
|
|
2013-07-19 11:13:05 +01:00
|
|
|
int virCgroupNewDetect(pid_t pid,
|
2013-07-24 17:31:25 +01:00
|
|
|
int controllers,
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroup **group);
|
2013-07-19 11:13:05 +01:00
|
|
|
|
2017-07-21 15:51:03 +02:00
|
|
|
int
|
|
|
|
virCgroupNewDetectMachine(const char *name,
|
|
|
|
const char *drivername,
|
|
|
|
pid_t pid,
|
|
|
|
int controllers,
|
|
|
|
char *machinename,
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroup **group)
|
2016-02-01 16:50:54 +01:00
|
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2);
|
2013-07-24 17:36:42 +01:00
|
|
|
|
2013-07-18 16:55:37 +01:00
|
|
|
int virCgroupNewMachine(const char *name,
|
|
|
|
const char *drivername,
|
|
|
|
const unsigned char *uuid,
|
|
|
|
const char *rootdir,
|
|
|
|
pid_t pidleader,
|
|
|
|
bool isContainer,
|
2014-11-11 17:38:43 +00:00
|
|
|
size_t nnicindexes,
|
|
|
|
int *nicindexes,
|
2013-07-18 16:55:37 +01:00
|
|
|
const char *partition,
|
|
|
|
int controllers,
|
2019-05-22 17:12:14 -06:00
|
|
|
unsigned int maxthreads,
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroup **group)
|
2013-07-18 16:55:37 +01:00
|
|
|
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2)
|
2016-02-06 06:45:46 -05:00
|
|
|
ATTRIBUTE_NONNULL(3);
|
2013-07-18 16:55:37 +01:00
|
|
|
|
2016-02-01 16:50:54 +01:00
|
|
|
int virCgroupTerminateMachine(const char *name)
|
|
|
|
ATTRIBUTE_NONNULL(1);
|
2014-09-25 13:32:58 +02:00
|
|
|
|
2013-07-04 16:49:24 +01:00
|
|
|
bool virCgroupNewIgnoreError(void);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
void virCgroupFree(virCgroup *group);
|
2013-08-12 15:20:59 -06:00
|
|
|
|
2020-09-22 11:33:19 +02:00
|
|
|
G_DEFINE_AUTOPTR_CLEANUP_FUNC(virCgroup, virCgroupFree);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
bool virCgroupHasController(virCgroup *cgroup, int controller);
|
|
|
|
int virCgroupPathOfController(virCgroup *group,
|
2018-08-15 17:21:47 +02:00
|
|
|
unsigned int controller,
|
2011-03-07 16:41:40 -07:00
|
|
|
const char *key,
|
|
|
|
char **path);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupAddProcess(virCgroup *group, pid_t pid);
|
|
|
|
int virCgroupAddMachineProcess(virCgroup *group, pid_t pid);
|
|
|
|
int virCgroupAddThread(virCgroup *group, pid_t pid);
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetBlkioWeight(virCgroup *group, unsigned int weight);
|
|
|
|
int virCgroupGetBlkioWeight(virCgroup *group, unsigned int *weight);
|
2011-02-08 14:56:39 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupGetBlkioIoServiced(virCgroup *group,
|
2014-02-14 18:48:59 +01:00
|
|
|
long long *bytes_read,
|
|
|
|
long long *bytes_write,
|
|
|
|
long long *requests_read,
|
|
|
|
long long *requests_write);
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupGetBlkioIoDeviceServiced(virCgroup *group,
|
2014-02-14 18:48:59 +01:00
|
|
|
const char *path,
|
|
|
|
long long *bytes_read,
|
|
|
|
long long *bytes_write,
|
|
|
|
long long *requests_read,
|
|
|
|
long long *requests_write);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupBlkioDeviceWeight(virCgroup *cgroup,
|
2020-02-17 16:29:08 -05:00
|
|
|
const char *path,
|
|
|
|
unsigned int *weight);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupBlkioDeviceReadIops(virCgroup *cgroup,
|
2020-02-17 16:29:08 -05:00
|
|
|
const char *path,
|
|
|
|
unsigned int *riops);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupBlkioDeviceWriteIops(virCgroup *cgroup,
|
2020-02-17 16:29:08 -05:00
|
|
|
const char *path,
|
|
|
|
unsigned int *wiops);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupBlkioDeviceReadBps(virCgroup *cgroup,
|
2020-02-17 16:29:08 -05:00
|
|
|
const char *path,
|
|
|
|
unsigned long long *rbps);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupBlkioDeviceWriteBps(virCgroup *cgroup,
|
2020-02-17 16:29:08 -05:00
|
|
|
const char *path,
|
|
|
|
unsigned long long *wbps);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetMemory(virCgroup *group, unsigned long long kb);
|
|
|
|
int virCgroupGetMemoryStat(virCgroup *group,
|
2018-07-20 14:47:11 +02:00
|
|
|
unsigned long long *cache,
|
|
|
|
unsigned long long *activeAnon,
|
|
|
|
unsigned long long *inactiveAnon,
|
|
|
|
unsigned long long *activeFile,
|
|
|
|
unsigned long long *inactiveFile,
|
|
|
|
unsigned long long *unevictable);
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupGetMemoryUsage(virCgroup *group, unsigned long *kb);
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetMemoryHardLimit(virCgroup *group, unsigned long long kb);
|
|
|
|
int virCgroupGetMemoryHardLimit(virCgroup *group, unsigned long long *kb);
|
|
|
|
int virCgroupSetMemorySoftLimit(virCgroup *group, unsigned long long kb);
|
|
|
|
int virCgroupGetMemorySoftLimit(virCgroup *group, unsigned long long *kb);
|
|
|
|
int virCgroupSetMemSwapHardLimit(virCgroup *group, unsigned long long kb);
|
|
|
|
int virCgroupGetMemSwapHardLimit(virCgroup *group, unsigned long long *kb);
|
|
|
|
int virCgroupGetMemSwapUsage(virCgroup *group, unsigned long long *kb);
|
2010-10-12 16:50:53 +02:00
|
|
|
|
2011-03-08 20:13:18 -07:00
|
|
|
enum {
|
|
|
|
VIR_CGROUP_DEVICE_READ = 1,
|
|
|
|
VIR_CGROUP_DEVICE_WRITE = 2,
|
|
|
|
VIR_CGROUP_DEVICE_MKNOD = 4,
|
|
|
|
VIR_CGROUP_DEVICE_RW = VIR_CGROUP_DEVICE_READ | VIR_CGROUP_DEVICE_WRITE,
|
|
|
|
VIR_CGROUP_DEVICE_RWM = VIR_CGROUP_DEVICE_RW | VIR_CGROUP_DEVICE_MKNOD,
|
|
|
|
};
|
|
|
|
|
2014-06-20 13:33:16 +02:00
|
|
|
const char *virCgroupGetDevicePermsString(int perms);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupDenyAllDevices(virCgroup *group);
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupAllowAllDevices(virCgroup *group, int perms);
|
2014-07-18 10:02:29 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupAllowDevice(virCgroup *group,
|
2008-10-03 17:58:02 +00:00
|
|
|
char type,
|
|
|
|
int major,
|
2011-03-08 20:13:18 -07:00
|
|
|
int minor,
|
|
|
|
int perms);
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupAllowDevicePath(virCgroup *group,
|
2011-03-08 20:13:18 -07:00
|
|
|
const char *path,
|
2016-02-16 14:43:41 +01:00
|
|
|
int perms,
|
|
|
|
bool ignoreEacces);
|
2009-07-09 14:11:49 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupDenyDevice(virCgroup *group,
|
2009-07-09 14:11:49 +01:00
|
|
|
char type,
|
|
|
|
int major,
|
2011-03-08 20:13:18 -07:00
|
|
|
int minor,
|
|
|
|
int perms);
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupDenyDevicePath(virCgroup *group,
|
2011-03-08 20:13:18 -07:00
|
|
|
const char *path,
|
2016-02-16 14:43:41 +01:00
|
|
|
int perms,
|
|
|
|
bool ignoreEacces);
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2014-02-14 18:49:02 +01:00
|
|
|
int
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroupGetPercpuStats(virCgroup *group,
|
2014-02-14 18:49:02 +01:00
|
|
|
virTypedParameterPtr params,
|
|
|
|
unsigned int nparams,
|
|
|
|
int start_cpu,
|
2014-04-03 17:53:43 +02:00
|
|
|
unsigned int ncpus,
|
2021-03-11 08:16:13 +01:00
|
|
|
virBitmap *guestvcpus);
|
2014-02-14 18:49:02 +01:00
|
|
|
|
2014-02-14 18:49:01 +01:00
|
|
|
int
|
2021-03-11 08:16:13 +01:00
|
|
|
virCgroupGetDomainTotalCpuStats(virCgroup *group,
|
2014-02-14 18:49:01 +01:00
|
|
|
virTypedParameterPtr params,
|
|
|
|
int nparams);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpuShares(virCgroup *group, unsigned long long shares);
|
|
|
|
int virCgroupGetCpuShares(virCgroup *group, unsigned long long *shares);
|
2008-10-08 16:28:48 +00:00
|
|
|
|
2021-03-03 14:10:15 +01:00
|
|
|
#define VIR_CGROUP_CPU_SHARES_MIN 2LL
|
|
|
|
#define VIR_CGROUP_CPU_SHARES_MAX 262144LL
|
2020-11-25 11:47:02 +01:00
|
|
|
#define VIR_CGROUP_CPU_PERIOD_MIN 1000LL
|
|
|
|
#define VIR_CGROUP_CPU_PERIOD_MAX 1000000LL
|
|
|
|
#define VIR_CGROUP_CPU_QUOTA_MIN 1000LL
|
2020-11-25 12:41:16 +01:00
|
|
|
/* Based on kernel code ((1ULL << MAX_BW_BITS) - 1) where MAX_BW_BITS is
|
|
|
|
* (64 - BW_SHIFT) and BW_SHIFT is 20 */
|
|
|
|
#define VIR_CGROUP_CPU_QUOTA_MAX 17592186044415LL
|
2020-11-25 11:47:02 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpuCfsPeriod(virCgroup *group, unsigned long long cfs_period);
|
|
|
|
int virCgroupGetCpuCfsPeriod(virCgroup *group, unsigned long long *cfs_period);
|
|
|
|
int virCgroupGetCpuPeriodQuota(virCgroup *cgroup, unsigned long long *period,
|
2020-02-17 16:29:21 -05:00
|
|
|
long long *quota);
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetupCpuPeriodQuota(virCgroup *cgroup, unsigned long long period,
|
2020-02-17 16:29:15 -05:00
|
|
|
long long quota);
|
2011-07-21 15:21:05 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpuCfsQuota(virCgroup *group, long long cfs_quota);
|
|
|
|
int virCgroupGetCpuCfsQuota(virCgroup *group, long long *cfs_quota);
|
2011-07-21 15:21:05 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupGetCpuacctUsage(virCgroup *group, unsigned long long *usage);
|
|
|
|
int virCgroupGetCpuacctPercpuUsage(virCgroup *group, char **usage);
|
|
|
|
int virCgroupGetCpuacctStat(virCgroup *group, unsigned long long *user,
|
2012-03-08 17:35:59 -07:00
|
|
|
unsigned long long *sys);
|
2009-03-06 14:44:04 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetFreezerState(virCgroup *group, const char *state);
|
|
|
|
int virCgroupGetFreezerState(virCgroup *group, char **state);
|
2009-09-21 23:31:22 +09:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpusetMems(virCgroup *group, const char *mems);
|
|
|
|
int virCgroupGetCpusetMems(virCgroup *group, char **mems);
|
2011-12-20 16:34:58 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpusetMemoryMigrate(virCgroup *group, bool migrate);
|
|
|
|
int virCgroupGetCpusetMemoryMigrate(virCgroup *group, bool *migrate);
|
2015-03-11 11:15:29 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetCpusetCpus(virCgroup *group, const char *cpus);
|
|
|
|
int virCgroupGetCpusetCpus(virCgroup *group, char **cpus);
|
|
|
|
int virCgroupSetupCpusetCpus(virCgroup *cgroup, virBitmap *cpumask);
|
2012-08-21 17:18:30 +08:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupRemove(virCgroup *group);
|
2008-10-03 17:58:02 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupKillRecursive(virCgroup *group, int signum);
|
|
|
|
int virCgroupKillPainfully(virCgroup *group);
|
2011-02-22 17:33:59 +00:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupBindMount(virCgroup *group,
|
2016-01-22 16:07:18 +00:00
|
|
|
const char *oldroot,
|
|
|
|
const char *mountopts);
|
2013-04-05 12:48:47 +01:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
bool virCgroupSupportsCpuBW(virCgroup *cgroup);
|
2013-09-13 16:03:14 +02:00
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupSetOwner(virCgroup *cgroup,
|
2014-02-24 12:23:33 +00:00
|
|
|
uid_t uid,
|
|
|
|
gid_t gid,
|
|
|
|
int controllers);
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
int virCgroupHasEmptyTasks(virCgroup *cgroup, int controller);
|
2014-12-13 09:56:00 +01:00
|
|
|
|
2015-03-31 11:39:13 +02:00
|
|
|
bool virCgroupControllerAvailable(int controller);
|