ARM: DRA7 / OMAP5: Add workaround for ARM errata 798870
This patch enables the workaround for ARM errata 798870 for OMAP5 / DRA7 which says "If back-to-back speculative cache line fills (fill A and fill B) are issued from the L1 data cache of a CPU to the L2 cache, the second request (fill B) is then cancelled, and the second request would have detected a hazard against a recent write or eviction (write B) to the same cache line as fill B then the L2 logic might deadlock." An l2auxctlr accessor implementation for OMAP5 and DRA7 is introduced here as well. Signed-off-by: Praveen Rao <prao@ti.com> Signed-off-by: Angela Stegmaier <angelabaker@ti.com> Signed-off-by: Nishanth Menon <nm@ti.com> Tested-by: Matt Porter <mporter@konsulko.com> Reviewed-by: Tom Rini <trini@konsulko.com>
This commit is contained in:
parent
49ec949091
commit
5f603761c3
@ -381,3 +381,10 @@ void setup_warmreset_time(void)
|
||||
rst_val |= rst_time;
|
||||
writel(rst_val, (*prcm)->prm_rsttime);
|
||||
}
|
||||
|
||||
void v7_arch_cp15_set_l2aux_ctrl(u32 l2auxctrl, u32 cpu_midr,
|
||||
u32 cpu_rev_comb, u32 cpu_variant,
|
||||
u32 cpu_rev)
|
||||
{
|
||||
omap_smc1(OMAP5_SERVICE_L2ACTLR_SET, l2auxctrl);
|
||||
}
|
||||
|
@ -66,4 +66,7 @@ static inline u32 usec_to_32k(u32 usec)
|
||||
{
|
||||
return div_round_up(32768 * usec, 1000000);
|
||||
}
|
||||
|
||||
#define OMAP5_SERVICE_L2ACTLR_SET 0x104
|
||||
|
||||
#endif
|
||||
|
@ -21,6 +21,9 @@
|
||||
#define CONFIG_DISPLAY_BOARDINFO
|
||||
#define CONFIG_ARCH_CPU_INIT
|
||||
|
||||
/* Common ARM Erratas */
|
||||
#define CONFIG_ARM_ERRATA_798870
|
||||
|
||||
#define CONFIG_SYS_CACHELINE_SIZE 64
|
||||
|
||||
/* Use General purpose timer 1 */
|
||||
|
Loading…
Reference in New Issue
Block a user