diff options
author | Steven J. Hill <sjhill@mips.com> | 2012-08-28 23:20:08 -0500 |
---|---|---|
committer | Steven J. Hill <sjhill@mips.com> | 2012-09-13 15:43:52 -0500 |
commit | 625c0a21700bdb90844d926a1508a17a77e369c9 (patch) | |
tree | cda27e3f4b541e91d92788fa18985bfa20a6b119 /arch/mips/mm | |
parent | 3234f4466934f08136736790e3de3c6debc71271 (diff) | |
download | linux-stable-625c0a21700bdb90844d926a1508a17a77e369c9.tar.gz linux-stable-625c0a21700bdb90844d926a1508a17a77e369c9.tar.bz2 linux-stable-625c0a21700bdb90844d926a1508a17a77e369c9.zip |
MIPS: Avoid pipeline stalls on some MIPS32R2 cores.
The architecture specification says that an EHB instruction is
needed to avoid a hazard when writing TLB entries. However, some
cores do not have this hazard, and thus the EHB instruction causes
a costly pipeline stall. Detect these cores and do not use the EHB
instruction.
Signed-off-by: Steven J. Hill <sjhill@mips.com>
Diffstat (limited to 'arch/mips/mm')
-rw-r--r-- | arch/mips/mm/tlbex.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/arch/mips/mm/tlbex.c b/arch/mips/mm/tlbex.c index 03eb0ef91580..22ba108d708d 100644 --- a/arch/mips/mm/tlbex.c +++ b/arch/mips/mm/tlbex.c @@ -449,8 +449,20 @@ static void __cpuinit build_tlb_write_entry(u32 **p, struct uasm_label **l, } if (cpu_has_mips_r2) { - if (cpu_has_mips_r2_exec_hazard) + /* + * The architecture spec says an ehb is required here, + * but a number of cores do not have the hazard and + * using an ehb causes an expensive pipeline stall. + */ + switch (current_cpu_type()) { + case CPU_M14KC: + case CPU_74K: + break; + + default: uasm_i_ehb(p); + break; + } tlbw(p); return; } |