Commit 819da1ea authored by Paul Burton's avatar Paul Burton Committed by Ralf Baechle

MIPS: c-r4k: Treat I6400 dcache as though physically indexed

The L1 data cache in I6400 CPUs is indexed by physical address bits if
an entry for the address is present in the DTLB early enough in the
pipelined execution of a memory access instruction. If an entry is not
present then it's indexed by virtual address bits, but hardware will
check in a later pipeline stage when a DTLB entry has been created
whether the virtual address bits used match the physical address bits,
and if not will transparently restart the memory access instruction.

This means that although it isn't always physically indexed, it appears
so to software & we can treat the I6400 L1 data cache as being
physically indexed in order to avoid considering aliasing.
Signed-off-by: default avatarPaul Burton <paul.burton@imgtec.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/14016/Signed-off-by: default avatarRalf Baechle <ralf@linux-mips.org>
parent 5d0a99d6
...@@ -1452,6 +1452,7 @@ static void probe_pcache(void) ...@@ -1452,6 +1452,7 @@ static void probe_pcache(void)
switch (current_cpu_type()) { switch (current_cpu_type()) {
case CPU_20KC: case CPU_20KC:
case CPU_25KF: case CPU_25KF:
case CPU_I6400:
case CPU_SB1: case CPU_SB1:
case CPU_SB1A: case CPU_SB1A:
case CPU_XLR: case CPU_XLR:
...@@ -1478,7 +1479,6 @@ static void probe_pcache(void) ...@@ -1478,7 +1479,6 @@ static void probe_pcache(void)
case CPU_PROAPTIV: case CPU_PROAPTIV:
case CPU_M5150: case CPU_M5150:
case CPU_QEMU_GENERIC: case CPU_QEMU_GENERIC:
case CPU_I6400:
case CPU_P6600: case CPU_P6600:
case CPU_M6250: case CPU_M6250:
if (!(read_c0_config7() & MIPS_CONF7_IAR) && if (!(read_c0_config7() & MIPS_CONF7_IAR) &&
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment