From: Konstantin Khlebnikov Date: Wed, 27 Feb 2019 08:10:18 +0000 (+0300) Subject: sched/core: Handle overflow in cpu_shares_write_u64 X-Git-Tag: v4.19.47~139 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=355673f80835c9ddfa58b0aa18b48433394bba87;p=platform%2Fkernel%2Flinux-rpi3.git sched/core: Handle overflow in cpu_shares_write_u64 [ Upstream commit 5b61d50ab4ef590f5e1d4df15cd2cea5f5715308 ] Bit shift in scale_load() could overflow shares. This patch saturates it to MAX_SHARES like following sched_group_set_shares(). Example: # echo 9223372036854776832 > cpu.shares # cat cpu.shares Before patch: 1024 After pattch: 262144 Signed-off-by: Konstantin Khlebnikov Acked-by: Peter Zijlstra Cc: Linus Torvalds Cc: Peter Zijlstra Cc: Thomas Gleixner Link: http://lkml.kernel.org/r/155125501891.293431.3345233332801109696.stgit@buzz Signed-off-by: Ingo Molnar Signed-off-by: Sasha Levin --- diff --git a/kernel/sched/core.c b/kernel/sched/core.c index bd5ae34..6138754 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -6491,6 +6491,8 @@ static void cpu_cgroup_attach(struct cgroup_taskset *tset) static int cpu_shares_write_u64(struct cgroup_subsys_state *css, struct cftype *cftype, u64 shareval) { + if (shareval > scale_load_down(ULONG_MAX)) + shareval = MAX_SHARES; return sched_group_set_shares(css_tg(css), scale_load(shareval)); }