blob: 15fd68b196c089f2b881f74df55843deab43fb8b [file] [log] [blame]
Heiko Carstensa8061702008-04-17 07:46:26 +02001#ifndef _ENTRY_H
2#define _ENTRY_H
3
4#include <linux/types.h>
5#include <linux/signal.h>
6#include <asm/ptrace.h>
7
8typedef void pgm_check_handler_t(struct pt_regs *, long);
9extern pgm_check_handler_t *pgm_check_table[128];
10pgm_check_handler_t do_protection_exception;
11pgm_check_handler_t do_dat_exception;
12
13extern int sysctl_userprocess_debug;
14
15void do_single_step(struct pt_regs *regs);
16void syscall_trace(struct pt_regs *regs, int entryexit);
17void kernel_stack_overflow(struct pt_regs * regs);
18void do_signal(struct pt_regs *regs);
19int handle_signal32(unsigned long sig, struct k_sigaction *ka,
20 siginfo_t *info, sigset_t *oldset, struct pt_regs *regs);
21
22void do_extint(struct pt_regs *regs, unsigned short code);
23int __cpuinit start_secondary(void *cpuvoid);
24void __init startup_init(void);
25void die(const char * str, struct pt_regs * regs, long err);
26
27struct new_utsname;
Christoph Hellwiga4679372010-03-10 15:21:15 -080028struct s390_mmap_arg_struct;
Heiko Carstensa8061702008-04-17 07:46:26 +020029struct fadvise64_64_args;
30struct old_sigaction;
Heiko Carstensa8061702008-04-17 07:46:26 +020031
Christoph Hellwiga4679372010-03-10 15:21:15 -080032long sys_mmap2(struct s390_mmap_arg_struct __user *arg);
Christoph Hellwigbaed7fc2010-03-10 15:21:18 -080033long sys_s390_ipc(uint call, int first, unsigned long second,
Heiko Carstensa8061702008-04-17 07:46:26 +020034 unsigned long third, void __user *ptr);
Heiko Carstens26689452009-01-14 14:14:36 +010035long sys_s390_newuname(struct new_utsname __user *name);
36long sys_s390_personality(unsigned long personality);
37long sys_s390_fadvise64(int fd, u32 offset_high, u32 offset_low,
Heiko Carstensa8061702008-04-17 07:46:26 +020038 size_t len, int advice);
Heiko Carstens26689452009-01-14 14:14:36 +010039long sys_s390_fadvise64_64(struct fadvise64_64_args __user *args);
40long sys_s390_fallocate(int fd, int mode, loff_t offset, u32 len_high,
41 u32 len_low);
Heiko Carstensa8061702008-04-17 07:46:26 +020042long sys_fork(void);
Heiko Carstens2d70ca22009-09-22 22:58:41 +020043long sys_clone(unsigned long newsp, unsigned long clone_flags,
44 int __user *parent_tidptr, int __user *child_tidptr);
Heiko Carstensa8061702008-04-17 07:46:26 +020045long sys_vfork(void);
46void execve_tail(void);
Heiko Carstens3e86a8c2009-09-22 22:58:42 +020047long sys_execve(char __user *name, char __user * __user *argv,
48 char __user * __user *envp);
Heiko Carstens26689452009-01-14 14:14:36 +010049long sys_sigsuspend(int history0, int history1, old_sigset_t mask);
Heiko Carstensa8061702008-04-17 07:46:26 +020050long sys_sigaction(int sig, const struct old_sigaction __user *act,
51 struct old_sigaction __user *oact);
52long sys_sigaltstack(const stack_t __user *uss, stack_t __user *uoss);
53long sys_sigreturn(void);
54long sys_rt_sigreturn(void);
55long sys32_sigreturn(void);
56long sys32_rt_sigreturn(void);
Heiko Carstensa8061702008-04-17 07:46:26 +020057
58#endif /* _ENTRY_H */