mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-19 11:43:40 +00:00
a5c05453a1
Rework the handling of the CBR address and cache it. This address doesn't change and can be cached instead of reading the register every time. This is in preparation of permitting to tweak the CBR address in DT with broken SoC or bootloader. bmips_cbr_addr is defined in setup.c for each arch to keep compatibility with legacy brcm47xx/brcm63xx and generic BMIPS target. Acked-by: Florian Fainelli <florian.fainelli@broadcom.com> Signed-off-by: Christian Marangi <ansuelsmth@gmail.com> Signed-off-by: Thomas Bogendoerfer <tsbogend@alpha.franken.de>
28 lines
626 B
C
28 lines
626 B
C
// SPDX-License-Identifier: GPL-2.0+
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/dma-map-ops.h>
|
|
#include <asm/bmips.h>
|
|
#include <asm/io.h>
|
|
|
|
bool bmips_rac_flush_disable;
|
|
|
|
void arch_sync_dma_for_cpu_all(void)
|
|
{
|
|
void __iomem *cbr = bmips_cbr_addr;
|
|
u32 cfg;
|
|
|
|
if (boot_cpu_type() != CPU_BMIPS3300 &&
|
|
boot_cpu_type() != CPU_BMIPS4350 &&
|
|
boot_cpu_type() != CPU_BMIPS4380)
|
|
return;
|
|
|
|
if (unlikely(bmips_rac_flush_disable))
|
|
return;
|
|
|
|
/* Flush stale data out of the readahead cache */
|
|
cfg = __raw_readl(cbr + BMIPS_RAC_CONFIG);
|
|
__raw_writel(cfg | 0x100, cbr + BMIPS_RAC_CONFIG);
|
|
__raw_readl(cbr + BMIPS_RAC_CONFIG);
|
|
}
|