1#ifndef _ASM_POWERPC_ASM_PROTOTYPES_H
2#define _ASM_POWERPC_ASM_PROTOTYPES_H
3
4
5
6
7
8
9
10
11
12
13
14
15#include <linux/threads.h>
16#include <asm/cacheflush.h>
17#include <asm/checksum.h>
18#include <linux/uaccess.h>
19#include <asm/epapr_hcalls.h>
20#include <asm/dcr.h>
21#include <asm/mmu_context.h>
22
23#include <uapi/asm/ucontext.h>
24
25
26extern struct thread_info *current_set[NR_CPUS];
27extern struct thread_info *secondary_ti;
28void start_secondary(void *unused);
29
30
31struct paca_struct;
32struct kimage;
33extern struct paca_struct kexec_paca;
34void kexec_copy_flush(struct kimage *image);
35
36
37extern struct static_key hcall_tracepoint_key;
38void __trace_hcall_entry(unsigned long opcode, unsigned long *args);
39void __trace_hcall_exit(long opcode, unsigned long retval,
40 unsigned long *retbuf);
41
42#ifdef HAVE_JUMP_LABEL
43extern struct static_key opal_tracepoint_key;
44#endif
45
46void __trace_opal_entry(unsigned long opcode, unsigned long *args);
47void __trace_opal_exit(long opcode, unsigned long retval);
48
49
50int enter_vmx_usercopy(void);
51int exit_vmx_usercopy(void);
52int enter_vmx_copy(void);
53void * exit_vmx_copy(void *dest);
54
55
56long machine_check_early(struct pt_regs *regs);
57long hmi_exception_realmode(struct pt_regs *regs);
58void SMIException(struct pt_regs *regs);
59void handle_hmi_exception(struct pt_regs *regs);
60void instruction_breakpoint_exception(struct pt_regs *regs);
61void RunModeException(struct pt_regs *regs);
62void single_step_exception(struct pt_regs *regs);
63void program_check_exception(struct pt_regs *regs);
64void alignment_exception(struct pt_regs *regs);
65void StackOverflow(struct pt_regs *regs);
66void nonrecoverable_exception(struct pt_regs *regs);
67void kernel_fp_unavailable_exception(struct pt_regs *regs);
68void altivec_unavailable_exception(struct pt_regs *regs);
69void vsx_unavailable_exception(struct pt_regs *regs);
70void fp_unavailable_tm(struct pt_regs *regs);
71void altivec_unavailable_tm(struct pt_regs *regs);
72void vsx_unavailable_tm(struct pt_regs *regs);
73void facility_unavailable_exception(struct pt_regs *regs);
74void TAUException(struct pt_regs *regs);
75void altivec_assist_exception(struct pt_regs *regs);
76void unrecoverable_exception(struct pt_regs *regs);
77void kernel_bad_stack(struct pt_regs *regs);
78void system_reset_exception(struct pt_regs *regs);
79void machine_check_exception(struct pt_regs *regs);
80void emulation_assist_interrupt(struct pt_regs *regs);
81
82
83#ifdef CONFIG_PPC64
84int sys_swapcontext(struct ucontext __user *old_ctx,
85 struct ucontext __user *new_ctx,
86 long ctx_size, long r6, long r7, long r8, struct pt_regs *regs);
87#else
88long sys_swapcontext(struct ucontext __user *old_ctx,
89 struct ucontext __user *new_ctx,
90 int ctx_size, int r6, int r7, int r8, struct pt_regs *regs);
91#endif
92long sys_switch_endian(void);
93notrace unsigned int __check_irq_replay(void);
94void notrace restore_interrupts(void);
95
96
97long do_syscall_trace_enter(struct pt_regs *regs);
98void do_syscall_trace_leave(struct pt_regs *regs);
99
100
101void restore_math(struct pt_regs *regs);
102void restore_tm_state(struct pt_regs *regs);
103
104
105unsigned long __init prom_init(unsigned long r3, unsigned long r4,
106 unsigned long pp,
107 unsigned long r6, unsigned long r7,
108 unsigned long kbase);
109
110
111void __init early_setup(unsigned long dt_ptr);
112void early_setup_secondary(void);
113
114
115void accumulate_stolen_time(void);
116
117
118extern u64 __bswapdi2(u64);
119extern s64 __lshrdi3(s64, int);
120extern s64 __ashldi3(s64, int);
121extern s64 __ashrdi3(s64, int);
122extern int __cmpdi2(s64, s64);
123extern int __ucmpdi2(u64, u64);
124
125
126void _mcount(void);
127unsigned long prepare_ftrace_return(unsigned long parent, unsigned long ip);
128
129#endif
130