]> git.baikalelectronics.ru Git - kernel.git/commit
parisc: Mark cr16 CPU clocksource unstable on all SMP machines
authorHelge Deller <deller@gmx.de>
Sat, 4 Dec 2021 20:21:46 +0000 (21:21 +0100)
committerHelge Deller <deller@gmx.de>
Sat, 4 Dec 2021 20:36:04 +0000 (21:36 +0100)
commitd52c107a38e372564926314aee516f31fc781522
treec56cda00d7d2701935a67bcdbbe6c5ec0c969edc
parent69250daa5d0262b3ea7c6156558f6211f6d4914c
parisc: Mark cr16 CPU clocksource unstable on all SMP machines

In commit 2681e41cfba1 ("parisc: Enhance detection of synchronous cr16
clocksources") I assumed that CPUs on the same physical core are syncronous.
While booting up the kernel on two different C8000 machines, one with a
dual-core PA8800 and one with a dual-core PA8900 CPU, this turned out to be
wrong. The symptom was that I saw a jump in the internal clocks printed to the
syslog and strange overall behaviour.  On machines which have 4 cores (2
dual-cores) the problem isn't visible, because the current logic already marked
the cr16 clocksource unstable in this case.

This patch now marks the cr16 interval timers unstable if we have more than one
CPU in the system, and it fixes this issue.

Fixes: 2681e41cfba1 ("parisc: Enhance detection of synchronous cr16 clocksources")
Signed-off-by: Helge Deller <deller@gmx.de>
Cc: <stable@vger.kernel.org> # v5.15+
arch/parisc/kernel/time.c