#include <asm/mipsmtregs.h>
 #include <asm/mmzone.h>
 #include <asm/unroll.h>
-#include <linux/uaccess.h> /* for uaccess_kernel() */
 
 extern void (*r4k_blast_dcache)(void);
 extern void (*r4k_blast_icache)(void);
        cache_op(Hit_Writeback_Inv_SD, addr);
 }
 
-#define protected_cache_op(op,addr)                            \
+#ifdef CONFIG_EVA
+
+#define protected_cache_op(op, addr)                           \
 ({                                                             \
        int __err = 0;                                          \
        __asm__ __volatile__(                                   \
        "       .set    push                    \n"             \
        "       .set    noreorder               \n"             \
-       "       .set "MIPS_ISA_ARCH_LEVEL"      \n"             \
-       "1:     cache   %1, (%2)                \n"             \
+       "       .set    mips0                   \n"             \
+       "       .set    eva                     \n"             \
+       "1:     cachee  %1, (%2)                \n"             \
        "2:     .insn                           \n"             \
        "       .set    pop                     \n"             \
        "       .section .fixup,\"ax\"          \n"             \
        : "i" (op), "r" (addr), "i" (-EFAULT));                 \
        __err;                                                  \
 })
+#else
 
-
-#define protected_cachee_op(op,addr)                           \
+#define protected_cache_op(op, addr)                           \
 ({                                                             \
        int __err = 0;                                          \
        __asm__ __volatile__(                                   \
        "       .set    push                    \n"             \
        "       .set    noreorder               \n"             \
-       "       .set    mips0                   \n"             \
-       "       .set    eva                     \n"             \
-       "1:     cachee  %1, (%2)                \n"             \
+       "       .set "MIPS_ISA_ARCH_LEVEL"      \n"             \
+       "1:     cache   %1, (%2)                \n"             \
        "2:     .insn                           \n"             \
        "       .set    pop                     \n"             \
        "       .section .fixup,\"ax\"          \n"             \
        : "i" (op), "r" (addr), "i" (-EFAULT));                 \
        __err;                                                  \
 })
+#endif
 
 /*
  * The next two are for badland addresses like signal trampolines.
                return protected_cache_op(Hit_Invalidate_I_Loongson2, addr);
 
        default:
-#ifdef CONFIG_EVA
-               return protected_cachee_op(Hit_Invalidate_I, addr);
-#else
                return protected_cache_op(Hit_Invalidate_I, addr);
-#endif
        }
 }
 
  */
 static inline int protected_writeback_dcache_line(unsigned long addr)
 {
-#ifdef CONFIG_EVA
-       return protected_cachee_op(Hit_Writeback_Inv_D, addr);
-#else
        return protected_cache_op(Hit_Writeback_Inv_D, addr);
-#endif
 }
 
 static inline int protected_writeback_scache_line(unsigned long addr)
 {
-#ifdef CONFIG_EVA
-       return protected_cachee_op(Hit_Writeback_Inv_SD, addr);
-#else
        return protected_cache_op(Hit_Writeback_Inv_SD, addr);
-#endif
 }
 
 /*
        }                                                               \
 }
 
-#ifndef CONFIG_EVA
-
 __BUILD_BLAST_CACHE_RANGE(d, dcache, Hit_Writeback_Inv_D, protected_, )
 __BUILD_BLAST_CACHE_RANGE(i, icache, Hit_Invalidate_I, protected_, )
-
-#else
-
-#define __BUILD_PROT_BLAST_CACHE_RANGE(pfx, desc, hitop)               \
-static inline void protected_blast_##pfx##cache##_range(unsigned long start,\
-                                                       unsigned long end) \
-{                                                                      \
-       unsigned long lsize = cpu_##desc##_line_size();                 \
-       unsigned long addr = start & ~(lsize - 1);                      \
-       unsigned long aend = (end - 1) & ~(lsize - 1);                  \
-                                                                       \
-       if (!uaccess_kernel()) {                                        \
-               while (1) {                                             \
-                       protected_cachee_op(hitop, addr);               \
-                       if (addr == aend)                               \
-                               break;                                  \
-                       addr += lsize;                                  \
-               }                                                       \
-       } else {                                                        \
-               while (1) {                                             \
-                       protected_cache_op(hitop, addr);                \
-                       if (addr == aend)                               \
-                               break;                                  \
-                       addr += lsize;                                  \
-               }                                                       \
-                                                                       \
-       }                                                               \
-}
-
-__BUILD_PROT_BLAST_CACHE_RANGE(d, dcache, Hit_Writeback_Inv_D)
-__BUILD_PROT_BLAST_CACHE_RANGE(i, icache, Hit_Invalidate_I)
-
-#endif
 __BUILD_BLAST_CACHE_RANGE(s, scache, Hit_Writeback_Inv_SD, protected_, )
 __BUILD_BLAST_CACHE_RANGE(i, icache, Hit_Invalidate_I_Loongson2, \
        protected_, loongson2_)