s390: update defconfigs
[linux-2.6-block.git] / arch / s390 / kernel / entry.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
a806170e
HC
2#ifndef _ENTRY_H
3#define _ENTRY_H
4
521b00cd 5#include <linux/percpu.h>
a806170e
HC
6#include <linux/types.h>
7#include <linux/signal.h>
8#include <asm/ptrace.h>
b5f87f15 9#include <asm/idle.h>
638ad34a 10
638ad34a
MS
11extern void *restart_stack;
12
8b646bd7
MS
13void 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);
8b646bd7 19
638ad34a
MS
20asmlinkage long do_syscall_trace_enter(struct pt_regs *regs);
21asmlinkage void do_syscall_trace_exit(struct pt_regs *regs);
22
aa33c8cb
MS
23void do_protection_exception(struct pt_regs *regs);
24void do_dat_exception(struct pt_regs *regs);
084ea4d6
VG
25void do_secure_storage_access(struct pt_regs *regs);
26void do_non_secure_storage_access(struct pt_regs *regs);
cd4d3d5f 27void do_secure_storage_violation(struct pt_regs *regs);
a806170e 28
b01a37a7
HC
29void addressing_exception(struct pt_regs *regs);
30void data_exception(struct pt_regs *regs);
31void default_trap_handler(struct pt_regs *regs);
32void divide_exception(struct pt_regs *regs);
33void execute_exception(struct pt_regs *regs);
34void hfp_divide_exception(struct pt_regs *regs);
35void hfp_overflow_exception(struct pt_regs *regs);
36void hfp_significance_exception(struct pt_regs *regs);
37void hfp_sqrt_exception(struct pt_regs *regs);
38void hfp_underflow_exception(struct pt_regs *regs);
39void illegal_op(struct pt_regs *regs);
40void operand_exception(struct pt_regs *regs);
41void overflow_exception(struct pt_regs *regs);
42void privileged_op(struct pt_regs *regs);
43void space_switch_exception(struct pt_regs *regs);
44void special_op_exception(struct pt_regs *regs);
45void specification_exception(struct pt_regs *regs);
46void transaction_exception(struct pt_regs *regs);
47void translation_exception(struct pt_regs *regs);
80703617 48void vector_exception(struct pt_regs *regs);
17248ea0 49void monitor_event_exception(struct pt_regs *regs);
b01a37a7 50
5e9a2692 51void do_per_trap(struct pt_regs *regs);
2a0a5b22 52void do_report_trap(struct pt_regs *regs, int si_signo, int si_code, char *str);
a806170e
HC
53void syscall_trace(struct pt_regs *regs, int entryexit);
54void kernel_stack_overflow(struct pt_regs * regs);
55void do_signal(struct pt_regs *regs);
067bf2d4
RW
56void handle_signal32(struct ksignal *ksig, sigset_t *oldset,
57 struct pt_regs *regs);
638ad34a 58void do_notify_resume(struct pt_regs *regs);
a806170e 59
63df41d6
HC
60void __init init_IRQ(void);
61void do_IRQ(struct pt_regs *regs, int irq);
638ad34a 62void do_restart(void);
a806170e 63void __init startup_init(void);
aa33c8cb 64void die(struct pt_regs *regs, const char *str);
63df41d6 65int setup_profiling_timer(unsigned int multiplier);
638ad34a 66void __init time_init(void);
ec7bf478 67unsigned long prepare_ftrace_return(unsigned long parent, unsigned long sp, unsigned long ip);
638ad34a 68
a4679373 69struct s390_mmap_arg_struct;
a806170e
HC
70struct fadvise64_64_args;
71struct old_sigaction;
a806170e 72
e0a50545
HC
73long sys_rt_sigreturn(void);
74long sys_sigreturn(void);
75
86d295e1 76long sys_s390_personality(unsigned int personality);
00fcb149 77long sys_s390_runtime_instr(int command, int signum);
916cda1a 78long sys_s390_guarded_storage(int command, struct gs_cb __user *);
4eafad7f
AI
79long sys_s390_pci_mmio_write(unsigned long, const void __user *, size_t);
80long sys_s390_pci_mmio_read(unsigned long, void __user *, size_t);
3d8757b8 81long sys_s390_sthyi(unsigned long function_code, void __user *buffer, u64 __user *return_code, unsigned long flags);
521b00cd
HC
82
83DECLARE_PER_CPU(u64, mt_cycles[8]);
84
916cda1a 85void gs_load_bc_cb(struct pt_regs *regs);
be2412c2 86
ce3dc447
MS
87unsigned long stack_alloc(void);
88void stack_free(unsigned long stack);
89
b61e1f32
HC
90extern char kprobes_insn_page[];
91
a806170e 92#endif /* _ENTRY_H */