]> git.baikalelectronics.ru Git - kernel.git/commit
MIPS: Synchronize MIPS count one CPU at a time
authorJayachandran C <jchandra@broadcom.com>
Tue, 14 Aug 2012 13:26:13 +0000 (18:56 +0530)
committerRalf Baechle <ralf@linux-mips.org>
Fri, 17 Aug 2012 08:57:28 +0000 (10:57 +0200)
commit5fa7a3ea208bd867ecda7259c3975f8594303651
tree86d7da54a921d0545e396a1d6da229b15d3e44e9
parentb7c7aa5799803e0761a9c7b4fc4eab6a944a5c03
MIPS: Synchronize MIPS count one CPU at a time

The current implementation of synchronise_count_{master,slave} blocks
slave CPUs in early boot until all of them come up. This no longer
works because blocking a CPU with interrupts off after notifying the
CPU to be online causes problems with the current kernel.

Specifically, after the workqueue changes
(commit b671465f2b8a8 "Pull workqueue changes from Tejun Heo")
the CPU_ONLINE notification callback workqueue_cpu_up_callback()
will hang on wait_for_completion(&idle_rebind.done), if the slave
CPUs are blocked for synchronize_count_slave().

The changes are to update synchronize_count_{master,slave}() to handle
one CPU at a time and to call synchronise_count_master() in __cpu_up()
so that the CPU_ONLINE notification goes out only after the COP0 COUNT
register is synchronized.

[ralf@linux-mips.org: This matter only to those few platforms which are
using the cp0 counter as their clocksource which are XLP, XLR and MIPS'
CMP solution.]

Signed-off-by: Jayachandran C <jchandra@broadcom.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/4216/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/include/asm/r4k-timer.h
arch/mips/kernel/smp.c
arch/mips/kernel/sync-r4k.c