blob: 3d0c0ac5c20eb85a7adaf692136f920ade98bcf3 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Heiko Carstensa8061702008-04-17 07:46:26 +02002#ifndef _ENTRY_H
3#define _ENTRY_H
4
Heiko Carstens521b00c2016-05-07 12:15:21 +02005#include <linux/percpu.h>
Heiko Carstensa8061702008-04-17 07:46:26 +02006#include <linux/types.h>
7#include <linux/signal.h>
8#include <asm/ptrace.h>
Martin Schwidefskyb5f87f12014-10-01 10:57:57 +02009#include <asm/idle.h>
Martin Schwidefsky638ad342011-10-30 15:17:13 +010010
Martin Schwidefsky638ad342011-10-30 15:17:13 +010011extern void *restart_stack;
12
Martin Schwidefsky8b646bd2012-03-11 11:59:26 -040013void system_call(void);
14void pgm_check_handler(void);
15void ext_int_handler(void);
16void io_int_handler(void);
17void mcck_int_handler(void);
18void restart_int_handler(void);
Martin Schwidefsky8b646bd2012-03-11 11:59:26 -040019
Sven Schnelle56e62a72020-11-21 11:14:56 +010020void __ret_from_fork(struct task_struct *prev, struct pt_regs *regs);
21void __do_pgm_check(struct pt_regs *regs);
22void __do_syscall(struct pt_regs *regs, int per_trap);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010023
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +010024void do_protection_exception(struct pt_regs *regs);
25void do_dat_exception(struct pt_regs *regs);
Vasily Gorbik084ea4d2020-01-21 09:43:10 +010026void do_secure_storage_access(struct pt_regs *regs);
27void do_non_secure_storage_access(struct pt_regs *regs);
Janosch Frankcd4d3d52020-09-08 09:05:04 -040028void do_secure_storage_violation(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020029
Heiko Carstensb01a37a2012-10-18 18:10:06 +020030void addressing_exception(struct pt_regs *regs);
31void data_exception(struct pt_regs *regs);
32void default_trap_handler(struct pt_regs *regs);
33void divide_exception(struct pt_regs *regs);
34void execute_exception(struct pt_regs *regs);
35void hfp_divide_exception(struct pt_regs *regs);
36void hfp_overflow_exception(struct pt_regs *regs);
37void hfp_significance_exception(struct pt_regs *regs);
38void hfp_sqrt_exception(struct pt_regs *regs);
39void hfp_underflow_exception(struct pt_regs *regs);
40void illegal_op(struct pt_regs *regs);
41void operand_exception(struct pt_regs *regs);
42void overflow_exception(struct pt_regs *regs);
43void privileged_op(struct pt_regs *regs);
44void space_switch_exception(struct pt_regs *regs);
45void special_op_exception(struct pt_regs *regs);
46void specification_exception(struct pt_regs *regs);
47void transaction_exception(struct pt_regs *regs);
48void translation_exception(struct pt_regs *regs);
Martin Schwidefsky80703612014-10-06 17:53:53 +020049void vector_exception(struct pt_regs *regs);
Sven Schnelle17248ea2020-01-15 13:42:27 +010050void monitor_event_exception(struct pt_regs *regs);
Heiko Carstensb01a37a2012-10-18 18:10:06 +020051
Jan Willeke2a0a5b22014-09-22 16:39:06 +020052void do_report_trap(struct pt_regs *regs, int si_signo, int si_code, char *str);
Heiko Carstensa8061702008-04-17 07:46:26 +020053void kernel_stack_overflow(struct pt_regs * regs);
54void do_signal(struct pt_regs *regs);
Richard Weinberger067bf2d2014-07-13 22:21:03 +020055void handle_signal32(struct ksignal *ksig, sigset_t *oldset,
56 struct pt_regs *regs);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010057void do_notify_resume(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020058
Heiko Carstens63df41d62013-09-06 19:10:48 +020059void __init init_IRQ(void);
Sven Schnelle56e62a72020-11-21 11:14:56 +010060void do_io_irq(struct pt_regs *regs);
61void do_ext_irq(struct pt_regs *regs);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010062void do_restart(void);
Heiko Carstensa8061702008-04-17 07:46:26 +020063void __init startup_init(void);
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +010064void die(struct pt_regs *regs, const char *str);
Heiko Carstens63df41d62013-09-06 19:10:48 +020065int setup_profiling_timer(unsigned int multiplier);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010066void __init time_init(void);
Martin Schwidefskyec7bf472019-02-18 16:51:28 +010067unsigned long prepare_ftrace_return(unsigned long parent, unsigned long sp, unsigned long ip);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010068
Christoph Hellwiga4679372010-03-10 15:21:15 -080069struct s390_mmap_arg_struct;
Heiko Carstensa8061702008-04-17 07:46:26 +020070struct fadvise64_64_args;
71struct old_sigaction;
Heiko Carstensa8061702008-04-17 07:46:26 +020072
Heiko Carstense0a50542014-12-12 13:11:08 +010073long sys_rt_sigreturn(void);
74long sys_sigreturn(void);
75
Heiko Carstens86d295e2014-02-27 15:16:04 +010076long sys_s390_personality(unsigned int personality);
Heiko Carstens00fcb1492014-03-01 12:18:46 +010077long sys_s390_runtime_instr(int command, int signum);
Martin Schwidefsky916cda12016-01-26 14:10:34 +010078long sys_s390_guarded_storage(int command, struct gs_cb __user *);
Alexey Ishchuk4eafad72014-11-14 14:27:58 +010079long sys_s390_pci_mmio_write(unsigned long, const void __user *, size_t);
80long sys_s390_pci_mmio_read(unsigned long, void __user *, size_t);
QingFeng Hao3d8757b2017-09-29 12:41:52 +020081long sys_s390_sthyi(unsigned long function_code, void __user *buffer, u64 __user *return_code, unsigned long flags);
Heiko Carstens521b00c2016-05-07 12:15:21 +020082
83DECLARE_PER_CPU(u64, mt_cycles[8]);
84
Martin Schwidefskyce3dc442017-09-12 16:37:33 +020085unsigned long stack_alloc(void);
86void stack_free(unsigned long stack);
87
Heiko Carstensb61e1f32020-09-18 10:26:19 +020088extern char kprobes_insn_page[];
89
Heiko Carstensa8061702008-04-17 07:46:26 +020090#endif /* _ENTRY_H */