Merge tag 'powerpc-4.9-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc...
[cascardo/linux.git] / arch / powerpc / include / asm / asm-prototypes.h
1 #ifndef _ASM_POWERPC_ASM_PROTOTYPES_H
2 #define _ASM_POWERPC_ASM_PROTOTYPES_H
3 /*
4  * This file is for prototypes of C functions that are only called
5  * from asm, and any associated variables.
6  *
7  * Copyright 2016, Daniel Axtens, IBM Corporation.
8  *
9  * This program is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License
11  * as published by the Free Software Foundation; either version 2
12  * of the License, or (at your option) any later version.
13  */
14
15 #include <linux/threads.h>
16 #include <linux/kprobes.h>
17
18 #include <uapi/asm/ucontext.h>
19
20 /* SMP */
21 extern struct thread_info *current_set[NR_CPUS];
22 extern struct thread_info *secondary_ti;
23 void start_secondary(void *unused);
24
25 /* kexec */
26 struct paca_struct;
27 struct kimage;
28 extern struct paca_struct kexec_paca;
29 void kexec_copy_flush(struct kimage *image);
30
31 /* pseries hcall tracing */
32 extern struct static_key hcall_tracepoint_key;
33 void __trace_hcall_entry(unsigned long opcode, unsigned long *args);
34 void __trace_hcall_exit(long opcode, unsigned long retval,
35                         unsigned long *retbuf);
36 /* OPAL tracing */
37 #ifdef HAVE_JUMP_LABEL
38 extern struct static_key opal_tracepoint_key;
39 #endif
40
41 void __trace_opal_entry(unsigned long opcode, unsigned long *args);
42 void __trace_opal_exit(long opcode, unsigned long retval);
43
44 /* VMX copying */
45 int enter_vmx_usercopy(void);
46 int exit_vmx_usercopy(void);
47 int enter_vmx_copy(void);
48 void * exit_vmx_copy(void *dest);
49
50 /* Traps */
51 long machine_check_early(struct pt_regs *regs);
52 long hmi_exception_realmode(struct pt_regs *regs);
53 void SMIException(struct pt_regs *regs);
54 void handle_hmi_exception(struct pt_regs *regs);
55 void instruction_breakpoint_exception(struct pt_regs *regs);
56 void RunModeException(struct pt_regs *regs);
57 void single_step_exception(struct pt_regs *regs);
58 void program_check_exception(struct pt_regs *regs);
59 void alignment_exception(struct pt_regs *regs);
60 void StackOverflow(struct pt_regs *regs);
61 void nonrecoverable_exception(struct pt_regs *regs);
62 void kernel_fp_unavailable_exception(struct pt_regs *regs);
63 void altivec_unavailable_exception(struct pt_regs *regs);
64 void vsx_unavailable_exception(struct pt_regs *regs);
65 void fp_unavailable_tm(struct pt_regs *regs);
66 void altivec_unavailable_tm(struct pt_regs *regs);
67 void vsx_unavailable_tm(struct pt_regs *regs);
68 void facility_unavailable_exception(struct pt_regs *regs);
69 void TAUException(struct pt_regs *regs);
70 void altivec_assist_exception(struct pt_regs *regs);
71 void unrecoverable_exception(struct pt_regs *regs);
72 void kernel_bad_stack(struct pt_regs *regs);
73 void system_reset_exception(struct pt_regs *regs);
74 void machine_check_exception(struct pt_regs *regs);
75 void emulation_assist_interrupt(struct pt_regs *regs);
76
77 /* signals, syscalls and interrupts */
78 #ifdef CONFIG_PPC64
79 int sys_swapcontext(struct ucontext __user *old_ctx,
80                     struct ucontext __user *new_ctx,
81                     long ctx_size, long r6, long r7, long r8, struct pt_regs *regs);
82 #else
83 long sys_swapcontext(struct ucontext __user *old_ctx,
84                     struct ucontext __user *new_ctx,
85                     int ctx_size, int r6, int r7, int r8, struct pt_regs *regs);
86 #endif
87 long sys_switch_endian(void);
88 notrace unsigned int __check_irq_replay(void);
89 void notrace restore_interrupts(void);
90
91 /* ptrace */
92 long do_syscall_trace_enter(struct pt_regs *regs);
93 void do_syscall_trace_leave(struct pt_regs *regs);
94
95 /* process */
96 void restore_math(struct pt_regs *regs);
97 void restore_tm_state(struct pt_regs *regs);
98
99 /* prom_init (OpenFirmware) */
100 unsigned long __init prom_init(unsigned long r3, unsigned long r4,
101                                unsigned long pp,
102                                unsigned long r6, unsigned long r7,
103                                unsigned long kbase);
104
105 /* setup */
106 void __init early_setup(unsigned long dt_ptr);
107 void early_setup_secondary(void);
108
109 /* time */
110 void accumulate_stolen_time(void);
111
112 #endif /* _ASM_POWERPC_ASM_PROTOTYPES_H */