]> git.karo-electronics.de Git - karo-tx-linux.git/commit
MIPS: Kernel hangs occasionally during boot.
authorAl Cooper <alcooperx@gmail.com>
Tue, 8 Nov 2011 14:59:01 +0000 (09:59 -0500)
committerRalf Baechle <ralf@linux-mips.org>
Tue, 15 Nov 2011 21:13:28 +0000 (21:13 +0000)
commitb483c884b6a1841e049a5d4332f35871b70b66f4
treeb1173ed4676b2b886ffa2a336fc7fc8e877d3ede
parent4fdfaa655849e45a3ae66a7f8ce87887c85077ef
MIPS: Kernel hangs occasionally during boot.

The Kernel hangs occasionally during boot after "Calibrating delay loop..".
This is caused by the c0_compare_int_usable() routine in cevt-r4k.c
returning false which causes the system to disable the timer and hang later.
The false return happens because the routine is using a series of four calls
to irq_disable_hazard() as a delay while it waits for the timer changes to
propagate to the cp0 cause register. On newer MIPS cores, like the 74K, the
series of irq_disable_hazard() calls turn into ehb instructions and can take
as little as a few clock ticks for all 4 instructions. This is not enough of
a delay, so the routine thinks the timer is not working.  This fix uses up
to a max number of cycle counter ticks for the delay and uses
back_to_back_c0_hazard() instead of irq_disable_hazard() to handle the
hazard condition between cp0 writes and cp0 reads.

Signed-off-by: Al Cooper <alcooperx@gmail.com>
Cc: linux-mips@linux-mips.org
Cc: linux-kernel@vger.kernel.org
Patchwork: https://patchwork.linux-mips.org/patch/2911/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/kernel/cevt-r4k.c