1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * Copyright (C) 2012 Regents of the University of California
5 * This file was copied from include/asm-generic/uaccess.h
8 #ifndef _ASM_RISCV_UACCESS_H
9 #define _ASM_RISCV_UACCESS_H
11 #include <asm/asm-extable.h>
12 #include <asm/cpufeature.h>
13 #include <asm/pgtable.h> /* for TASK_SIZE */
15 #ifdef CONFIG_RISCV_ISA_SUPM
16 static inline unsigned long __untagged_addr_remote(struct mm_struct
*mm
, unsigned long addr
)
18 if (riscv_has_extension_unlikely(RISCV_ISA_EXT_SUPM
)) {
19 u8 pmlen
= mm
->context
.pmlen
;
21 /* Virtual addresses are sign-extended; physical addresses are zero-extended. */
22 if (IS_ENABLED(CONFIG_MMU
))
23 return (long)(addr
<< pmlen
) >> pmlen
;
25 return (addr
<< pmlen
) >> pmlen
;
31 #define untagged_addr(addr) ({ \
32 unsigned long __addr = (__force unsigned long)(addr); \
33 (__force __typeof__(addr))__untagged_addr_remote(current->mm, __addr); \
36 #define untagged_addr_remote(mm, addr) ({ \
37 unsigned long __addr = (__force unsigned long)(addr); \
38 mmap_assert_locked(mm); \
39 (__force __typeof__(addr))__untagged_addr_remote(mm, __addr); \
42 #define access_ok(addr, size) likely(__access_ok(untagged_addr(addr), size))
44 #define untagged_addr(addr) (addr)
48 * User space memory access functions
51 #include <linux/errno.h>
52 #include <linux/compiler.h>
53 #include <linux/thread_info.h>
54 #include <asm/byteorder.h>
55 #include <asm/extable.h>
57 #include <asm-generic/access_ok.h>
59 #define __enable_user_access() \
60 __asm__ __volatile__ ("csrs sstatus, %0" : : "r" (SR_SUM) : "memory")
61 #define __disable_user_access() \
62 __asm__ __volatile__ ("csrc sstatus, %0" : : "r" (SR_SUM) : "memory")
65 * The exception table consists of pairs of addresses: the first is the
66 * address of an instruction that is allowed to fault, and the second is
67 * the address at which the program should continue. No registers are
68 * modified, so it is entirely up to the continuation code to figure out
71 * All the routines below use bits of fixup code that are out of line
72 * with the main instruction path. This means when everything is well,
73 * we don't even have to jump over them. Further, they do not intrude
74 * on our cache or tlb entries.
81 * The "__xxx" versions of the user access functions do not verify the address
82 * space - it must have been done previously with a separate "access_ok()"
86 #define __get_user_asm(insn, x, ptr, err) \
89 __asm__ __volatile__ ( \
91 " " insn " %1, %2\n" \
93 _ASM_EXTABLE_UACCESS_ERR_ZERO(1b, 2b, %0, %1) \
94 : "+r" (err), "=&r" (__x) \
100 #define __get_user_8(x, ptr, err) \
101 __get_user_asm("ld", x, ptr, err)
102 #else /* !CONFIG_64BIT */
103 #define __get_user_8(x, ptr, err) \
105 u32 __user *__ptr = (u32 __user *)(ptr); \
107 __asm__ __volatile__ ( \
113 _ASM_EXTABLE_UACCESS_ERR_ZERO(1b, 3b, %0, %1) \
114 _ASM_EXTABLE_UACCESS_ERR_ZERO(2b, 3b, %0, %1) \
115 : "+r" (err), "=&r" (__lo), "=r" (__hi) \
116 : "m" (__ptr[__LSW]), "m" (__ptr[__MSW])); \
119 (x) = (__typeof__(x))((__typeof__((x)-(x)))( \
120 (((u64)__hi << 32) | __lo))); \
122 #endif /* CONFIG_64BIT */
124 #define __get_user_nocheck(x, __gu_ptr, __gu_err) \
126 switch (sizeof(*__gu_ptr)) { \
128 __get_user_asm("lb", (x), __gu_ptr, __gu_err); \
131 __get_user_asm("lh", (x), __gu_ptr, __gu_err); \
134 __get_user_asm("lw", (x), __gu_ptr, __gu_err); \
137 __get_user_8((x), __gu_ptr, __gu_err); \
145 * __get_user: - Get a simple variable from user space, with less checking.
146 * @x: Variable to store result.
147 * @ptr: Source address, in user space.
149 * Context: User context only. This function may sleep.
151 * This macro copies a single simple variable from user space to kernel
152 * space. It supports simple types like char and int, but not larger
153 * data types like structures or arrays.
155 * @ptr must have pointer-to-simple-variable type, and the result of
156 * dereferencing @ptr must be assignable to @x without a cast.
158 * Caller must check the pointer with access_ok() before calling this
161 * Returns zero on success, or -EFAULT on error.
162 * On error, the variable @x is set to zero.
164 #define __get_user(x, ptr) \
166 const __typeof__(*(ptr)) __user *__gu_ptr = untagged_addr(ptr); \
169 __chk_user_ptr(__gu_ptr); \
171 __enable_user_access(); \
172 __get_user_nocheck(x, __gu_ptr, __gu_err); \
173 __disable_user_access(); \
179 * get_user: - Get a simple variable from user space.
180 * @x: Variable to store result.
181 * @ptr: Source address, in user space.
183 * Context: User context only. This function may sleep.
185 * This macro copies a single simple variable from user space to kernel
186 * space. It supports simple types like char and int, but not larger
187 * data types like structures or arrays.
189 * @ptr must have pointer-to-simple-variable type, and the result of
190 * dereferencing @ptr must be assignable to @x without a cast.
192 * Returns zero on success, or -EFAULT on error.
193 * On error, the variable @x is set to zero.
195 #define get_user(x, ptr) \
197 const __typeof__(*(ptr)) __user *__p = (ptr); \
199 access_ok(__p, sizeof(*__p)) ? \
200 __get_user((x), __p) : \
201 ((x) = (__force __typeof__(x))0, -EFAULT); \
204 #define __put_user_asm(insn, x, ptr, err) \
206 __typeof__(*(ptr)) __x = x; \
207 __asm__ __volatile__ ( \
209 " " insn " %z2, %1\n" \
211 _ASM_EXTABLE_UACCESS_ERR(1b, 2b, %0) \
212 : "+r" (err), "=m" (*(ptr)) \
217 #define __put_user_8(x, ptr, err) \
218 __put_user_asm("sd", x, ptr, err)
219 #else /* !CONFIG_64BIT */
220 #define __put_user_8(x, ptr, err) \
222 u32 __user *__ptr = (u32 __user *)(ptr); \
223 u64 __x = (__typeof__((x)-(x)))(x); \
224 __asm__ __volatile__ ( \
230 _ASM_EXTABLE_UACCESS_ERR(1b, 3b, %0) \
231 _ASM_EXTABLE_UACCESS_ERR(2b, 3b, %0) \
233 "=m" (__ptr[__LSW]), \
234 "=m" (__ptr[__MSW]) \
235 : "rJ" (__x), "rJ" (__x >> 32)); \
237 #endif /* CONFIG_64BIT */
239 #define __put_user_nocheck(x, __gu_ptr, __pu_err) \
241 switch (sizeof(*__gu_ptr)) { \
243 __put_user_asm("sb", (x), __gu_ptr, __pu_err); \
246 __put_user_asm("sh", (x), __gu_ptr, __pu_err); \
249 __put_user_asm("sw", (x), __gu_ptr, __pu_err); \
252 __put_user_8((x), __gu_ptr, __pu_err); \
260 * __put_user: - Write a simple value into user space, with less checking.
261 * @x: Value to copy to user space.
262 * @ptr: Destination address, in user space.
264 * Context: User context only. This function may sleep.
266 * This macro copies a single simple value from kernel space to user
267 * space. It supports simple types like char and int, but not larger
268 * data types like structures or arrays.
270 * @ptr must have pointer-to-simple-variable type, and @x must be assignable
271 * to the result of dereferencing @ptr. The value of @x is copied to avoid
272 * re-ordering where @x is evaluated inside the block that enables user-space
273 * access (thus bypassing user space protection if @x is a function).
275 * Caller must check the pointer with access_ok() before calling this
278 * Returns zero on success, or -EFAULT on error.
280 #define __put_user(x, ptr) \
282 __typeof__(*(ptr)) __user *__gu_ptr = untagged_addr(ptr); \
283 __typeof__(*__gu_ptr) __val = (x); \
286 __chk_user_ptr(__gu_ptr); \
288 __enable_user_access(); \
289 __put_user_nocheck(__val, __gu_ptr, __pu_err); \
290 __disable_user_access(); \
296 * put_user: - Write a simple value into user space.
297 * @x: Value to copy to user space.
298 * @ptr: Destination address, in user space.
300 * Context: User context only. This function may sleep.
302 * This macro copies a single simple value from kernel space to user
303 * space. It supports simple types like char and int, but not larger
304 * data types like structures or arrays.
306 * @ptr must have pointer-to-simple-variable type, and @x must be assignable
307 * to the result of dereferencing @ptr.
309 * Returns zero on success, or -EFAULT on error.
311 #define put_user(x, ptr) \
313 __typeof__(*(ptr)) __user *__p = (ptr); \
315 access_ok(__p, sizeof(*__p)) ? \
316 __put_user((x), __p) : \
321 unsigned long __must_check
__asm_copy_to_user(void __user
*to
,
322 const void *from
, unsigned long n
);
323 unsigned long __must_check
__asm_copy_from_user(void *to
,
324 const void __user
*from
, unsigned long n
);
326 static inline unsigned long
327 raw_copy_from_user(void *to
, const void __user
*from
, unsigned long n
)
329 return __asm_copy_from_user(to
, untagged_addr(from
), n
);
332 static inline unsigned long
333 raw_copy_to_user(void __user
*to
, const void *from
, unsigned long n
)
335 return __asm_copy_to_user(untagged_addr(to
), from
, n
);
338 extern long strncpy_from_user(char *dest
, const char __user
*src
, long count
);
340 extern long __must_check
strnlen_user(const char __user
*str
, long n
);
343 unsigned long __must_check
__clear_user(void __user
*addr
, unsigned long n
);
346 unsigned long __must_check
clear_user(void __user
*to
, unsigned long n
)
349 return access_ok(to
, n
) ?
350 __clear_user(untagged_addr(to
), n
) : n
;
353 #define __get_kernel_nofault(dst, src, type, err_label) \
357 __get_user_nocheck(*((type *)(dst)), (type *)(src), __kr_err); \
358 if (unlikely(__kr_err)) \
362 #define __put_kernel_nofault(dst, src, type, err_label) \
366 __put_user_nocheck(*((type *)(src)), (type *)(dst), __kr_err); \
367 if (unlikely(__kr_err)) \
371 #else /* CONFIG_MMU */
372 #include <asm-generic/uaccess.h>
373 #endif /* CONFIG_MMU */
374 #endif /* _ASM_RISCV_UACCESS_H */