treewide: remove redundant IS_ERR() before error code check
[linux/fpc-iii.git] / arch / csky / include / asm / syscall.h
blobf624fa3bbc22fef3e3d0fe4ecbebe8b4d8c5c6fb
1 /* SPDX-License-Identifier: GPL-2.0 */
3 #ifndef __ASM_SYSCALL_H
4 #define __ASM_SYSCALL_H
6 #include <linux/sched.h>
7 #include <linux/err.h>
8 #include <abi/regdef.h>
9 #include <uapi/linux/audit.h>
11 extern void *sys_call_table[];
13 static inline int
14 syscall_get_nr(struct task_struct *task, struct pt_regs *regs)
16 return regs_syscallid(regs);
19 static inline void
20 syscall_set_nr(struct task_struct *task, struct pt_regs *regs,
21 int sysno)
23 regs_syscallid(regs) = sysno;
26 static inline void
27 syscall_rollback(struct task_struct *task, struct pt_regs *regs)
29 regs->a0 = regs->orig_a0;
32 static inline long
33 syscall_get_error(struct task_struct *task, struct pt_regs *regs)
35 unsigned long error = regs->a0;
37 return IS_ERR_VALUE(error) ? error : 0;
40 static inline long
41 syscall_get_return_value(struct task_struct *task, struct pt_regs *regs)
43 return regs->a0;
46 static inline void
47 syscall_set_return_value(struct task_struct *task, struct pt_regs *regs,
48 int error, long val)
50 regs->a0 = (long) error ?: val;
53 static inline void
54 syscall_get_arguments(struct task_struct *task, struct pt_regs *regs,
55 unsigned long *args)
57 args[0] = regs->orig_a0;
58 args++;
59 memcpy(args, &regs->a1, 5 * sizeof(args[0]));
62 static inline void
63 syscall_set_arguments(struct task_struct *task, struct pt_regs *regs,
64 const unsigned long *args)
66 regs->orig_a0 = args[0];
67 args++;
68 memcpy(&regs->a1, args, 5 * sizeof(regs->a1));
71 static inline int
72 syscall_get_arch(struct task_struct *task)
74 return AUDIT_ARCH_CSKY;
77 #endif /* __ASM_SYSCALL_H */