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