| /* |
| * 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); |
| |
| /* kernel/process.c */ |
| int sys_fork(struct pt_regs *); |
| int sys_vfork(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 *); |
| |
| /* 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/ioport.c */ |
| long sys_iopl(struct pt_regs *); |
| |
| /* kernel/process_32.c */ |
| int sys_clone(struct pt_regs *); |
| int sys_execve(struct pt_regs *); |
| |
| /* 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 *); |
| int sys_sigaltstack(struct pt_regs *); |
| unsigned long sys_sigreturn(struct pt_regs *); |
| |
| /* kernel/sys_i386_32.c */ |
| struct mmap_arg_struct; |
| struct sel_arg_struct; |
| struct oldold_utsname; |
| struct old_utsname; |
| |
| asmlinkage long sys_mmap2(unsigned long, unsigned long, unsigned long, |
| unsigned long, unsigned long, unsigned long); |
| 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 *); |
| |
| /* kernel/vm86_32.c */ |
| int sys_vm86old(struct pt_regs *); |
| int sys_vm86(struct pt_regs *); |
| |
| #else /* CONFIG_X86_32 */ |
| |
| /* X86_64 only */ |
| /* kernel/ioport.c */ |
| asmlinkage long sys_iopl(unsigned int, struct pt_regs *); |
| |
| /* kernel/process_64.c */ |
| asmlinkage long sys_clone(unsigned long, unsigned long, |
| void __user *, void __user *, |
| struct pt_regs *); |
| asmlinkage long sys_execve(char __user *, char __user * __user *, |
| char __user * __user *, |
| struct pt_regs *); |
| long sys_arch_prctl(int, unsigned long); |
| |
| /* kernel/signal.c */ |
| asmlinkage long sys_sigaltstack(const stack_t __user *, stack_t __user *, |
| struct pt_regs *); |
| |
| /* 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 */ |