2008-07-21 10:04:13 -06:00
|
|
|
/*
|
|
|
|
* syscalls.h - Linux syscall interfaces (arch-specific)
|
|
|
|
*
|
2009-04-10 12:33:10 -06:00
|
|
|
* Copyright (c) 2008 Jaswinder Singh Rajput
|
2008-07-21 10:04:13 -06:00
|
|
|
*
|
|
|
|
* 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>
|
2009-04-10 12:33:10 -06:00
|
|
|
#include <linux/types.h>
|
2008-07-21 10:04:13 -06:00
|
|
|
|
|
|
|
/* Common in X86_32 and X86_64 */
|
|
|
|
/* kernel/ioport.c */
|
|
|
|
asmlinkage long sys_ioperm(unsigned long, unsigned long, int);
|
2009-12-09 17:01:52 -07:00
|
|
|
long sys_iopl(unsigned int, struct pt_regs *);
|
2008-07-21 10:04:13 -06:00
|
|
|
|
2009-04-10 12:33:10 -06:00
|
|
|
/* kernel/process.c */
|
|
|
|
int sys_fork(struct pt_regs *);
|
|
|
|
int sys_vfork(struct pt_regs *);
|
2009-12-09 17:01:53 -07:00
|
|
|
long sys_execve(char __user *, char __user * __user *,
|
|
|
|
char __user * __user *, struct pt_regs *);
|
2009-12-09 17:01:56 -07:00
|
|
|
long sys_clone(unsigned long, unsigned long, void __user *,
|
|
|
|
void __user *, struct pt_regs *);
|
2009-04-10 12:33:10 -06:00
|
|
|
|
2008-12-15 09:56:30 -07:00
|
|
|
/* kernel/ldt.c */
|
|
|
|
asmlinkage int sys_modify_ldt(int, void __user *, unsigned long);
|
|
|
|
|
2009-04-10 12:33:10 -06:00
|
|
|
/* kernel/signal.c */
|
|
|
|
long sys_rt_sigreturn(struct pt_regs *);
|
2009-12-09 17:01:54 -07:00
|
|
|
long sys_sigaltstack(const stack_t __user *, stack_t __user *,
|
|
|
|
struct pt_regs *);
|
|
|
|
|
2009-04-10 12:33:10 -06:00
|
|
|
|
2008-12-17 10:48:52 -07:00
|
|
|
/* kernel/tls.c */
|
|
|
|
asmlinkage int sys_set_thread_area(struct user_desc __user *);
|
|
|
|
asmlinkage int sys_get_thread_area(struct user_desc __user *);
|
|
|
|
|
2008-07-21 10:04:13 -06:00
|
|
|
/* X86_32 only */
|
|
|
|
#ifdef CONFIG_X86_32
|
|
|
|
|
2009-04-10 12:33:10 -06:00
|
|
|
/* kernel/signal.c */
|
2008-07-21 10:04:13 -06:00
|
|
|
asmlinkage int sys_sigsuspend(int, int, old_sigset_t);
|
|
|
|
asmlinkage int sys_sigaction(int, const struct old_sigaction __user *,
|
|
|
|
struct old_sigaction __user *);
|
2009-02-11 14:43:58 -07:00
|
|
|
unsigned long sys_sigreturn(struct pt_regs *);
|
2008-07-21 10:04:13 -06:00
|
|
|
|
|
|
|
/* kernel/sys_i386_32.c */
|
2009-04-10 12:33:10 -06:00
|
|
|
struct mmap_arg_struct;
|
|
|
|
struct sel_arg_struct;
|
|
|
|
struct oldold_utsname;
|
|
|
|
struct old_utsname;
|
|
|
|
|
2008-07-21 10:04:13 -06:00
|
|
|
asmlinkage int old_mmap(struct mmap_arg_struct __user *);
|
|
|
|
asmlinkage int old_select(struct sel_arg_struct __user *);
|
|
|
|
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 *);
|
|
|
|
|
2008-07-23 06:01:02 -06:00
|
|
|
/* kernel/vm86_32.c */
|
2009-12-09 17:01:55 -07:00
|
|
|
int sys_vm86old(struct vm86_struct __user *, struct pt_regs *);
|
|
|
|
int sys_vm86(unsigned long, unsigned long, struct pt_regs *);
|
2008-07-23 06:01:02 -06:00
|
|
|
|
2008-07-21 10:04:13 -06:00
|
|
|
#else /* CONFIG_X86_32 */
|
|
|
|
|
|
|
|
/* X86_64 only */
|
|
|
|
/* kernel/process_64.c */
|
2009-02-02 09:18:33 -07:00
|
|
|
long sys_arch_prctl(int, unsigned long);
|
2008-07-21 10:04:13 -06:00
|
|
|
|
|
|
|
/* kernel/sys_x86_64.c */
|
2009-04-10 12:33:10 -06:00
|
|
|
struct new_utsname;
|
|
|
|
|
2008-07-21 10:04:13 -06:00
|
|
|
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 */
|