2019-05-27 13:55:01 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2011-06-05 02:26:51 +07:00
|
|
|
/*
|
|
|
|
* OpenRISC Linux
|
|
|
|
*
|
|
|
|
* Linux architectural port borrowing liberally from similar works of
|
|
|
|
* others. All original copyrights apply as per the original source
|
|
|
|
* declaration.
|
|
|
|
*
|
|
|
|
* OpenRISC implementation:
|
|
|
|
* Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com>
|
|
|
|
* Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
|
|
|
|
* et al.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __ASM_OPENRISC_SYSCALL_H__
|
|
|
|
#define __ASM_OPENRISC_SYSCALL_H__
|
|
|
|
|
2014-03-12 00:50:46 +07:00
|
|
|
#include <uapi/linux/audit.h>
|
2011-06-05 02:26:51 +07:00
|
|
|
#include <linux/err.h>
|
|
|
|
#include <linux/sched.h>
|
|
|
|
|
|
|
|
static inline int
|
|
|
|
syscall_get_nr(struct task_struct *task, struct pt_regs *regs)
|
|
|
|
{
|
2012-03-02 16:05:24 +07:00
|
|
|
return regs->orig_gpr11;
|
2011-06-05 02:26:51 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
syscall_rollback(struct task_struct *task, struct pt_regs *regs)
|
|
|
|
{
|
|
|
|
regs->gpr[11] = regs->orig_gpr11;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline long
|
|
|
|
syscall_get_error(struct task_struct *task, struct pt_regs *regs)
|
|
|
|
{
|
|
|
|
return IS_ERR_VALUE(regs->gpr[11]) ? regs->gpr[11] : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline long
|
|
|
|
syscall_get_return_value(struct task_struct *task, struct pt_regs *regs)
|
|
|
|
{
|
|
|
|
return regs->gpr[11];
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
syscall_set_return_value(struct task_struct *task, struct pt_regs *regs,
|
|
|
|
int error, long val)
|
|
|
|
{
|
2012-03-02 16:05:24 +07:00
|
|
|
regs->gpr[11] = (long) error ?: val;
|
2011-06-05 02:26:51 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
syscall_get_arguments(struct task_struct *task, struct pt_regs *regs,
|
2016-11-08 04:26:37 +07:00
|
|
|
unsigned long *args)
|
2011-06-05 02:26:51 +07:00
|
|
|
{
|
2016-11-08 04:26:37 +07:00
|
|
|
memcpy(args, ®s->gpr[3], 6 * sizeof(args[0]));
|
2011-06-05 02:26:51 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void
|
|
|
|
syscall_set_arguments(struct task_struct *task, struct pt_regs *regs,
|
2019-03-28 07:07:31 +07:00
|
|
|
const unsigned long *args)
|
2011-06-05 02:26:51 +07:00
|
|
|
{
|
2019-03-28 07:07:31 +07:00
|
|
|
memcpy(®s->gpr[3], args, 6 * sizeof(args[0]));
|
2011-06-05 02:26:51 +07:00
|
|
|
}
|
|
|
|
|
2019-03-18 06:30:18 +07:00
|
|
|
static inline int syscall_get_arch(struct task_struct *task)
|
2014-03-12 00:50:46 +07:00
|
|
|
{
|
|
|
|
return AUDIT_ARCH_OPENRISC;
|
|
|
|
}
|
2011-06-05 02:26:51 +07:00
|
|
|
#endif
|