aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86_64/lib
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/lib')
-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