aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86_64
diff options
context:
space:
mode:
authorAlexander Nyberg <alexn@telia.com>2005-04-21 10:59:51 -0400
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-04-21 10:59:51 -0400
commit3a6fd752a50af92765853879f4a11cc0cfcd0320 (patch)
treedc79d50fb8d8c74259945b8a044f93982a9289bd /arch/x86_64
parent6d9c5d94d39a09d9b112613f0bfdb9af0e6dc253 (diff)
[PATCH] x86_64: Bug in new out of line put_user()
The new out of line put_user() assembly on x86_64 changes %rcx without telling GCC about it causing things like: http://bugme.osdl.org/show_bug.cgi?id=4515 See to it that %rcx is not changed (made it consistent with get_user()). Signed-off-by: Alexander Nyberg <alexn@telia.com> Signed-off-by: ak@suse.de Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch/x86_64')
-rw-r--r--arch/x86_64/lib/getuser.S4
-rw-r--r--arch/x86_64/lib/putuser.S27
2 files changed, 20 insertions, 11 deletions
diff --git a/arch/x86_64/lib/getuser.S b/arch/x86_64/lib/getuser.S
index f94ea8a44051..f80bafee8669 100644
--- a/arch/x86_64/lib/getuser.S
+++ b/arch/x86_64/lib/getuser.S
@@ -78,9 +78,9 @@ __get_user_4:
78__get_user_8: 78__get_user_8:
79 GET_THREAD_INFO(%r8) 79 GET_THREAD_INFO(%r8)
80 addq $7,%rcx 80 addq $7,%rcx
81 jc bad_get_user 81 jc 40f
82 cmpq threadinfo_addr_limit(%r8),%rcx 82 cmpq threadinfo_addr_limit(%r8),%rcx
83 jae bad_get_user 83 jae 40f
84 subq $7,%rcx 84 subq $7,%rcx
854: movq (%rcx),%rdx 854: movq (%rcx),%rdx
86 xorl %eax,%eax 86 xorl %eax,%eax
diff --git a/arch/x86_64/lib/putuser.S b/arch/x86_64/lib/putuser.S
index 0dee1fdcb162..d9d3e5ec9ad1 100644
--- a/arch/x86_64/lib/putuser.S
+++ b/arch/x86_64/lib/putuser.S
@@ -46,36 +46,45 @@ __put_user_1:
46__put_user_2: 46__put_user_2:
47 GET_THREAD_INFO(%r8) 47 GET_THREAD_INFO(%r8)
48 addq $1,%rcx 48 addq $1,%rcx
49 jc bad_put_user 49 jc 20f
50 cmpq threadinfo_addr_limit(%r8),%rcx 50 cmpq threadinfo_addr_limit(%r8),%rcx
51 jae bad_put_user 51 jae 20f
522: movw %dx,-1(%rcx) 522: decq %rcx
53 movw %dx,(%rcx)
53 xorl %eax,%eax 54 xorl %eax,%eax
54 ret 55 ret
5620: decq %rcx
57 jmp bad_put_user
55 58
56 .p2align 4 59 .p2align 4
57.globl __put_user_4 60.globl __put_user_4
58__put_user_4: 61__put_user_4:
59 GET_THREAD_INFO(%r8) 62 GET_THREAD_INFO(%r8)
60 addq $3,%rcx 63 addq $3,%rcx
61 jc bad_put_user 64 jc 30f
62 cmpq threadinfo_addr_limit(%r8),%rcx 65 cmpq threadinfo_addr_limit(%r8),%rcx
63 jae bad_put_user 66 jae 30f
643: movl %edx,-3(%rcx) 673: subq $3,%rcx
68 movl %edx,(%rcx)
65 xorl %eax,%eax 69 xorl %eax,%eax
66 ret 70 ret
7130: subq $3,%rcx
72 jmp bad_put_user
67 73
68 .p2align 4 74 .p2align 4
69.globl __put_user_8 75.globl __put_user_8
70__put_user_8: 76__put_user_8:
71 GET_THREAD_INFO(%r8) 77 GET_THREAD_INFO(%r8)
72 addq $7,%rcx 78 addq $7,%rcx
73 jc bad_put_user 79 jc 40f
74 cmpq threadinfo_addr_limit(%r8),%rcx 80 cmpq threadinfo_addr_limit(%r8),%rcx
75 jae bad_put_user 81 jae 40f
764: movq %rdx,-7(%rcx) 824: subq $7,%rcx
83 movq %rdx,(%rcx)
77 xorl %eax,%eax 84 xorl %eax,%eax
78 ret 85 ret
8640: subq $7,%rcx
87 jmp bad_put_user
79 88
80bad_put_user: 89bad_put_user:
81 movq $(-EFAULT),%rax 90 movq $(-EFAULT),%rax