Skip to content

Commit

Permalink
arm64: don't zero in __copy_from_user{,_inatomic}
Browse files Browse the repository at this point in the history
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
  • Loading branch information
Al Viro committed Sep 15, 2016
1 parent 9134449 commit 4855bd2
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 10 deletions.
10 changes: 6 additions & 4 deletions arch/arm64/include/asm/uaccess.h
Original file line number Diff line number Diff line change
Expand Up @@ -278,14 +278,16 @@ static inline unsigned long __must_check __copy_to_user(void __user *to, const v

static inline unsigned long __must_check copy_from_user(void *to, const void __user *from, unsigned long n)
{
unsigned long res = n;
kasan_check_write(to, n);

if (access_ok(VERIFY_READ, from, n)) {
check_object_size(to, n, false);
n = __arch_copy_from_user(to, from, n);
} else /* security hole - plug it */
memset(to, 0, n);
return n;
res = __arch_copy_from_user(to, from, n);
}
if (unlikely(res))
memset(to + (n - res), 0, res);
return res;
}

static inline unsigned long __must_check copy_to_user(void __user *to, const void *from, unsigned long n)
Expand Down
7 changes: 1 addition & 6 deletions arch/arm64/lib/copy_from_user.S
Original file line number Diff line number Diff line change
Expand Up @@ -79,11 +79,6 @@ ENDPROC(__arch_copy_from_user)

.section .fixup,"ax"
.align 2
9998:
sub x0, end, dst
9999:
strb wzr, [dst], #1 // zero remaining buffer space
cmp dst, end
b.lo 9999b
9998: sub x0, end, dst // bytes not copied
ret
.previous

0 comments on commit 4855bd2

Please sign in to comment.