summaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorMichael wang <wangyun@linux.vnet.ibm.com>2013-11-13 11:10:56 +0800
committerIngo Molnar <mingo@kernel.org>2013-11-13 13:33:50 +0100
commit106dd5afde3cd10db7e1370b6ddc77f0b2496a75 (patch)
tree5a83870657588c076e17d59a19a3c27f20fe38cb /net
parent9b66bfb28049594fe2bb2b91607ba302f511ce8b (diff)
downloadlinux-106dd5afde3cd10db7e1370b6ddc77f0b2496a75.tar.bz2
sched: Fix endless sync_sched/rcu() loop inside _cpu_down()
Commit 6acce3ef8: sched: Remove get_online_cpus() usage tries to do sync_sched/rcu() inside _cpu_down() but triggers: INFO: task swapper/0:1 blocked for more than 120 seconds. ... [<ffffffff811263dc>] synchronize_rcu+0x2c/0x30 [<ffffffff81d1bd82>] _cpu_down+0x2b2/0x340 ... It was caused by that in the rcu boost case we rely on smpboot thread to finish the rcu callback, which has already been parked before sync in here and leads to the endless sync_sched/rcu(). This patch exchanges the sequence of smpboot_park_threads() and sync_sched/rcu() to fix the bug. Reported-by: Fengguang Wu <fengguang.wu@intel.com> Tested-by: Fengguang Wu <fengguang.wu@intel.com> Signed-off-by: Michael Wang <wangyun@linux.vnet.ibm.com> Signed-off-by: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/5282EDC0.6060003@linux.vnet.ibm.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'net')
0 files changed, 0 insertions, 0 deletions