projects
/
firefly-linux-kernel-4.4.55.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
3123574
)
parisc: fix copy_from_user()
author
Al Viro
<viro@zeniv.linux.org.uk>
Sat, 20 Aug 2016 23:03:37 +0000
(19:03 -0400)
committer
Greg Kroah-Hartman
<gregkh@linuxfoundation.org>
Sat, 24 Sep 2016 08:07:45 +0000
(10:07 +0200)
commit
aace880feea38875fbc919761b77e5732a3659ef
upstream.
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/parisc/include/asm/uaccess.h
patch
|
blob
|
history
diff --git
a/arch/parisc/include/asm/uaccess.h
b/arch/parisc/include/asm/uaccess.h
index 1960b87c1c8becb9796babc5c77e4452472b6e37..4ad51465890bdcc35b75c055a21a9dd616f96a1f 100644
(file)
--- a/
arch/parisc/include/asm/uaccess.h
+++ b/
arch/parisc/include/asm/uaccess.h
@@
-10,6
+10,7
@@
#include <asm-generic/uaccess-unaligned.h>
#include <linux/bug.h>
+#include <linux/string.h>
#define VERIFY_READ 0
#define VERIFY_WRITE 1
@@
-245,13
+246,14
@@
static inline unsigned long __must_check copy_from_user(void *to,
unsigned long n)
{
int sz = __compiletime_object_size(to);
-
int ret = -EFAULT
;
+
unsigned long ret = n
;
if (likely(sz == -1 || !__builtin_constant_p(n) || sz >= n))
ret = __copy_from_user(to, from, n);
else
copy_from_user_overflow();
-
+ if (unlikely(ret))
+ memset(to + (n - ret), 0, ret);
return ret;
}