blob: bf538aaf407d8ceb433f094e7d8b6cb22f2c65d5 [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
Martin Schwidefsky638ad342011-10-30 15:17:13 +01008
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +01009extern void (*pgm_check_table[128])(struct pt_regs *);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010010extern void *restart_stack;
11
12asmlinkage long do_syscall_trace_enter(struct pt_regs *regs);
13asmlinkage void do_syscall_trace_exit(struct pt_regs *regs);
14
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +010015void do_protection_exception(struct pt_regs *regs);
16void do_dat_exception(struct pt_regs *regs);
17void do_asce_exception(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020018
Martin Schwidefsky5e9a2692011-01-05 12:48:10 +010019void do_per_trap(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020020void syscall_trace(struct pt_regs *regs, int entryexit);
21void kernel_stack_overflow(struct pt_regs * regs);
22void do_signal(struct pt_regs *regs);
23int handle_signal32(unsigned long sig, struct k_sigaction *ka,
24 siginfo_t *info, sigset_t *oldset, struct pt_regs *regs);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010025void do_notify_resume(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020026
Martin Schwidefskyf6649a72010-10-25 16:10:38 +020027void do_extint(struct pt_regs *regs, unsigned int, unsigned int, unsigned long);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010028void do_restart(void);
Heiko Carstensa8061702008-04-17 07:46:26 +020029int __cpuinit start_secondary(void *cpuvoid);
30void __init startup_init(void);
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +010031void die(struct pt_regs *regs, const char *str);
Heiko Carstensa8061702008-04-17 07:46:26 +020032
Martin Schwidefsky638ad342011-10-30 15:17:13 +010033void __init time_init(void);
34
Christoph Hellwiga4679372010-03-10 15:21:15 -080035struct s390_mmap_arg_struct;
Heiko Carstensa8061702008-04-17 07:46:26 +020036struct fadvise64_64_args;
37struct old_sigaction;
Heiko Carstensa8061702008-04-17 07:46:26 +020038
Christoph Hellwiga4679372010-03-10 15:21:15 -080039long sys_mmap2(struct s390_mmap_arg_struct __user *arg);
Christoph Hellwigbaed7fc2010-03-10 15:21:18 -080040long sys_s390_ipc(uint call, int first, unsigned long second,
Heiko Carstensa8061702008-04-17 07:46:26 +020041 unsigned long third, void __user *ptr);
Heiko Carstens3a110372010-08-13 10:06:39 +020042long sys_s390_personality(unsigned int personality);
Heiko Carstens26689452009-01-14 14:14:36 +010043long sys_s390_fadvise64(int fd, u32 offset_high, u32 offset_low,
Heiko Carstensa8061702008-04-17 07:46:26 +020044 size_t len, int advice);
Heiko Carstens26689452009-01-14 14:14:36 +010045long sys_s390_fadvise64_64(struct fadvise64_64_args __user *args);
46long sys_s390_fallocate(int fd, int mode, loff_t offset, u32 len_high,
47 u32 len_low);
Heiko Carstensa8061702008-04-17 07:46:26 +020048long sys_fork(void);
Heiko Carstens2d70ca22009-09-22 22:58:41 +020049long sys_clone(unsigned long newsp, unsigned long clone_flags,
50 int __user *parent_tidptr, int __user *child_tidptr);
Heiko Carstensa8061702008-04-17 07:46:26 +020051long sys_vfork(void);
52void execve_tail(void);
Sebastian Ott7af048d2010-08-24 09:26:20 +020053long sys_execve(const char __user *name, const char __user *const __user *argv,
54 const char __user *const __user *envp);
Heiko Carstens26689452009-01-14 14:14:36 +010055long sys_sigsuspend(int history0, int history1, old_sigset_t mask);
Heiko Carstensa8061702008-04-17 07:46:26 +020056long sys_sigaction(int sig, const struct old_sigaction __user *act,
57 struct old_sigaction __user *oact);
58long sys_sigaltstack(const stack_t __user *uss, stack_t __user *uoss);
59long sys_sigreturn(void);
60long sys_rt_sigreturn(void);
61long sys32_sigreturn(void);
62long sys32_rt_sigreturn(void);
Heiko Carstensa8061702008-04-17 07:46:26 +020063
64#endif /* _ENTRY_H */