{
        unsigned long pid;
 
-       preempt_disable();
        pid = mm->context.id;
        if (unlikely(pid == MMU_NO_CONTEXT))
-               goto no_context;
+               return;
 
+       preempt_disable();
        if (!mm_is_thread_local(mm))
                _tlbie_pid(pid, RIC_FLUSH_TLB);
        else
                _tlbiel_pid(pid, RIC_FLUSH_TLB);
-no_context:
        preempt_enable();
 }
 EXPORT_SYMBOL(radix__flush_tlb_mm);
 {
        unsigned long pid;
 
-       preempt_disable();
        pid = mm->context.id;
        if (unlikely(pid == MMU_NO_CONTEXT))
-               goto no_context;
+               return;
 
+       preempt_disable();
        if (!mm_is_thread_local(mm))
                _tlbie_pid(pid, RIC_FLUSH_ALL);
        else
                _tlbiel_pid(pid, RIC_FLUSH_ALL);
-no_context:
        preempt_enable();
 }
 EXPORT_SYMBOL(radix__flush_all_mm);
        unsigned long pid;
        unsigned long ap = mmu_get_ap(psize);
 
-       preempt_disable();
        pid = mm->context.id;
        if (unlikely(pid == MMU_NO_CONTEXT))
-               goto bail;
+               return;
+
+       preempt_disable();
        if (!mm_is_thread_local(mm))
                _tlbie_va(vmaddr, pid, ap, RIC_FLUSH_TLB);
        else
                _tlbiel_va(vmaddr, pid, ap, RIC_FLUSH_TLB);
-bail:
        preempt_enable();
 }
 
 {
        unsigned long pid;
        unsigned long addr;
-       int local = mm_is_thread_local(mm);
+       bool local;
        unsigned long ap = mmu_get_ap(psize);
        unsigned long page_size = 1UL << mmu_psize_defs[psize].shift;
 
-
-       preempt_disable();
        pid = mm->context.id;
        if (unlikely(pid == MMU_NO_CONTEXT))
-               goto err_out;
+               return;
 
+       preempt_disable();
+       local = mm_is_thread_local(mm);
        if (end == TLB_FLUSH_ALL ||
            (end - start) > tlb_single_page_flush_ceiling * page_size) {
                if (local)
                        _tlbiel_pid(pid, RIC_FLUSH_TLB);
                else
                        _tlbie_pid(pid, RIC_FLUSH_TLB);
-               goto err_out;
-       }
-       for (addr = start; addr < end; addr += page_size) {
+       } else {
+               for (addr = start; addr < end; addr += page_size) {
 
-               if (local)
-                       _tlbiel_va(addr, pid, ap, RIC_FLUSH_TLB);
-               else
-                       _tlbie_va(addr, pid, ap, RIC_FLUSH_TLB);
+                       if (local)
+                               _tlbiel_va(addr, pid, ap, RIC_FLUSH_TLB);
+                       else
+                               _tlbie_va(addr, pid, ap, RIC_FLUSH_TLB);
+               }
        }
-err_out:
        preempt_enable();
 }
 
 #ifdef CONFIG_TRANSPARENT_HUGEPAGE
 void radix__flush_tlb_collapsed_pmd(struct mm_struct *mm, unsigned long addr)
 {
-       int local = mm_is_thread_local(mm);
        unsigned long ap = mmu_get_ap(mmu_virtual_psize);
        unsigned long pid, end;
-
+       bool local;
 
        pid = mm->context.id;
        if (unlikely(pid == MMU_NO_CONTEXT))
-               goto no_context;
+               return;
 
        /* 4k page size, just blow the world */
        if (PAGE_SIZE == 0x1000) {
                return;
        }
 
+       preempt_disable();
+       local = mm_is_thread_local(mm);
        /* Otherwise first do the PWC */
        if (local)
                _tlbiel_pid(pid, RIC_FLUSH_PWC);
                else
                        _tlbie_va(addr, pid, ap, RIC_FLUSH_TLB);
        }
-no_context:
+
        preempt_enable();
 }
 #endif /* CONFIG_TRANSPARENT_HUGEPAGE */