1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * Copyright (C) 1999 Cort Dougan <cort@cs.nmt.edu>
4  */
5 #ifndef _ASM_POWERPC_DEBUG_H
6 #define _ASM_POWERPC_DEBUG_H
7 
8 #include <asm/hw_breakpoint.h>
9 
10 struct pt_regs;
11 
12 #if defined(CONFIG_DEBUGGER) || defined(CONFIG_KEXEC_CORE)
13 
14 extern int (*__debugger)(struct pt_regs *regs);
15 extern int (*__debugger_ipi)(struct pt_regs *regs);
16 extern int (*__debugger_bpt)(struct pt_regs *regs);
17 extern int (*__debugger_sstep)(struct pt_regs *regs);
18 extern int (*__debugger_iabr_match)(struct pt_regs *regs);
19 extern int (*__debugger_break_match)(struct pt_regs *regs);
20 extern int (*__debugger_fault_handler)(struct pt_regs *regs);
21 
22 #define DEBUGGER_BOILERPLATE(__NAME) \
23 static inline int __NAME(struct pt_regs *regs) \
24 { \
25 	if (unlikely(__ ## __NAME)) \
26 		return __ ## __NAME(regs); \
27 	return 0; \
28 }
29 
30 DEBUGGER_BOILERPLATE(debugger)
31 DEBUGGER_BOILERPLATE(debugger_ipi)
32 DEBUGGER_BOILERPLATE(debugger_bpt)
33 DEBUGGER_BOILERPLATE(debugger_sstep)
34 DEBUGGER_BOILERPLATE(debugger_iabr_match)
35 DEBUGGER_BOILERPLATE(debugger_break_match)
36 DEBUGGER_BOILERPLATE(debugger_fault_handler)
37 
38 #else
39 static inline int debugger(struct pt_regs *regs) { return 0; }
40 static inline int debugger_ipi(struct pt_regs *regs) { return 0; }
41 static inline int debugger_bpt(struct pt_regs *regs) { return 0; }
42 static inline int debugger_sstep(struct pt_regs *regs) { return 0; }
43 static inline int debugger_iabr_match(struct pt_regs *regs) { return 0; }
44 static inline int debugger_break_match(struct pt_regs *regs) { return 0; }
45 static inline int debugger_fault_handler(struct pt_regs *regs) { return 0; }
46 #endif
47 
48 void __set_breakpoint(int nr, struct arch_hw_breakpoint *brk);
49 bool ppc_breakpoint_available(void);
50 #ifdef CONFIG_PPC_ADV_DEBUG_REGS
51 extern void do_send_trap(struct pt_regs *regs, unsigned long address,
52 			 unsigned long error_code, int brkpt);
53 #endif
54 
55 #endif /* _ASM_POWERPC_DEBUG_H */
56