Commit 05d88a49 authored by Vineet Gupta's avatar Vineet Gupta

asm-generic: uaccess: Allow arches to over-ride __{get,put}_user_fn()

As of now these default to calling the arch provided __copy_{to,from}_user()
routines which being general purpose (w.r.t buffer alignment and lengths)
would lead to alignment checks in generated code (for arches which don't
support unaligned load/stores).

Given that in this case we already know that data involved is "unit"
sized and aligned, using the vanilla copy backend is a bit wasteful.

This change thus allows arches to over-ride the aforementioned routines.
Signed-off-by: default avatarVineet Gupta <vgupta@synopsys.com>
Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
parent 43697cb0
...@@ -169,12 +169,18 @@ static inline __must_check long __copy_to_user(void __user *to, ...@@ -169,12 +169,18 @@ static inline __must_check long __copy_to_user(void __user *to,
-EFAULT; \ -EFAULT; \
}) })
#ifndef __put_user_fn
static inline int __put_user_fn(size_t size, void __user *ptr, void *x) static inline int __put_user_fn(size_t size, void __user *ptr, void *x)
{ {
size = __copy_to_user(ptr, x, size); size = __copy_to_user(ptr, x, size);
return size ? -EFAULT : size; return size ? -EFAULT : size;
} }
#define __put_user_fn(sz, u, k) __put_user_fn(sz, u, k)
#endif
extern int __put_user_bad(void) __attribute__((noreturn)); extern int __put_user_bad(void) __attribute__((noreturn));
#define __get_user(x, ptr) \ #define __get_user(x, ptr) \
...@@ -225,12 +231,17 @@ extern int __put_user_bad(void) __attribute__((noreturn)); ...@@ -225,12 +231,17 @@ extern int __put_user_bad(void) __attribute__((noreturn));
-EFAULT; \ -EFAULT; \
}) })
#ifndef __get_user_fn
static inline int __get_user_fn(size_t size, const void __user *ptr, void *x) static inline int __get_user_fn(size_t size, const void __user *ptr, void *x)
{ {
size = __copy_from_user(x, ptr, size); size = __copy_from_user(x, ptr, size);
return size ? -EFAULT : size; return size ? -EFAULT : size;
} }
#define __get_user_fn(sz, u, k) __get_user_fn(sz, u, k)
#endif
extern int __get_user_bad(void) __attribute__((noreturn)); extern int __get_user_bad(void) __attribute__((noreturn));
#ifndef __copy_from_user_inatomic #ifndef __copy_from_user_inatomic
......
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