162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Access to user system call parameters and results
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2008 Intel Corp.  Shaohua Li <shaohua.li@intel.com>
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * See asm-generic/syscall.h for descriptions of what we must do here.
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#ifndef _ASM_SYSCALL_H
1162306a36Sopenharmony_ci#define _ASM_SYSCALL_H	1
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include <uapi/linux/audit.h>
1462306a36Sopenharmony_ci#include <linux/sched.h>
1562306a36Sopenharmony_ci#include <linux/err.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_cistatic inline long syscall_get_nr(struct task_struct *task,
1862306a36Sopenharmony_ci				  struct pt_regs *regs)
1962306a36Sopenharmony_ci{
2062306a36Sopenharmony_ci	if ((long)regs->cr_ifs < 0) /* Not a syscall */
2162306a36Sopenharmony_ci		return -1;
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci	return regs->r15;
2462306a36Sopenharmony_ci}
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_cistatic inline void syscall_rollback(struct task_struct *task,
2762306a36Sopenharmony_ci				    struct pt_regs *regs)
2862306a36Sopenharmony_ci{
2962306a36Sopenharmony_ci	/* do nothing */
3062306a36Sopenharmony_ci}
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_cistatic inline long syscall_get_error(struct task_struct *task,
3362306a36Sopenharmony_ci				     struct pt_regs *regs)
3462306a36Sopenharmony_ci{
3562306a36Sopenharmony_ci	return regs->r10 == -1 ? -regs->r8:0;
3662306a36Sopenharmony_ci}
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_cistatic inline long syscall_get_return_value(struct task_struct *task,
3962306a36Sopenharmony_ci					    struct pt_regs *regs)
4062306a36Sopenharmony_ci{
4162306a36Sopenharmony_ci	return regs->r8;
4262306a36Sopenharmony_ci}
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_cistatic inline void syscall_set_return_value(struct task_struct *task,
4562306a36Sopenharmony_ci					    struct pt_regs *regs,
4662306a36Sopenharmony_ci					    int error, long val)
4762306a36Sopenharmony_ci{
4862306a36Sopenharmony_ci	if (error) {
4962306a36Sopenharmony_ci		/* error < 0, but ia64 uses > 0 return value */
5062306a36Sopenharmony_ci		regs->r8 = -error;
5162306a36Sopenharmony_ci		regs->r10 = -1;
5262306a36Sopenharmony_ci	} else {
5362306a36Sopenharmony_ci		regs->r8 = val;
5462306a36Sopenharmony_ci		regs->r10 = 0;
5562306a36Sopenharmony_ci	}
5662306a36Sopenharmony_ci}
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ciextern void syscall_get_arguments(struct task_struct *task,
5962306a36Sopenharmony_ci	struct pt_regs *regs, unsigned long *args);
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_cistatic inline int syscall_get_arch(struct task_struct *task)
6262306a36Sopenharmony_ci{
6362306a36Sopenharmony_ci	return AUDIT_ARCH_IA64;
6462306a36Sopenharmony_ci}
6562306a36Sopenharmony_ci#endif	/* _ASM_SYSCALL_H */
66