}
 
 extern void get_new_mmu_context(struct mm_struct *mm);
+extern void check_mmu_context(struct mm_struct *mm);
+extern void check_switch_mmu_context(struct mm_struct *mm);
 
 /*
  * Initialize the context related info for a new mm_struct
        local_irq_save(flags);
 
        htw_stop();
-       /* Check if our ASID is of an older version and thus invalid */
-       if ((cpu_context(cpu, next) ^ asid_cache(cpu)) & asid_version_mask(cpu))
-               get_new_mmu_context(next);
-       write_c0_entryhi(cpu_asid(cpu, next));
-       TLBMISS_HANDLER_SETUP_PGD(next->pgd);
+       check_switch_mmu_context(next);
 
        /*
         * Mark current->active_mm as not "active" anymore.
 
         */
        if (current->flags & PF_VCPU) {
                mm = KVM_GUEST_KERNEL_MODE(vcpu) ? kern_mm : user_mm;
-               if ((cpu_context(cpu, mm) ^ asid_cache(cpu)) &
-                   asid_version_mask(cpu))
-                       get_new_mmu_context(mm);
-               write_c0_entryhi(cpu_asid(cpu, mm));
-               TLBMISS_HANDLER_SETUP_PGD(mm->pgd);
+               check_switch_mmu_context(mm);
                kvm_mips_suspend_mm(cpu);
                ehb();
        }
 
        if (current->flags & PF_VCPU) {
                /* Restore normal Linux process memory map */
-               if (((cpu_context(cpu, current->mm) ^ asid_cache(cpu)) &
-                    asid_version_mask(cpu)))
-                       get_new_mmu_context(current->mm);
-               write_c0_entryhi(cpu_asid(cpu, current->mm));
-               TLBMISS_HANDLER_SETUP_PGD(current->mm->pgd);
+               check_switch_mmu_context(current->mm);
                kvm_mips_resume_mm(cpu);
                ehb();
        }
         * Check if ASID is stale. This may happen due to a TLB flush request or
         * a lazy user MM invalidation.
         */
-       if ((cpu_context(cpu, mm) ^ asid_cache(cpu)) &
-           asid_version_mask(cpu))
-               get_new_mmu_context(mm);
+       check_mmu_context(mm);
 }
 
 static int kvm_trap_emul_vcpu_run(struct kvm_run *run, struct kvm_vcpu *vcpu)
        cpu = smp_processor_id();
 
        /* Restore normal Linux process memory map */
-       if (((cpu_context(cpu, current->mm) ^ asid_cache(cpu)) &
-            asid_version_mask(cpu)))
-               get_new_mmu_context(current->mm);
-       write_c0_entryhi(cpu_asid(cpu, current->mm));
-       TLBMISS_HANDLER_SETUP_PGD(current->mm->pgd);
+       check_switch_mmu_context(current->mm);
        kvm_mips_resume_mm(cpu);
 
        htw_start();
 
                 * Root ASID dealiases guest GPA mappings in the root TLB.
                 * Allocate new root ASID if needed.
                 */
-               if (cpumask_test_and_clear_cpu(cpu, &kvm->arch.asid_flush_mask)
-                   || (cpu_context(cpu, gpa_mm) ^ asid_cache(cpu)) &
-                                               asid_version_mask(cpu))
+               if (cpumask_test_and_clear_cpu(cpu, &kvm->arch.asid_flush_mask))
                        get_new_mmu_context(gpa_mm);
+               else
+                       check_mmu_context(gpa_mm);
        }
 }
 
 
 
        cpu_context(cpu, mm) = asid_cache(cpu) = asid;
 }
+
+void check_mmu_context(struct mm_struct *mm)
+{
+       unsigned int cpu = smp_processor_id();
+
+       /* Check if our ASID is of an older version and thus invalid */
+       if ((cpu_context(cpu, mm) ^ asid_cache(cpu)) & asid_version_mask(cpu))
+               get_new_mmu_context(mm);
+}
+
+void check_switch_mmu_context(struct mm_struct *mm)
+{
+       unsigned int cpu = smp_processor_id();
+
+       check_mmu_context(mm);
+       write_c0_entryhi(cpu_asid(cpu, mm));
+       TLBMISS_HANDLER_SETUP_PGD(mm->pgd);
+}