X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=arch%2Fmicroblaze%2Finclude%2Fasm%2Fuaccess.h;h=826676778094f23a8ced8264b5c448184c0fa006;hb=e98b9e37ae04562d52c96f46b3cf4c2e80222dc1;hp=331b0d35f89ce301ad9ba876be7322f417d7c909;hpb=4ad79562577a3936b08365260f86eeb83156479f;p=linux-2.6-block.git diff --git a/arch/microblaze/include/asm/uaccess.h b/arch/microblaze/include/asm/uaccess.h index 331b0d35f89c..826676778094 100644 --- a/arch/microblaze/include/asm/uaccess.h +++ b/arch/microblaze/include/asm/uaccess.h @@ -227,7 +227,7 @@ extern long __user_bad(void); #define __get_user(x, ptr) \ ({ \ - unsigned long __gu_val; \ + unsigned long __gu_val = 0; \ /*unsigned long __gu_ptr = (unsigned long)(ptr);*/ \ long __gu_err; \ switch (sizeof(*(ptr))) { \ @@ -373,10 +373,13 @@ extern long __user_bad(void); static inline long copy_from_user(void *to, const void __user *from, unsigned long n) { + unsigned long res = n; might_fault(); - if (access_ok(VERIFY_READ, from, n)) - return __copy_from_user(to, from, n); - return n; + if (likely(access_ok(VERIFY_READ, from, n))) + res = __copy_from_user(to, from, n); + if (unlikely(res)) + memset(to + (n - res), 0, res); + return res; } #define __copy_to_user(to, from, n) \