diff options
author | Glauber Costa <gcosta@redhat.com> | 2008-06-24 14:03:40 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-09 03:14:08 -0400 |
commit | 770546b99fb99e71a3aa4181980d42664f9c18bd (patch) | |
tree | 46339e76339c08a4ab0513840af18ef42f5b178a | |
parent | 70706e432ee5618abf59381101d8dea7b8d97a7d (diff) |
x86: clobber rbx in putuser_64.S.
Instead of clobbering r8, clobber rbx, which is the i386 way.
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>
-rw-r--r-- | arch/x86/lib/putuser_64.S | 18 | ||||
-rw-r--r-- | include/asm-x86/uaccess_64.h | 2 |
2 files changed, 10 insertions, 10 deletions
diff --git a/arch/x86/lib/putuser_64.S b/arch/x86/lib/putuser_64.S index 940796fa0d98..07028851064c 100644 --- a/arch/x86/lib/putuser_64.S +++ b/arch/x86/lib/putuser_64.S | |||
@@ -18,7 +18,7 @@ | |||
18 | * | 18 | * |
19 | * Outputs: %rax is error code (0 or -EFAULT) | 19 | * Outputs: %rax is error code (0 or -EFAULT) |
20 | * | 20 | * |
21 | * %r8 is destroyed. | 21 | * %rbx is destroyed. |
22 | * | 22 | * |
23 | * These functions should not modify any other registers, | 23 | * These functions should not modify any other registers, |
24 | * as they get called from within inline assembly. | 24 | * as they get called from within inline assembly. |
@@ -34,8 +34,8 @@ | |||
34 | .text | 34 | .text |
35 | ENTRY(__put_user_1) | 35 | ENTRY(__put_user_1) |
36 | CFI_STARTPROC | 36 | CFI_STARTPROC |
37 | GET_THREAD_INFO(%r8) | 37 | GET_THREAD_INFO(%rbx) |
38 | cmpq TI_addr_limit(%r8),%rcx | 38 | cmpq TI_addr_limit(%rbx),%rcx |
39 | jae bad_put_user | 39 | jae bad_put_user |
40 | 1: movb %dl,(%rcx) | 40 | 1: movb %dl,(%rcx) |
41 | xorl %eax,%eax | 41 | xorl %eax,%eax |
@@ -45,10 +45,10 @@ ENDPROC(__put_user_1) | |||
45 | 45 | ||
46 | ENTRY(__put_user_2) | 46 | ENTRY(__put_user_2) |
47 | CFI_STARTPROC | 47 | CFI_STARTPROC |
48 | GET_THREAD_INFO(%r8) | 48 | GET_THREAD_INFO(%rbx) |
49 | addq $1,%rcx | 49 | addq $1,%rcx |
50 | jc 20f | 50 | jc 20f |
51 | cmpq TI_addr_limit(%r8),%rcx | 51 | cmpq TI_addr_limit(%rbx),%rcx |
52 | jae 20f | 52 | jae 20f |
53 | decq %rcx | 53 | decq %rcx |
54 | 2: movw %dx,(%rcx) | 54 | 2: movw %dx,(%rcx) |
@@ -61,10 +61,10 @@ ENDPROC(__put_user_2) | |||
61 | 61 | ||
62 | ENTRY(__put_user_4) | 62 | ENTRY(__put_user_4) |
63 | CFI_STARTPROC | 63 | CFI_STARTPROC |
64 | GET_THREAD_INFO(%r8) | 64 | GET_THREAD_INFO(%rbx) |
65 | addq $3,%rcx | 65 | addq $3,%rcx |
66 | jc 30f | 66 | jc 30f |
67 | cmpq TI_addr_limit(%r8),%rcx | 67 | cmpq TI_addr_limit(%rbx),%rcx |
68 | jae 30f | 68 | jae 30f |
69 | subq $3,%rcx | 69 | subq $3,%rcx |
70 | 3: movl %edx,(%rcx) | 70 | 3: movl %edx,(%rcx) |
@@ -77,10 +77,10 @@ ENDPROC(__put_user_4) | |||
77 | 77 | ||
78 | ENTRY(__put_user_8) | 78 | ENTRY(__put_user_8) |
79 | CFI_STARTPROC | 79 | CFI_STARTPROC |
80 | GET_THREAD_INFO(%r8) | 80 | GET_THREAD_INFO(%rbx) |
81 | addq $7,%rcx | 81 | addq $7,%rcx |
82 | jc 40f | 82 | jc 40f |
83 | cmpq TI_addr_limit(%r8),%rcx | 83 | cmpq TI_addr_limit(%rbx),%rcx |
84 | jae 40f | 84 | jae 40f |
85 | subq $7,%rcx | 85 | subq $7,%rcx |
86 | 4: movq %rdx,(%rcx) | 86 | 4: movq %rdx,(%rcx) |
diff --git a/include/asm-x86/uaccess_64.h b/include/asm-x86/uaccess_64.h index a2d49078e19c..21fda9ebee13 100644 --- a/include/asm-x86/uaccess_64.h +++ b/include/asm-x86/uaccess_64.h | |||
@@ -131,7 +131,7 @@ extern void __put_user_bad(void); | |||
131 | asm volatile("call __put_user_" #size \ | 131 | asm volatile("call __put_user_" #size \ |
132 | :"=a" (ret) \ | 132 | :"=a" (ret) \ |
133 | :"c" (ptr),"d" (x) \ | 133 | :"c" (ptr),"d" (x) \ |
134 | :"r8") | 134 | :"ebx") |
135 | 135 | ||
136 | #define put_user(x, ptr) \ | 136 | #define put_user(x, ptr) \ |
137 | __put_user_check((__typeof__(*(ptr)))(x), (ptr), sizeof(*(ptr))) | 137 | __put_user_check((__typeof__(*(ptr)))(x), (ptr), sizeof(*(ptr))) |