From 9afacaea65f3e0140cef59bdb643aad147748b22 Mon Sep 17 00:00:00 2001 From: Johnlay Park Date: Mon, 19 Feb 2018 14:51:23 +0900 Subject: [PATCH] [COMMON] sched/fair: Fix hang during rebuilding sd in compute_energy. This patch implemtes the hotplug race check differently and should therefore reinstate support for per-cpu capacity states. refer the commit d5f2ca8a4778938c45d679d67c45b256114de3c5, 64f6fd103dadaf762d3dc11173c5544ff6ec1b16. Change-Id: Iab48cf63c3672e10ad8230d1eeb09185ea588022 Signed-off-by: Johnlay Park --- kernel/sched/fair.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index ddbf7eeefcc0..bc6ce0bc170e 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -5867,7 +5867,17 @@ static int compute_energy(struct energy_env *eenv) } while (sg = sg->next, sg != sd->groups); } + + /* + * If we raced with hotplug and got an sd NULL-pointer; + * returning a wrong energy estimation is better than + * entering an infinite loop. + */ + if (cpumask_test_cpu(cpu, &visit_cpus)) + return -EINVAL; + next_cpu: + cpumask_clear_cpu(cpu, &visit_cpus); continue; } -- 2.20.1