a4679373cf
Add a generic implementation of the old mmap() syscall, which expects its argument in a memory block and switch all architectures over to use it. Signed-off-by: Christoph Hellwig <hch@lst.de> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Cc: Paul Mundt <lethal@linux-sh.org> Cc: Jeff Dike <jdike@addtoit.com> Cc: Hirokazu Takata <takata@linux-m32r.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Ingo Molnar <mingo@elte.hu> Reviewed-by: H. Peter Anvin <hpa@zytor.com> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Heiko Carstens <heiko.carstens@de.ibm.com> Cc: Martin Schwidefsky <schwidefsky@de.ibm.com> Cc: "Luck, Tony" <tony.luck@intel.com> Cc: James Morris <jmorris@namei.org> Cc: Andreas Schwab <schwab@linux-m68k.org> Acked-by: Jesper Nilsson <jesper.nilsson@axis.com> Acked-by: Russell King <rmk+kernel@arm.linux.org.uk> Acked-by: Greg Ungerer <gerg@uclinux.org> Acked-by: David Howells <dhowells@redhat.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
80 lines
2.2 KiB
C
80 lines
2.2 KiB
C
/*
|
|
* syscalls.h - Linux syscall interfaces (arch-specific)
|
|
*
|
|
* Copyright (c) 2008 Jaswinder Singh Rajput
|
|
*
|
|
* This file is released under the GPLv2.
|
|
* See the file COPYING for more details.
|
|
*/
|
|
|
|
#ifndef _ASM_X86_SYSCALLS_H
|
|
#define _ASM_X86_SYSCALLS_H
|
|
|
|
#include <linux/compiler.h>
|
|
#include <linux/linkage.h>
|
|
#include <linux/signal.h>
|
|
#include <linux/types.h>
|
|
|
|
/* Common in X86_32 and X86_64 */
|
|
/* kernel/ioport.c */
|
|
asmlinkage long sys_ioperm(unsigned long, unsigned long, int);
|
|
long sys_iopl(unsigned int, struct pt_regs *);
|
|
|
|
/* kernel/process.c */
|
|
int sys_fork(struct pt_regs *);
|
|
int sys_vfork(struct pt_regs *);
|
|
long sys_execve(char __user *, char __user * __user *,
|
|
char __user * __user *, struct pt_regs *);
|
|
long sys_clone(unsigned long, unsigned long, void __user *,
|
|
void __user *, struct pt_regs *);
|
|
|
|
/* kernel/ldt.c */
|
|
asmlinkage int sys_modify_ldt(int, void __user *, unsigned long);
|
|
|
|
/* kernel/signal.c */
|
|
long sys_rt_sigreturn(struct pt_regs *);
|
|
long sys_sigaltstack(const stack_t __user *, stack_t __user *,
|
|
struct pt_regs *);
|
|
|
|
|
|
/* kernel/tls.c */
|
|
asmlinkage int sys_set_thread_area(struct user_desc __user *);
|
|
asmlinkage int sys_get_thread_area(struct user_desc __user *);
|
|
|
|
/* X86_32 only */
|
|
#ifdef CONFIG_X86_32
|
|
|
|
/* kernel/signal.c */
|
|
asmlinkage int sys_sigsuspend(int, int, old_sigset_t);
|
|
asmlinkage int sys_sigaction(int, const struct old_sigaction __user *,
|
|
struct old_sigaction __user *);
|
|
unsigned long sys_sigreturn(struct pt_regs *);
|
|
|
|
/* kernel/sys_i386_32.c */
|
|
struct oldold_utsname;
|
|
struct old_utsname;
|
|
|
|
asmlinkage int sys_ipc(uint, int, int, int, void __user *, long);
|
|
asmlinkage int sys_uname(struct old_utsname __user *);
|
|
asmlinkage int sys_olduname(struct oldold_utsname __user *);
|
|
|
|
/* kernel/vm86_32.c */
|
|
int sys_vm86old(struct vm86_struct __user *, struct pt_regs *);
|
|
int sys_vm86(unsigned long, unsigned long, struct pt_regs *);
|
|
|
|
#else /* CONFIG_X86_32 */
|
|
|
|
/* X86_64 only */
|
|
/* kernel/process_64.c */
|
|
long sys_arch_prctl(int, unsigned long);
|
|
|
|
/* kernel/sys_x86_64.c */
|
|
struct new_utsname;
|
|
|
|
asmlinkage long sys_mmap(unsigned long, unsigned long, unsigned long,
|
|
unsigned long, unsigned long, unsigned long);
|
|
asmlinkage long sys_uname(struct new_utsname __user *);
|
|
|
|
#endif /* CONFIG_X86_32 */
|
|
#endif /* _ASM_X86_SYSCALLS_H */
|