diff options
author | Alexander Nyberg <alexn@telia.com> | 2005-04-21 10:59:51 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2005-04-21 10:59:51 -0400 |
commit | 3a6fd752a50af92765853879f4a11cc0cfcd0320 (patch) | |
tree | dc79d50fb8d8c74259945b8a044f93982a9289bd /arch/x86_64 | |
parent | 6d9c5d94d39a09d9b112613f0bfdb9af0e6dc253 (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.S | 4 | ||||
-rw-r--r-- | arch/x86_64/lib/putuser.S | 27 |
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 |
85 | 4: movq (%rcx),%rdx | 85 | 4: 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 |
52 | 2: movw %dx,-1(%rcx) | 52 | 2: decq %rcx |
53 | movw %dx,(%rcx) | ||
53 | xorl %eax,%eax | 54 | xorl %eax,%eax |
54 | ret | 55 | ret |
56 | 20: 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 |
64 | 3: movl %edx,-3(%rcx) | 67 | 3: subq $3,%rcx |
68 | movl %edx,(%rcx) | ||
65 | xorl %eax,%eax | 69 | xorl %eax,%eax |
66 | ret | 70 | ret |
71 | 30: 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 |
76 | 4: movq %rdx,-7(%rcx) | 82 | 4: subq $7,%rcx |
83 | movq %rdx,(%rcx) | ||
77 | xorl %eax,%eax | 84 | xorl %eax,%eax |
78 | ret | 85 | ret |
86 | 40: subq $7,%rcx | ||
87 | jmp bad_put_user | ||
79 | 88 | ||
80 | bad_put_user: | 89 | bad_put_user: |
81 | movq $(-EFAULT),%rax | 90 | movq $(-EFAULT),%rax |