Skip to content

Commit d464118

Browse files
Christoph Hellwigpalmer-dabbelt
authored andcommitted
riscv: implement __get_kernel_nofault and __put_user_nofault
Implement the non-faulting kernel access helpers directly instead of abusing the uaccess routines under set_fs(KERNEL_DS). Signed-off-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
1 parent f289a34 commit d464118

1 file changed

Lines changed: 20 additions & 0 deletions

File tree

arch/riscv/include/asm/uaccess.h

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -486,6 +486,26 @@ unsigned long __must_check clear_user(void __user *to, unsigned long n)
486486
__ret; \
487487
})
488488

489+
#define HAVE_GET_KERNEL_NOFAULT
490+
491+
#define __get_kernel_nofault(dst, src, type, err_label) \
492+
do { \
493+
long __kr_err; \
494+
\
495+
__get_user_nocheck(*((type *)(dst)), (type *)(src), __kr_err); \
496+
if (unlikely(__kr_err)) \
497+
goto err_label; \
498+
} while (0)
499+
500+
#define __put_kernel_nofault(dst, src, type, err_label) \
501+
do { \
502+
long __kr_err; \
503+
\
504+
__put_user_nocheck(*((type *)(dst)), (type *)(src), __kr_err); \
505+
if (unlikely(__kr_err)) \
506+
goto err_label; \
507+
} while (0)
508+
489509
#else /* CONFIG_MMU */
490510
#include <asm-generic/uaccess.h>
491511
#endif /* CONFIG_MMU */

0 commit comments

Comments
 (0)