parisc: switch to RAW_COPY_USER
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 25 Mar 2017 03:11:26 +0000 (23:11 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Sun, 2 Apr 2017 16:07:21 +0000 (12:07 -0400)
... and remove dead declarations, while we are at it

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
arch/parisc/Kconfig
arch/parisc/include/asm/uaccess.h
arch/parisc/lib/memcpy.c

index ad294b3fb90be4bb4e4a800fdd50354e7a5e970c..15b7b279a1692f9acd9d60b2d90ede0679d75dd8 100644 (file)
@@ -41,6 +41,7 @@ config PARISC
        select GENERIC_CLOCKEVENTS
        select ARCH_NO_COHERENT_DMA_MMAP
        select CPU_NO_EFFICIENT_FFS
+       select ARCH_HAS_RAW_COPY_USER
 
        help
          The PA-RISC microprocessor is designed by Hewlett-Packard and used
index cbb0aaca8d391d3961a283a9d39c7a6d4b650f38..852322f2d1f9987777026622f5dc7ef6063ad959 100644 (file)
@@ -187,9 +187,6 @@ struct exception_data {
  * Complex access routines -- external declarations
  */
 
-extern unsigned long lcopy_to_user(void __user *, const void *, unsigned long);
-extern unsigned long lcopy_from_user(void *, const void __user *, unsigned long);
-extern unsigned long lcopy_in_user(void __user *, const void __user *, unsigned long);
 extern long strncpy_from_user(char *, const char __user *, long);
 extern unsigned lclear_user(void __user *, unsigned long);
 extern long lstrnlen_user(const char __user *, long);
@@ -203,59 +200,14 @@ extern long lstrnlen_user(const char __user *, long);
 #define clear_user lclear_user
 #define __clear_user lclear_user
 
-unsigned long __must_check __copy_to_user(void __user *dst, const void *src,
-                                         unsigned long len);
-unsigned long __must_check __copy_from_user(void *dst, const void __user *src,
-                                         unsigned long len);
-unsigned long copy_in_user(void __user *dst, const void __user *src,
-                          unsigned long len);
-#define __copy_in_user copy_in_user
-#define __copy_to_user_inatomic __copy_to_user
-#define __copy_from_user_inatomic __copy_from_user
-
-extern void __compiletime_error("usercopy buffer size is too small")
-__bad_copy_user(void);
-
-static inline void copy_user_overflow(int size, unsigned long count)
-{
-       WARN(1, "Buffer overflow detected (%d < %lu)!\n", size, count);
-}
-
-static __always_inline unsigned long __must_check
-copy_from_user(void *to, const void __user *from, unsigned long n)
-{
-       int sz = __compiletime_object_size(to);
-       unsigned long ret = n;
-
-       if (likely(sz < 0 || sz >= n)) {
-               check_object_size(to, n, false);
-               ret = __copy_from_user(to, from, n);
-       } else if (!__builtin_constant_p(n))
-               copy_user_overflow(sz, n);
-       else
-               __bad_copy_user();
-
-       if (unlikely(ret))
-               memset(to + (n - ret), 0, ret);
-
-       return ret;
-}
-
-static __always_inline unsigned long __must_check
-copy_to_user(void __user *to, const void *from, unsigned long n)
-{
-       int sz = __compiletime_object_size(from);
-
-       if (likely(sz < 0 || sz >= n)) {
-               check_object_size(from, n, true);
-               n = __copy_to_user(to, from, n);
-       } else if (!__builtin_constant_p(n))
-               copy_user_overflow(sz, n);
-       else
-               __bad_copy_user();
-
-       return n;
-}
+unsigned long __must_check raw_copy_to_user(void __user *dst, const void *src,
+                                           unsigned long len);
+unsigned long __must_check raw_copy_from_user(void *dst, const void __user *src,
+                                           unsigned long len);
+unsigned long __must_check raw_copy_in_user(void __user *dst, const void __user *src,
+                                           unsigned long len);
+#define INLINE_COPY_TO_USER
+#define INLINE_COPY_FROM_USER
 
 struct pt_regs;
 int fixup_exception(struct pt_regs *regs);
index e88e4a5572dc52a85bea42158201b48864fffbf8..99115cd9e790b00a19e87161a2bbc89f8f4aee58 100644 (file)
@@ -36,25 +36,25 @@ DECLARE_PER_CPU(struct exception_data, exception_data);
 extern unsigned long pa_memcpy(void *dst, const void *src,
                                unsigned long len);
 
-unsigned long __copy_to_user(void __user *dst, const void *src,
-                            unsigned long len)
+unsigned long raw_copy_to_user(void __user *dst, const void *src,
+                              unsigned long len)
 {
        mtsp(get_kernel_space(), 1);
        mtsp(get_user_space(), 2);
        return pa_memcpy((void __force *)dst, src, len);
 }
-EXPORT_SYMBOL(__copy_to_user);
+EXPORT_SYMBOL(raw_copy_to_user);
 
-unsigned long __copy_from_user(void *dst, const void __user *src,
+unsigned long raw_copy_from_user(void *dst, const void __user *src,
                               unsigned long len)
 {
        mtsp(get_user_space(), 1);
        mtsp(get_kernel_space(), 2);
        return pa_memcpy(dst, (void __force *)src, len);
 }
-EXPORT_SYMBOL(__copy_from_user);
+EXPORT_SYMBOL(raw_copy_from_user);
 
-unsigned long copy_in_user(void __user *dst, const void __user *src, unsigned long len)
+unsigned long raw_copy_in_user(void __user *dst, const void __user *src, unsigned long len)
 {
        mtsp(get_user_space(), 1);
        mtsp(get_user_space(), 2);
@@ -70,7 +70,7 @@ void * memcpy(void * dst,const void *src, size_t count)
        return dst;
 }
 
-EXPORT_SYMBOL(copy_in_user);
+EXPORT_SYMBOL(raw_copy_in_user);
 EXPORT_SYMBOL(memcpy);
 
 long probe_kernel_read(void *dst, const void *src, size_t size)