]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/blame - arch/ia64/include/asm/syscall.h
treewide: Replace GPLv2 boilerplate/reference with SPDX - rule 193
[mirror_ubuntu-eoan-kernel.git] / arch / ia64 / include / asm / syscall.h
CommitLineData
2522fe45 1/* SPDX-License-Identifier: GPL-2.0-only */
cfb361f1
SL
2/*
3 * Access to user system call parameters and results
4 *
5 * Copyright (C) 2008 Intel Corp. Shaohua Li <shaohua.li@intel.com>
6 *
cfb361f1
SL
7 * See asm-generic/syscall.h for descriptions of what we must do here.
8 */
9
10#ifndef _ASM_SYSCALL_H
11#define _ASM_SYSCALL_H 1
12
ce5d1128 13#include <uapi/linux/audit.h>
cfb361f1
SL
14#include <linux/sched.h>
15#include <linux/err.h>
16
17static inline long syscall_get_nr(struct task_struct *task,
18 struct pt_regs *regs)
19{
cfb361f1
SL
20 if ((long)regs->cr_ifs < 0) /* Not a syscall */
21 return -1;
680973ed 22
cfb361f1
SL
23 return regs->r15;
24}
25
26static inline void syscall_rollback(struct task_struct *task,
27 struct pt_regs *regs)
28{
cfb361f1
SL
29 /* do nothing */
30}
31
32static inline long syscall_get_error(struct task_struct *task,
33 struct pt_regs *regs)
34{
cfb361f1
SL
35 return regs->r10 == -1 ? regs->r8:0;
36}
37
38static inline long syscall_get_return_value(struct task_struct *task,
39 struct pt_regs *regs)
40{
cfb361f1
SL
41 return regs->r8;
42}
43
44static inline void syscall_set_return_value(struct task_struct *task,
45 struct pt_regs *regs,
46 int error, long val)
47{
cfb361f1
SL
48 if (error) {
49 /* error < 0, but ia64 uses > 0 return value */
50 regs->r8 = -error;
51 regs->r10 = -1;
52 } else {
53 regs->r8 = val;
54 regs->r10 = 0;
55 }
56}
57
58extern void ia64_syscall_get_set_arguments(struct task_struct *task,
32d92586 59 struct pt_regs *regs, unsigned long *args, int rw);
cfb361f1
SL
60static inline void syscall_get_arguments(struct task_struct *task,
61 struct pt_regs *regs,
cfb361f1
SL
62 unsigned long *args)
63{
32d92586 64 ia64_syscall_get_set_arguments(task, regs, args, 0);
cfb361f1
SL
65}
66
67static inline void syscall_set_arguments(struct task_struct *task,
68 struct pt_regs *regs,
cfb361f1
SL
69 unsigned long *args)
70{
32d92586 71 ia64_syscall_get_set_arguments(task, regs, args, 1);
cfb361f1 72}
ce5d1128 73
16add411 74static inline int syscall_get_arch(struct task_struct *task)
ce5d1128
EP
75{
76 return AUDIT_ARCH_IA64;
77}
cfb361f1 78#endif /* _ASM_SYSCALL_H */