162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright Altera Corporation (C) <2014>. All rights reserved 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#ifndef __ASM_NIOS2_SYSCALL_H__ 762306a36Sopenharmony_ci#define __ASM_NIOS2_SYSCALL_H__ 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci#include <uapi/linux/audit.h> 1062306a36Sopenharmony_ci#include <linux/err.h> 1162306a36Sopenharmony_ci#include <linux/sched.h> 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_cistatic inline int syscall_get_nr(struct task_struct *task, struct pt_regs *regs) 1462306a36Sopenharmony_ci{ 1562306a36Sopenharmony_ci return regs->r2; 1662306a36Sopenharmony_ci} 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_cistatic inline void syscall_rollback(struct task_struct *task, 1962306a36Sopenharmony_ci struct pt_regs *regs) 2062306a36Sopenharmony_ci{ 2162306a36Sopenharmony_ci regs->r2 = regs->orig_r2; 2262306a36Sopenharmony_ci regs->r7 = regs->orig_r7; 2362306a36Sopenharmony_ci} 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_cistatic inline long syscall_get_error(struct task_struct *task, 2662306a36Sopenharmony_ci struct pt_regs *regs) 2762306a36Sopenharmony_ci{ 2862306a36Sopenharmony_ci return regs->r7 ? regs->r2 : 0; 2962306a36Sopenharmony_ci} 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_cistatic inline long syscall_get_return_value(struct task_struct *task, 3262306a36Sopenharmony_ci struct pt_regs *regs) 3362306a36Sopenharmony_ci{ 3462306a36Sopenharmony_ci return regs->r2; 3562306a36Sopenharmony_ci} 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistatic inline void syscall_set_return_value(struct task_struct *task, 3862306a36Sopenharmony_ci struct pt_regs *regs, int error, long val) 3962306a36Sopenharmony_ci{ 4062306a36Sopenharmony_ci if (error) { 4162306a36Sopenharmony_ci /* error < 0, but nios2 uses > 0 return value */ 4262306a36Sopenharmony_ci regs->r2 = -error; 4362306a36Sopenharmony_ci regs->r7 = 1; 4462306a36Sopenharmony_ci } else { 4562306a36Sopenharmony_ci regs->r2 = val; 4662306a36Sopenharmony_ci regs->r7 = 0; 4762306a36Sopenharmony_ci } 4862306a36Sopenharmony_ci} 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_cistatic inline void syscall_get_arguments(struct task_struct *task, 5162306a36Sopenharmony_ci struct pt_regs *regs, unsigned long *args) 5262306a36Sopenharmony_ci{ 5362306a36Sopenharmony_ci *args++ = regs->r4; 5462306a36Sopenharmony_ci *args++ = regs->r5; 5562306a36Sopenharmony_ci *args++ = regs->r6; 5662306a36Sopenharmony_ci *args++ = regs->r7; 5762306a36Sopenharmony_ci *args++ = regs->r8; 5862306a36Sopenharmony_ci *args = regs->r9; 5962306a36Sopenharmony_ci} 6062306a36Sopenharmony_ci 6162306a36Sopenharmony_cistatic inline int syscall_get_arch(struct task_struct *task) 6262306a36Sopenharmony_ci{ 6362306a36Sopenharmony_ci return AUDIT_ARCH_NIOS2; 6462306a36Sopenharmony_ci} 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci#endif 67