MIPS: BMIPS: local_r4k___flush_cache_all needs to blast S-cache
authorFlorian Fainelli <f.fainelli@gmail.com>
Mon, 4 Apr 2016 17:55:36 +0000 (10:55 -0700)
committerRalf Baechle <ralf@linux-mips.org>
Fri, 13 May 2016 12:02:07 +0000 (14:02 +0200)
local_r4k___flush_cache_all() is missing a special check for BMIPS5000
processors, we need to blast the S-cache, just like other MTI processors
since we have an inclusive cache. We also need an additional __sync() to
make sure this is completed.

Fixes: d74b0172e4e2c ("MIPS: BMIPS: Add special cache handling in c-r4k.c")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Cc: linux-mips@linux-mips.org
Patchwork: https://patchwork.linux-mips.org/patch/13012/
Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
arch/mips/mm/c-r4k.c

index 226516d9c85183844841b589c194e07bb4d08cc2..6f43bdf9a67963fb97f24faa978537d656f94ce2 100644 (file)
@@ -447,6 +447,11 @@ static inline void local_r4k___flush_cache_all(void * args)
                r4k_blast_scache();
                break;
 
+       case CPU_BMIPS5000:
+               r4k_blast_scache();
+               __sync();
+               break;
+
        default:
                r4k_blast_dcache();
                r4k_blast_icache();