static inline int
 valid_user_frame(const void __user *fp, unsigned long size)
 {
-       return (__range_not_ok(fp, size, TASK_SIZE) == 0);
+       return __access_ok(fp, size);
 }
 
 static unsigned long get_segment_base(unsigned int segment)
 
  * Test whether a block of memory is a valid user space address.
  * Returns 0 if the range is valid, nonzero otherwise.
  */
-static inline bool __chk_range_not_ok(unsigned long addr, unsigned long size, unsigned long limit)
+static inline bool __chk_range_not_ok(unsigned long addr, unsigned long size)
 {
+       unsigned long limit = TASK_SIZE_MAX;
+
        /*
         * If we have used "sizeof()" for the size,
         * we know it won't overflow the limit (but
        return unlikely(addr > limit);
 }
 
-#define __range_not_ok(addr, size, limit)                              \
+#define __access_ok(addr, size)                                                \
 ({                                                                     \
        __chk_user_ptr(addr);                                           \
-       __chk_range_not_ok((unsigned long __force)(addr), size, limit); \
+       !__chk_range_not_ok((unsigned long __force)(addr), size);       \
 })
 
 #ifdef CONFIG_DEBUG_ATOMIC_SLEEP
 #define access_ok(addr, size)                                  \
 ({                                                                     \
        WARN_ON_IN_IRQ();                                               \
-       likely(!__range_not_ok(addr, size, TASK_SIZE_MAX));             \
+       likely(__access_ok(addr, size));                                \
 })
 
 extern int __get_user_1(void);
 
        /* The user space code from other tasks cannot be accessed. */
        if (regs != task_pt_regs(current))
                return -EPERM;
-       /*
-        * Make sure userspace isn't trying to trick us into dumping kernel
-        * memory by pointing the userspace instruction pointer at it.
-        */
-       if (__chk_range_not_ok(src, nbytes, TASK_SIZE_MAX))
-               return -EINVAL;
 
        /*
         * Even if named copy_from_user_nmi() this can be invoked from