mirror of
https://git.proxmox.com/git/mirror_ubuntu-kernels.git
synced 2026-01-25 12:27:20 +00:00
This argument is required to extend the generic ptrace API with PTRACE_GET_SYSCALL_INFO request: syscall_get_arch() is going to be called from ptrace_request() along with syscall_get_nr(), syscall_get_arguments(), syscall_get_error(), and syscall_get_return_value() functions with a tracee as their argument. The primary intent is that the triple (audit_arch, syscall_nr, arg1..arg6) should describe what system call is being called and what its arguments are. Reverts:5e937a9ae9("syscall_get_arch: remove useless function arguments") Reverts:1002d94d30("syscall.h: fix doc text for syscall_get_arch()") Reviewed-by: Andy Lutomirski <luto@kernel.org> # for x86 Reviewed-by: Palmer Dabbelt <palmer@sifive.com> Acked-by: Paul Moore <paul@paul-moore.com> Acked-by: Paul Burton <paul.burton@mips.com> # MIPS parts Acked-by: Michael Ellerman <mpe@ellerman.id.au> (powerpc) Acked-by: Kees Cook <keescook@chromium.org> # seccomp parts Acked-by: Mark Salter <msalter@redhat.com> # for the c6x bit Cc: Elvira Khabirova <lineprinter@altlinux.org> Cc: Eugene Syromyatnikov <esyr@redhat.com> Cc: Oleg Nesterov <oleg@redhat.com> Cc: x86@kernel.org Cc: linux-alpha@vger.kernel.org Cc: linux-snps-arc@lists.infradead.org Cc: linux-arm-kernel@lists.infradead.org Cc: linux-c6x-dev@linux-c6x.org Cc: uclinux-h8-devel@lists.sourceforge.jp Cc: linux-hexagon@vger.kernel.org Cc: linux-ia64@vger.kernel.org Cc: linux-m68k@lists.linux-m68k.org Cc: linux-mips@vger.kernel.org Cc: nios2-dev@lists.rocketboards.org Cc: openrisc@lists.librecores.org Cc: linux-parisc@vger.kernel.org Cc: linuxppc-dev@lists.ozlabs.org Cc: linux-riscv@lists.infradead.org Cc: linux-s390@vger.kernel.org Cc: linux-sh@vger.kernel.org Cc: sparclinux@vger.kernel.org Cc: linux-um@lists.infradead.org Cc: linux-xtensa@linux-xtensa.org Cc: linux-arch@vger.kernel.org Cc: linux-audit@redhat.com Signed-off-by: Dmitry V. Levin <ldv@altlinux.org> Signed-off-by: Paul Moore <paul@paul-moore.com>
80 lines
1.9 KiB
C
80 lines
1.9 KiB
C
/*
|
|
* 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.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef __ASM_OPENRISC_SYSCALL_H__
|
|
#define __ASM_OPENRISC_SYSCALL_H__
|
|
|
|
#include <uapi/linux/audit.h>
|
|
#include <linux/err.h>
|
|
#include <linux/sched.h>
|
|
|
|
static inline int
|
|
syscall_get_nr(struct task_struct *task, struct pt_regs *regs)
|
|
{
|
|
return regs->orig_gpr11;
|
|
}
|
|
|
|
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)
|
|
{
|
|
regs->gpr[11] = (long) error ?: val;
|
|
}
|
|
|
|
static inline void
|
|
syscall_get_arguments(struct task_struct *task, struct pt_regs *regs,
|
|
unsigned int i, unsigned int n, unsigned long *args)
|
|
{
|
|
BUG_ON(i + n > 6);
|
|
|
|
memcpy(args, ®s->gpr[3 + i], n * sizeof(args[0]));
|
|
}
|
|
|
|
static inline void
|
|
syscall_set_arguments(struct task_struct *task, struct pt_regs *regs,
|
|
unsigned int i, unsigned int n, const unsigned long *args)
|
|
{
|
|
BUG_ON(i + n > 6);
|
|
|
|
memcpy(®s->gpr[3 + i], args, n * sizeof(args[0]));
|
|
}
|
|
|
|
static inline int syscall_get_arch(struct task_struct *task)
|
|
{
|
|
return AUDIT_ARCH_OPENRISC;
|
|
}
|
|
#endif
|