aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-sh/system.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/asm-sh/system.h')
-rw-r--r--include/asm-sh/system.h25
1 files changed, 19 insertions, 6 deletions
diff --git a/include/asm-sh/system.h b/include/asm-sh/system.h
index 0cfa96aa5844..6b02dfd587ea 100644
--- a/include/asm-sh/system.h
+++ b/include/asm-sh/system.h
@@ -185,12 +185,25 @@ void default_idle(void);
185void per_cpu_trap_init(void); 185void per_cpu_trap_init(void);
186 186
187asmlinkage void break_point_trap(void); 187asmlinkage void break_point_trap(void);
188asmlinkage void debug_trap_handler(unsigned long r4, unsigned long r5, 188
189 unsigned long r6, unsigned long r7, 189#ifdef CONFIG_SUPERH32
190 struct pt_regs __regs); 190#define BUILD_TRAP_HANDLER(name) \
191asmlinkage void bug_trap_handler(unsigned long r4, unsigned long r5, 191asmlinkage void name##_trap_handler(unsigned long r4, unsigned long r5, \
192 unsigned long r6, unsigned long r7, 192 unsigned long r6, unsigned long r7, \
193 struct pt_regs __regs); 193 struct pt_regs __regs)
194
195#define TRAP_HANDLER_DECL \
196 struct pt_regs *regs = RELOC_HIDE(&__regs, 0); \
197 unsigned int vec = regs->tra;
198#else
199#define BUILD_TRAP_HANDLER(name) \
200asmlinkage void name##_trap_handler(unsigned int vec, struct pt_regs *regs)
201#define TRAP_HANDLER_DECL
202#endif
203
204BUILD_TRAP_HANDLER(address_error);
205BUILD_TRAP_HANDLER(debug);
206BUILD_TRAP_HANDLER(bug);
194 207
195#define arch_align_stack(x) (x) 208#define arch_align_stack(x) (x)
196 209