blob: 1ab33465382ff7ecae40b42adeb7a17d4a57a402 [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);
Jan Willeke2a0a5b22014-09-22 16:39:06 +020029void do_report_trap(struct pt_regs *regs, int si_signo, int si_code, char *str);
Heiko Carstensa8061702008-04-17 07:46:26 +020030void kernel_stack_overflow(struct pt_regs * regs);
31void do_signal(struct pt_regs *regs);
Richard Weinberger067bf2d2014-07-13 22:21:03 +020032void handle_signal32(struct ksignal *ksig, sigset_t *oldset,
33 struct pt_regs *regs);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010034void do_notify_resume(struct pt_regs *regs);
Heiko Carstensa8061702008-04-17 07:46:26 +020035
Heiko Carstens63df41d62013-09-06 19:10:48 +020036void __init init_IRQ(void);
Sven Schnelle56e62a72020-11-21 11:14:56 +010037void do_io_irq(struct pt_regs *regs);
38void do_ext_irq(struct pt_regs *regs);
Alexander Gordeevb44913f2021-04-06 17:38:11 +020039void do_restart(void *arg);
Heiko Carstensa8061702008-04-17 07:46:26 +020040void __init startup_init(void);
Martin Schwidefskyaa33c8c2011-12-27 11:27:18 +010041void die(struct pt_regs *regs, const char *str);
Heiko Carstens63df41d62013-09-06 19:10:48 +020042int setup_profiling_timer(unsigned int multiplier);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010043void __init time_init(void);
Martin Schwidefskyec7bf472019-02-18 16:51:28 +010044unsigned long prepare_ftrace_return(unsigned long parent, unsigned long sp, unsigned long ip);
Martin Schwidefsky638ad342011-10-30 15:17:13 +010045
Christoph Hellwiga4679372010-03-10 15:21:15 -080046struct s390_mmap_arg_struct;
Heiko Carstensa8061702008-04-17 07:46:26 +020047struct fadvise64_64_args;
48struct old_sigaction;
Heiko Carstensa8061702008-04-17 07:46:26 +020049
Heiko Carstense0a50542014-12-12 13:11:08 +010050long sys_rt_sigreturn(void);
51long sys_sigreturn(void);
52
Heiko Carstens86d295e2014-02-27 15:16:04 +010053long sys_s390_personality(unsigned int personality);
Heiko Carstens00fcb1492014-03-01 12:18:46 +010054long sys_s390_runtime_instr(int command, int signum);
Martin Schwidefsky916cda12016-01-26 14:10:34 +010055long sys_s390_guarded_storage(int command, struct gs_cb __user *);
Alexey Ishchuk4eafad72014-11-14 14:27:58 +010056long sys_s390_pci_mmio_write(unsigned long, const void __user *, size_t);
57long sys_s390_pci_mmio_read(unsigned long, void __user *, size_t);
QingFeng Hao3d8757b2017-09-29 12:41:52 +020058long sys_s390_sthyi(unsigned long function_code, void __user *buffer, u64 __user *return_code, unsigned long flags);
Heiko Carstens521b00c2016-05-07 12:15:21 +020059
60DECLARE_PER_CPU(u64, mt_cycles[8]);
61
Martin Schwidefskyce3dc442017-09-12 16:37:33 +020062unsigned long stack_alloc(void);
63void stack_free(unsigned long stack);
64
Heiko Carstensb61e1f32020-09-18 10:26:19 +020065extern char kprobes_insn_page[];
66
Heiko Carstensa8061702008-04-17 07:46:26 +020067#endif /* _ENTRY_H */