|
@@ -345,11 +345,26 @@ static void r4k___flush_cache_all(void)
|
|
|
r4k_on_each_cpu(local_r4k___flush_cache_all, NULL, 1, 1);
|
|
|
}
|
|
|
|
|
|
+static inline int has_valid_asid(const struct mm_struct *mm)
|
|
|
+{
|
|
|
+#if defined(CONFIG_MIPS_MT_SMP) || defined(CONFIG_MIPS_MT_SMTC)
|
|
|
+ int i;
|
|
|
+
|
|
|
+ for_each_online_cpu(i)
|
|
|
+ if (cpu_context(i, mm))
|
|
|
+ return 1;
|
|
|
+
|
|
|
+ return 0;
|
|
|
+#else
|
|
|
+ return cpu_context(smp_processor_id(), mm);
|
|
|
+#endif
|
|
|
+}
|
|
|
+
|
|
|
static inline void local_r4k_flush_cache_range(void * args)
|
|
|
{
|
|
|
struct vm_area_struct *vma = args;
|
|
|
|
|
|
- if (!(cpu_context(smp_processor_id(), vma->vm_mm)))
|
|
|
+ if (!(has_valid_asid(vma->vm_mm)))
|
|
|
return;
|
|
|
|
|
|
r4k_blast_dcache();
|
|
@@ -368,7 +383,7 @@ static inline void local_r4k_flush_cache_mm(void * args)
|
|
|
{
|
|
|
struct mm_struct *mm = args;
|
|
|
|
|
|
- if (!cpu_context(smp_processor_id(), mm))
|
|
|
+ if (!has_valid_asid(mm))
|
|
|
return;
|
|
|
|
|
|
/*
|
|
@@ -420,7 +435,7 @@ static inline void local_r4k_flush_cache_page(void *args)
|
|
|
* If ownes no valid ASID yet, cannot possibly have gotten
|
|
|
* this page into the cache.
|
|
|
*/
|
|
|
- if (cpu_context(smp_processor_id(), mm) == 0)
|
|
|
+ if (!has_valid_asid(mm))
|
|
|
return;
|
|
|
|
|
|
addr &= PAGE_MASK;
|