int
virCgroupGetCpuacctPercpuUsage(virCgroupPtr group, char **usage)
{
- return virCgroupGetValueStr(group, VIR_CGROUP_CONTROLLER_CPUACCT,
- "cpuacct.usage_percpu", usage);
+ VIR_CGROUP_BACKEND_CALL(group, getCpuacctPercpuUsage, -1, usage);
}
int
virCgroupGetCpuacctUsage(virCgroupPtr group, unsigned long long *usage)
{
- return virCgroupGetValueU64(group,
- VIR_CGROUP_CONTROLLER_CPUACCT,
- "cpuacct.usage", usage);
+ VIR_CGROUP_BACKEND_CALL(group, getCpuacctUsage, -1, usage);
}
typedef bool
(*virCgroupSupportsCpuBWCB)(virCgroupPtr cgroup);
+typedef int
+(*virCgroupGetCpuacctUsageCB)(virCgroupPtr group,
+ unsigned long long *usage);
+
+typedef int
+(*virCgroupGetCpuacctPercpuUsageCB)(virCgroupPtr group,
+ char **usage);
+
struct _virCgroupBackend {
virCgroupBackendType type;
virCgroupSetCpuCfsQuotaCB setCpuCfsQuota;
virCgroupGetCpuCfsQuotaCB getCpuCfsQuota;
virCgroupSupportsCpuBWCB supportsCpuBW;
+
+ virCgroupGetCpuacctUsageCB getCpuacctUsage;
+ virCgroupGetCpuacctPercpuUsageCB getCpuacctPercpuUsage;
};
typedef struct _virCgroupBackend virCgroupBackend;
typedef virCgroupBackend *virCgroupBackendPtr;
}
+static int
+virCgroupV1GetCpuacctUsage(virCgroupPtr group,
+ unsigned long long *usage)
+{
+ return virCgroupGetValueU64(group,
+ VIR_CGROUP_CONTROLLER_CPUACCT,
+ "cpuacct.usage", usage);
+}
+
+
+static int
+virCgroupV1GetCpuacctPercpuUsage(virCgroupPtr group,
+ char **usage)
+{
+ return virCgroupGetValueStr(group, VIR_CGROUP_CONTROLLER_CPUACCT,
+ "cpuacct.usage_percpu", usage);
+}
+
+
virCgroupBackend virCgroupV1Backend = {
.type = VIR_CGROUP_BACKEND_TYPE_V1,
.setCpuCfsQuota = virCgroupV1SetCpuCfsQuota,
.getCpuCfsQuota = virCgroupV1GetCpuCfsQuota,
.supportsCpuBW = virCgroupV1SupportsCpuBW,
+
+ .getCpuacctUsage = virCgroupV1GetCpuacctUsage,
+ .getCpuacctPercpuUsage = virCgroupV1GetCpuacctPercpuUsage,
};