Skip to content

Commit ca0e433

Browse files
bjdooks-ctpalmer-dabbelt
authored andcommitted
riscv: fix __user annotation in traps_misaligned.c
The instruction reading code can read from either user or kernel addresses and thus the use of __user on pointers to instructions depends on which context. Fix a few sparse warnings by using __user for user-accesses and remove it when not. Fixes: arch/riscv/kernel/traps_misaligned.c:361:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:373:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:381:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:322:24: warning: incorrect type in initializer (different address spaces) arch/riscv/kernel/traps_misaligned.c:322:24: expected unsigned char const [noderef] __user *__gu_ptr arch/riscv/kernel/traps_misaligned.c:322:24: got unsigned char const [usertype] *addr arch/riscv/kernel/traps_misaligned.c:361:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:373:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:381:21: warning: dereference of noderef expression arch/riscv/kernel/traps_misaligned.c:332:24: warning: incorrect type in initializer (different address spaces) arch/riscv/kernel/traps_misaligned.c:332:24: expected unsigned char [noderef] __user *__gu_ptr arch/riscv/kernel/traps_misaligned.c:332:24: got unsigned char [usertype] *addr Fixes: 7c83232 ("riscv: add support for misaligned trap handling in S-mode") Signed-off-by: Ben Dooks <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Palmer Dabbelt <[email protected]>
1 parent cfbc4f8 commit ca0e433

File tree

1 file changed

+3
-3
lines changed

1 file changed

+3
-3
lines changed

arch/riscv/kernel/traps_misaligned.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -319,7 +319,7 @@ static inline int get_insn(struct pt_regs *regs, ulong mepc, ulong *r_insn)
319319
static inline int load_u8(struct pt_regs *regs, const u8 *addr, u8 *r_val)
320320
{
321321
if (user_mode(regs)) {
322-
return __get_user(*r_val, addr);
322+
return __get_user(*r_val, (u8 __user *)addr);
323323
} else {
324324
*r_val = *addr;
325325
return 0;
@@ -329,7 +329,7 @@ static inline int load_u8(struct pt_regs *regs, const u8 *addr, u8 *r_val)
329329
static inline int store_u8(struct pt_regs *regs, u8 *addr, u8 val)
330330
{
331331
if (user_mode(regs)) {
332-
return __put_user(val, addr);
332+
return __put_user(val, (u8 __user *)addr);
333333
} else {
334334
*addr = val;
335335
return 0;
@@ -343,7 +343,7 @@ static inline int store_u8(struct pt_regs *regs, u8 *addr, u8 val)
343343
if (user_mode(regs)) { \
344344
__ret = __get_user(insn, insn_addr); \
345345
} else { \
346-
insn = *insn_addr; \
346+
insn = *(__force u16 *)insn_addr; \
347347
__ret = 0; \
348348
} \
349349
\

0 commit comments

Comments
 (0)