[Devel] [PATCH vz10 01/14] sched: fix VZ build errors with CONFIG_CGROUP_SCHED=n
Eva Kurchatova
eva.kurchatova at virtuozzo.com
Fri Jun 26 01:08:03 MSK 2026
Guard VZ-specific code that depends on struct task_group,
root_task_group, cpu_cgrp_id and cpuacct_cgrp_id with the appropriate
Kconfig options.
Without CONFIG_CGROUP_SCHED:
- struct task_group is incomplete, so get_avenrun_tg() and
calc_load_ve() fail to compile.
- cpu_cgrp_id is undeclared, so the link_ve_root_cpu_cgroup() call in
cgroup_mark_ve_roots() does not build.
Without CONFIG_CGROUP_CPUACCT:
- cpuacct_cgrp_id is undeclared, so the cpu_cgrp_subsys.depends_on
initializer fails.
- cpu_cgroup_update_vcpustat() uses MAX_CPU_RATE which requires
CONFIG_CFS_CPULIMIT.
Add a static inline stub for get_avenrun_tg() when CONFIG_CGROUP_SCHED
is disabled, tighten the guards on calc_load_ve() to require both
CONFIG_VE and CONFIG_CGROUP_SCHED, and wrap cpu_cgroup_update_vcpustat()
with CONFIG_CFS_CPULIMIT.
Signed-off-by: Eva Kurchatova <eva.kurchatova at virtuozzo.com>
https://virtuozzo.atlassian.net/browse/VSTOR-134732
Feature: fix kunit
---
include/linux/sched/loadavg.h | 10 +++++++++-
kernel/sched/core.c | 2 ++
kernel/sched/cpuacct.c | 5 +++++
kernel/sched/loadavg.c | 6 ++++--
4 files changed, 20 insertions(+), 3 deletions(-)
diff --git a/include/linux/sched/loadavg.h b/include/linux/sched/loadavg.h
index 771e753e4670..f019a7306600 100644
--- a/include/linux/sched/loadavg.h
+++ b/include/linux/sched/loadavg.h
@@ -18,8 +18,16 @@ extern unsigned long avenrun[]; /* Load averages */
extern void get_avenrun(unsigned long *loads, unsigned long offset, int shift);
struct task_group;
+#ifdef CONFIG_CGROUP_SCHED
extern int get_avenrun_tg(struct task_group *tg, unsigned long *loads,
unsigned long offset, int shift);
+#else
+static inline int get_avenrun_tg(struct task_group *tg, unsigned long *loads,
+ unsigned long offset, int shift)
+{
+ return -1;
+}
+#endif
#define FSHIFT 11 /* nr of bits of precision */
#define FIXED_1 (1<<FSHIFT) /* 1.0 as fixed-point */
@@ -51,7 +59,7 @@ extern unsigned long calc_load_n(unsigned long load, unsigned long exp,
extern bool calc_global_load(void);
-#ifdef CONFIG_VE
+#if defined(CONFIG_VE) && defined(CONFIG_CGROUP_SCHED)
extern void calc_load_ve(void);
#else
#define calc_load_ve() do { } while (0)
diff --git a/kernel/sched/core.c b/kernel/sched/core.c
index d5b4d8c97a0c..7d2214749245 100644
--- a/kernel/sched/core.c
+++ b/kernel/sched/core.c
@@ -10441,7 +10441,9 @@ struct cgroup_subsys cpu_cgrp_subsys = {
.dfl_cftypes = cpu_files,
.early_init = true,
.threaded = true,
+#ifdef CONFIG_CGROUP_CPUACCT
.depends_on = 1 << cpuacct_cgrp_id,
+#endif
};
#endif /* CONFIG_CGROUP_SCHED */
diff --git a/kernel/sched/cpuacct.c b/kernel/sched/cpuacct.c
index 01a2b2c3c5b7..98c13ff2bac8 100644
--- a/kernel/sched/cpuacct.c
+++ b/kernel/sched/cpuacct.c
@@ -542,6 +542,7 @@ static void fixup_vcpustat_delta(struct kernel_cpustat *cur,
cur->cpustat[CPUTIME_STEAL] = 0;
}
+#ifdef CONFIG_CFS_CPULIMIT
static void cpu_cgroup_update_vcpustat(struct cgroup_subsys_state *cpu_css,
struct cgroup_subsys_state *cpuacct_css)
{
@@ -632,6 +633,10 @@ static void cpu_cgroup_update_vcpustat(struct cgroup_subsys_state *cpu_css,
out_unlock:
spin_unlock(&tg->vcpustat_lock);
}
+#else
+static inline void cpu_cgroup_update_vcpustat(struct cgroup_subsys_state *cpu_css,
+ struct cgroup_subsys_state *cpuacct_css) {}
+#endif
int cpu_cgroup_proc_stat(struct cgroup_subsys_state *cpu_css,
struct cgroup_subsys_state *cpuacct_css,
diff --git a/kernel/sched/loadavg.c b/kernel/sched/loadavg.c
index bc0b6bcdae2d..c4ca3c83f1cf 100644
--- a/kernel/sched/loadavg.c
+++ b/kernel/sched/loadavg.c
@@ -78,6 +78,7 @@ void get_avenrun(unsigned long *loads, unsigned long offset, int shift)
loads[2] = (avenrun[2] + offset) << shift;
}
+#ifdef CONFIG_CGROUP_SCHED
int get_avenrun_tg(struct task_group *tg, unsigned long *loads,
unsigned long offset, int shift)
{
@@ -93,6 +94,7 @@ int get_avenrun_tg(struct task_group *tg, unsigned long *loads,
return 0;
}
+#endif
long calc_load_fold_active(struct rq *this_rq, long adjust)
{
@@ -109,7 +111,7 @@ long calc_load_fold_active(struct rq *this_rq, long adjust)
return delta;
}
-#ifdef CONFIG_VE
+#if defined(CONFIG_VE) && defined(CONFIG_CGROUP_SCHED)
extern struct list_head ve_root_list;
extern raw_spinlock_t load_ve_lock;
@@ -166,7 +168,7 @@ void calc_load_ve(void)
kstat_glob.nr_unint_avg[2] = calc_load(kstat_glob.nr_unint_avg[2], EXP_15, nr_unint);
write_seqcount_end(&kstat_glob.nr_unint_avg_seq);
}
-#endif /* CONFIG_VE */
+#endif /* CONFIG_VE && CONFIG_CGROUP_SCHED */
/**
* fixed_power_int - compute: x^n, in O(log n) time
--
2.54.0
More information about the Devel
mailing list