]> www.infradead.org Git - users/dwmw2/linux.git/commit
mips: bmips: BCM6358: make sure CBR is correctly set
authorChristian Marangi <ansuelsmth@gmail.com>
Tue, 11 Jun 2024 11:35:33 +0000 (13:35 +0200)
committerThomas Bogendoerfer <tsbogend@alpha.franken.de>
Tue, 11 Jun 2024 14:05:24 +0000 (16:05 +0200)
commitce5cdd3b05216b704a704f466fb4c2dff3778caf
tree525c451aa77f9522519f836df3ce9fefffc825d5
parent277a0363120276645ae598d8d5fea7265e076ae9
mips: bmips: BCM6358: make sure CBR is correctly set

It was discovered that some device have CBR address set to 0 causing
kernel panic when arch_sync_dma_for_cpu_all is called.

This was notice in situation where the system is booted from TP1 and
BMIPS_GET_CBR() returns 0 instead of a valid address and
!!(read_c0_brcm_cmt_local() & (1 << 31)); not failing.

The current check whether RAC flush should be disabled or not are not
enough hence lets check if CBR is a valid address or not.

Fixes: ab327f8acdf8 ("mips: bmips: BCM6358: disable RAC flush for TP1")
Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
Acked-by: Florian Fainelli <florian.fainelli@broadcom.com>
Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
arch/mips/bmips/setup.c