Commit 6cac847a authored by Dan Williams's avatar Dan Williams Committed by Juerg Haefliger

x86/uaccess: Use __uaccess_begin_nospec() and uaccess_try_nospec

BugLink: https://bugs.launchpad.net/bugs/1811080

commit 304ec1b0 upstream.

Quoting Linus:

    I do think that it would be a good idea to very expressly document
    the fact that it's not that the user access itself is unsafe. I do
    agree that things like "get_user()" want to be protected, but not
    because of any direct bugs or problems with get_user() and friends,
    but simply because get_user() is an excellent source of a pointer
    that is obviously controlled from a potentially attacking user
    space. So it's a prime candidate for then finding _subsequent_
    accesses that can then be used to perturb the cache.

__uaccess_begin_nospec() covers __get_user() and copy_from_iter() where the
limit check is far away from the user pointer de-reference. In those cases
a barrier_nospec() prevents speculation with a potential pointer to
privileged memory. uaccess_try_nospec covers get_user_try.
Suggested-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
Suggested-by: default avatarAndi Kleen <ak@linux.intel.com>
Signed-off-by: default avatarDan Williams <dan.j.williams@intel.com>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Cc: linux-arch@vger.kernel.org
Cc: Kees Cook <keescook@chromium.org>
Cc: kernel-hardening@lists.openwall.com
Cc: gregkh@linuxfoundation.org
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: alan@linux.intel.com
Link: https://lkml.kernel.org/r/151727416953.33451.10508284228526170604.stgit@dwillia2-desk3.amr.corp.intel.com
[bwh: Backported to 4.4:
 - Convert several more functions to use __uaccess_begin_nospec(), that
   are just wrappers in mainline
 - Adjust context]
Signed-off-by: default avatarBen Hutchings <ben.hutchings@codethink.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
[juergh: Converted additional functions to use __uaccess_begin_nospec(),
 that were missed in the original backport.]
Signed-off-by: default avatarJuerg Haefliger <juergh@canonical.com>
Signed-off-by: default avatarStefan Bader <stefan.bader@canonical.com>
parent 86ecc9d3
...@@ -48,25 +48,25 @@ __copy_to_user_inatomic(void __user *to, const void *from, unsigned long n) ...@@ -48,25 +48,25 @@ __copy_to_user_inatomic(void __user *to, const void *from, unsigned long n)
switch (n) { switch (n) {
case 1: case 1:
__uaccess_begin(); __uaccess_begin_nospec();
__put_user_size(*(u8 *)from, (u8 __user *)to, __put_user_size(*(u8 *)from, (u8 __user *)to,
1, ret, 1); 1, ret, 1);
__uaccess_end(); __uaccess_end();
return ret; return ret;
case 2: case 2:
__uaccess_begin(); __uaccess_begin_nospec();
__put_user_size(*(u16 *)from, (u16 __user *)to, __put_user_size(*(u16 *)from, (u16 __user *)to,
2, ret, 2); 2, ret, 2);
__uaccess_end(); __uaccess_end();
return ret; return ret;
case 4: case 4:
__uaccess_begin(); __uaccess_begin_nospec();
__put_user_size(*(u32 *)from, (u32 __user *)to, __put_user_size(*(u32 *)from, (u32 __user *)to,
4, ret, 4); 4, ret, 4);
__uaccess_end(); __uaccess_end();
return ret; return ret;
case 8: case 8:
__uaccess_begin(); __uaccess_begin_nospec();
__put_user_size(*(u64 *)from, (u64 __user *)to, __put_user_size(*(u64 *)from, (u64 __user *)to,
8, ret, 8); 8, ret, 8);
__uaccess_end(); __uaccess_end();
......
...@@ -570,7 +570,7 @@ do { \ ...@@ -570,7 +570,7 @@ do { \
unsigned long __copy_to_user_ll(void __user *to, const void *from, unsigned long __copy_to_user_ll(void __user *to, const void *from,
unsigned long n) unsigned long n)
{ {
__uaccess_begin(); __uaccess_begin_nospec();
if (movsl_is_ok(to, from, n)) if (movsl_is_ok(to, from, n))
__copy_user(to, from, n); __copy_user(to, from, n);
else else
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment