x86: don't always use EFAULT on __get_user_size.
authorGlauber Costa <gcosta@redhat.com>
Wed, 25 Jun 2008 14:57:33 +0000 (11:57 -0300)
committerIngo Molnar <mingo@elte.hu>
Wed, 9 Jul 2008 07:14:23 +0000 (09:14 +0200)
Let the user of the macro specify the desired return.

Signed-off-by: Glauber Costa <gcosta@redhat.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
include/asm-x86/uaccess_64.h

index 42c01aa70e7284f5ab8d8410dec75f2e421d3ffa..e0875d7ae8988296e179231e566640a7140c9cd0 100644 (file)
@@ -61,27 +61,27 @@ extern void __put_user_bad(void);
 ({                                                             \
        int __gu_err;                                           \
        unsigned long __gu_val;                                 \
-       __get_user_size(__gu_val, (ptr), (size), __gu_err);     \
+       __get_user_size(__gu_val, (ptr), (size), __gu_err, -EFAULT);\
        (x) = (__force typeof(*(ptr)))__gu_val;                 \
        __gu_err;                                               \
 })
 
-#define __get_user_size(x, ptr, size, retval)                          \
+#define __get_user_size(x, ptr, size, retval, errret)                  \
 do {                                                                   \
        retval = 0;                                                     \
        __chk_user_ptr(ptr);                                            \
        switch (size) {                                                 \
        case 1:                                                         \
-               __get_user_asm(x, ptr, retval, "b", "b", "=q", -EFAULT);\
+               __get_user_asm(x, ptr, retval, "b", "b", "=q", errret);\
                break;                                                  \
        case 2:                                                         \
-               __get_user_asm(x, ptr, retval, "w", "w", "=r", -EFAULT);\
+               __get_user_asm(x, ptr, retval, "w", "w", "=r", errret);\
                break;                                                  \
        case 4:                                                         \
-               __get_user_asm(x, ptr, retval, "l", "k", "=r", -EFAULT);\
+               __get_user_asm(x, ptr, retval, "l", "k", "=r", errret);\
                break;                                                  \
        case 8:                                                         \
-               __get_user_asm(x, ptr, retval, "q", "", "=r", -EFAULT); \
+               __get_user_asm(x, ptr, retval, "q", "", "=r", errret);  \
                break;                                                  \
        default:                                                        \
                (x) = __get_user_bad();                                 \