/*
  * We use 128 set in radix mode and 256 set in hpt mode.
  */
-static __always_inline void _tlbiel_pid(unsigned long pid, unsigned long ric)
+static inline void _tlbiel_pid(unsigned long pid, unsigned long ric)
 {
        int set;
 
        asm volatile("ptesync": : :"memory");
 
-       /*
-        * Flush the first set of the TLB, and if we're doing a RIC_FLUSH_ALL,
-        * also flush the entire Page Walk Cache.
-        */
-       __tlbiel_pid(pid, 0, ric);
+       switch (ric) {
+       case RIC_FLUSH_PWC:
 
-       /* For PWC, only one flush is needed */
-       if (ric == RIC_FLUSH_PWC) {
+               /* For PWC, only one flush is needed */
+               __tlbiel_pid(pid, 0, RIC_FLUSH_PWC);
                ppc_after_tlbiel_barrier();
                return;
+       case RIC_FLUSH_TLB:
+               __tlbiel_pid(pid, 0, RIC_FLUSH_TLB);
+               break;
+       case RIC_FLUSH_ALL:
+       default:
+               /*
+                * Flush the first set of the TLB, and if
+                * we're doing a RIC_FLUSH_ALL, also flush
+                * the entire Page Walk Cache.
+                */
+               __tlbiel_pid(pid, 0, RIC_FLUSH_ALL);
        }
 
        if (!cpu_has_feature(CPU_FTR_ARCH_31)) {
        }
 }
 
-static __always_inline void __radix__flush_tlb_range_psize(struct mm_struct *mm,
+static void __radix__flush_tlb_range_psize(struct mm_struct *mm,
                                unsigned long start, unsigned long end,
                                int psize, bool also_pwc)
 {