diff options
author | Glauber Costa <gcosta@redhat.com> | 2008-06-25 09:14:13 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-09 03:14:13 -0400 |
commit | 53938a68a2f971058bc53aaa8c70f9f24f684cdc (patch) | |
tree | 773fad2d90dabfda1572d4990c041e6331d93722 /include/asm-x86 | |
parent | 5cbbc3b1eb37bdc72eefd2de03b39f5e784400c2 (diff) |
x86: commonize __range_not_ok.
For i386, __range_not_ok is a better name than __range_ok, since
it returns 0 when it is in fact okay. Other than that,
both versions does not need the word size specifiers, and we remove them.
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>
Diffstat (limited to 'include/asm-x86')
-rw-r--r-- | include/asm-x86/uaccess_32.h | 6 | ||||
-rw-r--r-- | include/asm-x86/uaccess_64.h | 3 |
2 files changed, 4 insertions, 5 deletions
diff --git a/include/asm-x86/uaccess_32.h b/include/asm-x86/uaccess_32.h index f8abc12a77c2..8d3f02d3562c 100644 --- a/include/asm-x86/uaccess_32.h +++ b/include/asm-x86/uaccess_32.h | |||
@@ -56,11 +56,11 @@ extern struct movsl_mask { | |||
56 | * | 56 | * |
57 | * This needs 33-bit arithmetic. We have a carry... | 57 | * This needs 33-bit arithmetic. We have a carry... |
58 | */ | 58 | */ |
59 | #define __range_ok(addr, size) \ | 59 | #define __range_not_ok(addr, size) \ |
60 | ({ \ | 60 | ({ \ |
61 | unsigned long flag, roksum; \ | 61 | unsigned long flag, roksum; \ |
62 | __chk_user_ptr(addr); \ | 62 | __chk_user_ptr(addr); \ |
63 | asm("addl %3,%1 ; sbbl %0,%0; cmpl %1,%4; sbbl $0,%0" \ | 63 | asm("add %3,%1 ; sbb %0,%0; cmp %1,%4; sbb $0,%0" \ |
64 | :"=&r" (flag), "=r" (roksum) \ | 64 | :"=&r" (flag), "=r" (roksum) \ |
65 | :"1" (addr), "g" ((int)(size)), \ | 65 | :"1" (addr), "g" ((int)(size)), \ |
66 | "rm" (current_thread_info()->addr_limit.seg)); \ | 66 | "rm" (current_thread_info()->addr_limit.seg)); \ |
@@ -86,7 +86,7 @@ extern struct movsl_mask { | |||
86 | * checks that the pointer is in the user space range - after calling | 86 | * checks that the pointer is in the user space range - after calling |
87 | * this function, memory access functions may still return -EFAULT. | 87 | * this function, memory access functions may still return -EFAULT. |
88 | */ | 88 | */ |
89 | #define access_ok(type, addr, size) (likely(__range_ok(addr, size) == 0)) | 89 | #define access_ok(type, addr, size) (likely(__range_not_ok(addr, size) == 0)) |
90 | 90 | ||
91 | /* | 91 | /* |
92 | * The exception table consists of pairs of addresses: the first is the | 92 | * The exception table consists of pairs of addresses: the first is the |
diff --git a/include/asm-x86/uaccess_64.h b/include/asm-x86/uaccess_64.h index f822a36cc1c0..012cba3972d7 100644 --- a/include/asm-x86/uaccess_64.h +++ b/include/asm-x86/uaccess_64.h | |||
@@ -41,8 +41,7 @@ | |||
41 | ({ \ | 41 | ({ \ |
42 | unsigned long flag, roksum; \ | 42 | unsigned long flag, roksum; \ |
43 | __chk_user_ptr(addr); \ | 43 | __chk_user_ptr(addr); \ |
44 | asm("# range_ok\n\r" \ | 44 | asm("add %3,%1 ; sbb %0,%0 ; cmp %1,%4 ; sbb $0,%0" \ |
45 | "addq %3,%1 ; sbbq %0,%0 ; cmpq %1,%4 ; sbbq $0,%0" \ | ||
46 | : "=&r" (flag), "=r" (roksum) \ | 45 | : "=&r" (flag), "=r" (roksum) \ |
47 | : "1" (addr), "g" ((long)(size)), \ | 46 | : "1" (addr), "g" ((long)(size)), \ |
48 | "g" (current_thread_info()->addr_limit.seg)); \ | 47 | "g" (current_thread_info()->addr_limit.seg)); \ |