syscalls: Remove start and number from syscall_get_arguments() args
[linux-block.git] / arch / parisc / include / asm / syscall.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* syscall.h */
3
4 #ifndef _ASM_PARISC_SYSCALL_H_
5 #define _ASM_PARISC_SYSCALL_H_
6
7 #include <uapi/linux/audit.h>
8 #include <linux/compat.h>
9 #include <linux/err.h>
10 #include <asm/ptrace.h>
11
12 #define NR_syscalls (__NR_Linux_syscalls)
13
14 static inline long syscall_get_nr(struct task_struct *tsk,
15                                   struct pt_regs *regs)
16 {
17         return regs->gr[20];
18 }
19
20 static inline void syscall_get_arguments(struct task_struct *tsk,
21                                          struct pt_regs *regs,
22                                          unsigned long *args)
23 {
24         args[5] = regs->gr[21];
25         args[4] = regs->gr[22];
26         args[3] = regs->gr[23];
27         args[2] = regs->gr[24];
28         args[1] = regs->gr[25];
29         args[0] = regs->gr[26];
30 }
31
32 static inline long syscall_get_return_value(struct task_struct *task,
33                                                 struct pt_regs *regs)
34 {
35         return regs->gr[28];
36 }
37
38 static inline void syscall_set_return_value(struct task_struct *task,
39                                             struct pt_regs *regs,
40                                             int error, long val)
41 {
42         regs->gr[28] = error ? error : val;
43 }
44
45 static inline void syscall_rollback(struct task_struct *task,
46                                     struct pt_regs *regs)
47 {
48         /* do nothing */
49 }
50
51 static inline int syscall_get_arch(void)
52 {
53         int arch = AUDIT_ARCH_PARISC;
54 #ifdef CONFIG_64BIT
55         if (!is_compat_task())
56                 arch = AUDIT_ARCH_PARISC64;
57 #endif
58         return arch;
59 }
60 #endif /*_ASM_PARISC_SYSCALL_H_*/