aboutsummaryrefslogtreecommitdiffstats
path: root/include
diff options
context:
space:
mode:
authorGlauber Costa <gcosta@redhat.com>2008-06-25 09:14:13 -0400
committerIngo Molnar <mingo@elte.hu>2008-07-09 03:14:13 -0400
commit53938a68a2f971058bc53aaa8c70f9f24f684cdc (patch)
tree773fad2d90dabfda1572d4990c041e6331d93722 /include
parent5cbbc3b1eb37bdc72eefd2de03b39f5e784400c2 (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')
-rw-r--r--include/asm-x86/uaccess_32.h6
-rw-r--r--include/asm-x86/uaccess_64.h3
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)); \