diff options
author | Vitaly Mayatskikh <v.mayatskih@gmail.com> | 2008-07-02 09:48:21 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-07-09 09:51:03 -0400 |
commit | 1129585a08baf58582c0da91e572cb29e3179acf (patch) | |
tree | 8ea03668221455bdeff91f885e4458676a89633b /arch/x86/lib | |
parent | de989ef093623ab5259f885f30be699c431d4006 (diff) |
x86: introduce copy_user_handle_tail() routine
Introduce generic C routine for handling necessary tail operations after
protection fault in copy_*_user on x86.
Signed-off-by: Vitaly Mayatskikh <v.mayatskih@gmail.com>
Acked-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/lib')
-rw-r--r-- | arch/x86/lib/usercopy_64.c | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/arch/x86/lib/usercopy_64.c b/arch/x86/lib/usercopy_64.c index 0c89d1bb0287..f4df6e7c718b 100644 --- a/arch/x86/lib/usercopy_64.c +++ b/arch/x86/lib/usercopy_64.c | |||
@@ -158,3 +158,26 @@ unsigned long copy_in_user(void __user *to, const void __user *from, unsigned le | |||
158 | } | 158 | } |
159 | EXPORT_SYMBOL(copy_in_user); | 159 | EXPORT_SYMBOL(copy_in_user); |
160 | 160 | ||
161 | /* | ||
162 | * Try to copy last bytes and clear the rest if needed. | ||
163 | * Since protection fault in copy_from/to_user is not a normal situation, | ||
164 | * it is not necessary to optimize tail handling. | ||
165 | */ | ||
166 | unsigned long | ||
167 | copy_user_handle_tail(char *to, char *from, unsigned len, unsigned zerorest) | ||
168 | { | ||
169 | char c; | ||
170 | unsigned zero_len; | ||
171 | |||
172 | for (; len; --len) { | ||
173 | if (__get_user_nocheck(c, from++, sizeof(char))) | ||
174 | break; | ||
175 | if (__put_user_nocheck(c, to++, sizeof(char))) | ||
176 | break; | ||
177 | } | ||
178 | |||
179 | for (c = 0, zero_len = len; zerorest && zero_len; --zero_len) | ||
180 | if (__put_user_nocheck(c, to++, sizeof(char))) | ||
181 | break; | ||
182 | return len; | ||
183 | } | ||