aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarkos Chandras <markos.chandras@imgtec.com>2014-01-30 12:21:29 -0500
committerRalf Baechle <ralf@linux-mips.org>2014-03-06 15:25:21 -0500
commit02dc6bfb080e8205aacea5c4b4dd6a9bd4c9406e (patch)
tree08224e4eb6d1b1471cc3322b626250e2d82bce7e
parent0414855fdc4a40da05221fc6062cccbc0c30f169 (diff)
MIPS: mm: c-r4k: Detect instruction cache aliases
The *Aptiv cores can use the CONF7/IAR bit to detect if the core has hardware support to remove instruction cache aliasing. This also defines the CONF7/AR bit in order to avoid using the '16' magic number. Signed-off-by: Markos Chandras <markos.chandras@imgtec.com> Cc: linux-mips@linux-mips.org Patchwork: https://patchwork.linux-mips.org/patch/6499/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
-rw-r--r--arch/mips/include/asm/mipsregs.h3
-rw-r--r--arch/mips/mm/c-r4k.c11
2 files changed, 11 insertions, 3 deletions
diff --git a/arch/mips/include/asm/mipsregs.h b/arch/mips/include/asm/mipsregs.h
index bbc3dd4294bc..0c746176d31c 100644
--- a/arch/mips/include/asm/mipsregs.h
+++ b/arch/mips/include/asm/mipsregs.h
@@ -653,6 +653,9 @@
653 653
654#define MIPS_CONF7_RPS (_ULCAST_(1) << 2) 654#define MIPS_CONF7_RPS (_ULCAST_(1) << 2)
655 655
656#define MIPS_CONF7_IAR (_ULCAST_(1) << 10)
657#define MIPS_CONF7_AR (_ULCAST_(1) << 16)
658
656/* EntryHI bit definition */ 659/* EntryHI bit definition */
657#define MIPS_ENTRYHI_EHINV (_ULCAST_(1) << 10) 660#define MIPS_ENTRYHI_EHINV (_ULCAST_(1) << 10)
658 661
diff --git a/arch/mips/mm/c-r4k.c b/arch/mips/mm/c-r4k.c
index c14259edd53f..8f1d549d5132 100644
--- a/arch/mips/mm/c-r4k.c
+++ b/arch/mips/mm/c-r4k.c
@@ -1117,9 +1117,14 @@ static void probe_pcache(void)
1117 case CPU_PROAPTIV: 1117 case CPU_PROAPTIV:
1118 if (current_cpu_type() == CPU_74K) 1118 if (current_cpu_type() == CPU_74K)
1119 alias_74k_erratum(c); 1119 alias_74k_erratum(c);
1120 if ((read_c0_config7() & (1 << 16))) { 1120 if (!(read_c0_config7() & MIPS_CONF7_IAR) &&
1121 /* effectively physically indexed dcache, 1121 (c->icache.waysize > PAGE_SIZE))
1122 thus no virtual aliases. */ 1122 c->icache.flags |= MIPS_CACHE_ALIASES;
1123 if (read_c0_config7() & MIPS_CONF7_AR) {
1124 /*
1125 * Effectively physically indexed dcache,
1126 * thus no virtual aliases.
1127 */
1123 c->dcache.flags |= MIPS_CACHE_PINDEX; 1128 c->dcache.flags |= MIPS_CACHE_PINDEX;
1124 break; 1129 break;
1125 } 1130 }