forked from Minki/linux
ARM: i.MX: system.c: Tweak prefetch settings for performance
Update Prefetch Control Register settings to match that of Freescale's
Linux tree. As the commit e3addf1b77
states (author Nitin Garg):
"... set Prefetch offset to 15, since it improves memcpy performance by
35%. Don't enable Incr double Linefill enable since it adversely affects
memcpy performance by about 32MB/s and reads by 90MB/s. Tested with 4K
to 16MB sized src and dst aligned buffer..."
Those results are also corroborated by our own testing.
Acked-by: Arnd Bergmann <arnd@arndb.de>
Tested-by: Chris Healy <cphealy@gmail.com>
Signed-off-by: Andrey Smirnov <andrew.smirnov@gmail.com>
Signed-off-by: Shawn Guo <shawnguo@kernel.org>
This commit is contained in:
parent
b829037136
commit
1d9e947799
@ -111,8 +111,12 @@ void __init imx_init_l2cache(void)
|
||||
val = readl_relaxed(l2x0_base + L310_PREFETCH_CTRL);
|
||||
val |= L310_PREFETCH_CTRL_DBL_LINEFILL |
|
||||
L310_PREFETCH_CTRL_INSTR_PREFETCH |
|
||||
L310_PREFETCH_CTRL_DATA_PREFETCH |
|
||||
L310_PREFETCH_CTRL_DBL_LINEFILL_INCR;
|
||||
L310_PREFETCH_CTRL_DATA_PREFETCH;
|
||||
|
||||
/* Set perfetch offset to improve performance */
|
||||
val &= ~L310_PREFETCH_CTRL_OFFSET_MASK;
|
||||
val |= 15;
|
||||
|
||||
writel_relaxed(val, l2x0_base + L310_PREFETCH_CTRL);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user