blackfin: no access_ok() for __copy_{to,from}_user()
[sfrench/cifs-2.6.git] / arch / blackfin / include / asm / uaccess.h
index 12f5d6851bbcb3e28c7ba5421a849df3cabbf4fd..0eff88aa6d6ae6626ad411876aeca9ee41887ca4 100644 (file)
@@ -163,32 +163,41 @@ static inline int bad_user_access_length(void)
                : "a" (__ptr(ptr)));            \
 })
 
-#define __copy_from_user(to, from, n) copy_from_user(to, from, n)
-#define __copy_to_user(to, from, n) copy_to_user(to, from, n)
 #define __copy_to_user_inatomic __copy_to_user
 #define __copy_from_user_inatomic __copy_from_user
 
 static inline unsigned long __must_check
-copy_from_user(void *to, const void __user *from, unsigned long n)
+__copy_from_user(void *to, const void __user *from, unsigned long n)
 {
-       if (access_ok(VERIFY_READ, from, n))
-               memcpy(to, (const void __force *)from, n);
-       else
-               return n;
+       memcpy(to, (const void __force *)from, n);
        return 0;
 }
 
 static inline unsigned long __must_check
-copy_to_user(void __user *to, const void *from, unsigned long n)
+__copy_to_user(void __user *to, const void *from, unsigned long n)
 {
-       if (access_ok(VERIFY_WRITE, to, n))
-               memcpy((void __force *)to, from, n);
-       else
-               return n;
+       memcpy((void __force *)to, from, n);
        SSYNC();
        return 0;
 }
 
+static inline unsigned long __must_check
+copy_from_user(void *to, const void __user *from, unsigned long n)
+{
+       if (likely(access_ok(VERIFY_READ, from, n)))
+               return __copy_from_user(to, from, n);
+       memset(to, 0, n);
+       return n;
+}
+
+static inline unsigned long __must_check
+copy_to_user(void __user *to, const void *from, unsigned long n)
+{
+       if (likely(access_ok(VERIFY_WRITE, to, n)))
+               return __copy_to_user(to, from, n);
+       return n;
+}
+
 /*
  * Copy a null terminated string from userspace.
  */