1 CNS3xxx SOCs have L310-compatible cache controller, so let's use it.
3 With this patch benchmarking with 'gzip' shows that performance is
4 doubled, and I'm still able to boot full-fledged userland over NFS
5 (using PCIe NIC), so the support should be pretty robust.
7 Signed-off-by: Anton Vorontsov <avorontsov@mvista.com>
10 arch/arm/mach-cns3xxx/cns3420vb.c | 2 +
11 arch/arm/mach-cns3xxx/core.c | 43 +++++++++++++++++++++++++++++++++++++
12 arch/arm/mach-cns3xxx/core.h | 6 +++++
13 arch/arm/mm/Kconfig | 2 +-
14 4 files changed, 52 insertions(+), 1 deletions(-)
16 --- a/arch/arm/mach-cns3xxx/cns3420vb.c
17 +++ b/arch/arm/mach-cns3xxx/cns3420vb.c
18 @@ -192,6 +192,8 @@ static struct platform_device *cns3420_p
20 static void __init cns3420_init(void)
22 + cns3xxx_l2x0_init();
24 platform_add_devices(cns3420_pdevs, ARRAY_SIZE(cns3420_pdevs));
27 --- a/arch/arm/mach-cns3xxx/core.c
28 +++ b/arch/arm/mach-cns3xxx/core.c
30 #include <asm/mach/time.h>
31 #include <asm/mach/irq.h>
32 #include <asm/hardware/gic.h>
33 +#include <asm/hardware/cache-l2x0.h>
34 #include <mach/cns3xxx.h>
37 @@ -244,3 +245,45 @@ static void __init cns3xxx_timer_init(vo
38 struct sys_timer cns3xxx_timer = {
39 .init = cns3xxx_timer_init,
42 +#ifdef CONFIG_CACHE_L2X0
44 +void __init cns3xxx_l2x0_init(void)
46 + void __iomem *base = ioremap(CNS3XXX_L2C_BASE, SZ_4K);
53 + * Tag RAM Control register
55 + * bit[10:8] - 1 cycle of write accesses latency
56 + * bit[6:4] - 1 cycle of read accesses latency
57 + * bit[3:0] - 1 cycle of setup latency
59 + * 1 cycle of latency for setup, read and write accesses
61 + val = readl(base + L2X0_TAG_LATENCY_CTRL);
63 + writel(val, base + L2X0_TAG_LATENCY_CTRL);
66 + * Data RAM Control register
68 + * bit[10:8] - 1 cycles of write accesses latency
69 + * bit[6:4] - 1 cycles of read accesses latency
70 + * bit[3:0] - 1 cycle of setup latency
72 + * 1 cycle of latency for setup, read and write accesses
74 + val = readl(base + L2X0_DATA_LATENCY_CTRL);
76 + writel(val, base + L2X0_DATA_LATENCY_CTRL);
78 + /* 32 KiB, 8-way, parity disable */
79 + l2x0_init(base, 0x00540000, 0xfe000fff);
82 +#endif /* CONFIG_CACHE_L2X0 */
83 --- a/arch/arm/mach-cns3xxx/core.h
84 +++ b/arch/arm/mach-cns3xxx/core.h
87 extern struct sys_timer cns3xxx_timer;
89 +#ifdef CONFIG_CACHE_L2X0
90 +void __init cns3xxx_l2x0_init(void);
92 +static inline void cns3xxx_l2x0_init(void) {}
93 +#endif /* CONFIG_CACHE_L2X0 */
95 void __init cns3xxx_map_io(void);
96 void __init cns3xxx_init_irq(void);
97 void cns3xxx_power_off(void);
98 --- a/arch/arm/mm/Kconfig
99 +++ b/arch/arm/mm/Kconfig
100 @@ -821,7 +821,7 @@ config CACHE_L2X0
101 depends on REALVIEW_EB_ARM11MP || MACH_REALVIEW_PB11MP || MACH_REALVIEW_PB1176 || \
102 REALVIEW_EB_A9MP || SOC_IMX35 || SOC_IMX31 || MACH_REALVIEW_PBX || \
103 ARCH_NOMADIK || ARCH_OMAP4 || ARCH_EXYNOS4 || ARCH_TEGRA || \
104 - ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || ARCH_SHMOBILE
105 + ARCH_U8500 || ARCH_VEXPRESS_CA9X4 || ARCH_SHMOBILE || ARCH_CNS3XXX
108 select OUTER_CACHE_SYNC