397dc2
From 92b7a56b1a23d1cf39e810a58a6d7d0b1f500e69 Mon Sep 17 00:00:00 2001
397dc2
Message-Id: <92b7a56b1a23d1cf39e810a58a6d7d0b1f500e69@dist-git>
397dc2
From: Pavel Hrdina <phrdina@redhat.com>
397dc2
Date: Thu, 21 Jan 2021 10:24:06 -0300
397dc2
Subject: [PATCH] vircgroup: fix cpu quota maximum limit
397dc2
397dc2
Kernel commit <d505b8af58912ae1e1a211fabc9995b19bd40828> added proper
397dc2
check for cpu quota maximum limit to prevent internal overflow.
397dc2
397dc2
Even though this change is not present in all kernels it makes sense
397dc2
to enforce the same limit in libvirt.
397dc2
397dc2
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=1750315
397dc2
397dc2
Signed-off-by: Pavel Hrdina <phrdina@redhat.com>
397dc2
Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
397dc2
(cherry picked from commit ed1ba69f5a8132f8c1e73d2a1f142d70de0b564a)
397dc2
397dc2
https://bugzilla.redhat.com/1915733
397dc2
397dc2
Signed-off-by: Daniel Henrique Barboza <dbarboza@redhat.com>
397dc2
Message-Id: <20210121132406.337681-5-dbarboza@redhat.com>
397dc2
Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
397dc2
---
397dc2
 src/util/vircgroup.h | 4 +++-
397dc2
 1 file changed, 3 insertions(+), 1 deletion(-)
397dc2
397dc2
diff --git a/src/util/vircgroup.h b/src/util/vircgroup.h
397dc2
index 83fa74840f..1c6edea0be 100644
397dc2
--- a/src/util/vircgroup.h
397dc2
+++ b/src/util/vircgroup.h
397dc2
@@ -246,7 +246,9 @@ int virCgroupGetCpuShares(virCgroupPtr group, unsigned long long *shares);
397dc2
 #define VIR_CGROUP_CPU_PERIOD_MIN 1000LL
397dc2
 #define VIR_CGROUP_CPU_PERIOD_MAX 1000000LL
397dc2
 #define VIR_CGROUP_CPU_QUOTA_MIN 1000LL
397dc2
-#define VIR_CGROUP_CPU_QUOTA_MAX 18446744073709551LL
397dc2
+/* Based on kernel code ((1ULL << MAX_BW_BITS) - 1) where MAX_BW_BITS is
397dc2
+ * (64 - BW_SHIFT) and BW_SHIFT is 20 */
397dc2
+#define VIR_CGROUP_CPU_QUOTA_MAX 17592186044415LL
397dc2
 
397dc2
 int virCgroupSetCpuCfsPeriod(virCgroupPtr group, unsigned long long cfs_period);
397dc2
 int virCgroupGetCpuCfsPeriod(virCgroupPtr group, unsigned long long *cfs_period);
397dc2
-- 
397dc2
2.30.0
397dc2