2012-03-29 01:30:02 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 1999 Cort Dougan <cort@cs.nmt.edu>
|
|
|
|
*/
|
|
|
|
#ifndef _ASM_POWERPC_DEBUG_H
|
|
|
|
#define _ASM_POWERPC_DEBUG_H
|
|
|
|
|
2012-12-20 22:06:44 +08:00
|
|
|
#include <asm/hw_breakpoint.h>
|
|
|
|
|
2012-03-29 01:30:02 +08:00
|
|
|
struct pt_regs;
|
|
|
|
|
|
|
|
extern struct dentry *powerpc_debugfs_root;
|
|
|
|
|
|
|
|
#if defined(CONFIG_DEBUGGER) || defined(CONFIG_KEXEC)
|
|
|
|
|
|
|
|
extern int (*__debugger)(struct pt_regs *regs);
|
|
|
|
extern int (*__debugger_ipi)(struct pt_regs *regs);
|
|
|
|
extern int (*__debugger_bpt)(struct pt_regs *regs);
|
|
|
|
extern int (*__debugger_sstep)(struct pt_regs *regs);
|
|
|
|
extern int (*__debugger_iabr_match)(struct pt_regs *regs);
|
2012-12-20 22:06:44 +08:00
|
|
|
extern int (*__debugger_break_match)(struct pt_regs *regs);
|
2012-03-29 01:30:02 +08:00
|
|
|
extern int (*__debugger_fault_handler)(struct pt_regs *regs);
|
|
|
|
|
|
|
|
#define DEBUGGER_BOILERPLATE(__NAME) \
|
|
|
|
static inline int __NAME(struct pt_regs *regs) \
|
|
|
|
{ \
|
|
|
|
if (unlikely(__ ## __NAME)) \
|
|
|
|
return __ ## __NAME(regs); \
|
|
|
|
return 0; \
|
|
|
|
}
|
|
|
|
|
|
|
|
DEBUGGER_BOILERPLATE(debugger)
|
|
|
|
DEBUGGER_BOILERPLATE(debugger_ipi)
|
|
|
|
DEBUGGER_BOILERPLATE(debugger_bpt)
|
|
|
|
DEBUGGER_BOILERPLATE(debugger_sstep)
|
|
|
|
DEBUGGER_BOILERPLATE(debugger_iabr_match)
|
2012-12-20 22:06:44 +08:00
|
|
|
DEBUGGER_BOILERPLATE(debugger_break_match)
|
2012-03-29 01:30:02 +08:00
|
|
|
DEBUGGER_BOILERPLATE(debugger_fault_handler)
|
|
|
|
|
|
|
|
#else
|
|
|
|
static inline int debugger(struct pt_regs *regs) { return 0; }
|
|
|
|
static inline int debugger_ipi(struct pt_regs *regs) { return 0; }
|
|
|
|
static inline int debugger_bpt(struct pt_regs *regs) { return 0; }
|
|
|
|
static inline int debugger_sstep(struct pt_regs *regs) { return 0; }
|
|
|
|
static inline int debugger_iabr_match(struct pt_regs *regs) { return 0; }
|
2012-12-20 22:06:44 +08:00
|
|
|
static inline int debugger_break_match(struct pt_regs *regs) { return 0; }
|
2012-03-29 01:30:02 +08:00
|
|
|
static inline int debugger_fault_handler(struct pt_regs *regs) { return 0; }
|
|
|
|
#endif
|
|
|
|
|
2014-04-30 03:25:16 +08:00
|
|
|
void set_breakpoint(struct arch_hw_breakpoint *brk);
|
2014-04-30 03:25:17 +08:00
|
|
|
void __set_breakpoint(struct arch_hw_breakpoint *brk);
|
2012-03-29 01:30:02 +08:00
|
|
|
#ifdef CONFIG_PPC_ADV_DEBUG_REGS
|
|
|
|
extern void do_send_trap(struct pt_regs *regs, unsigned long address,
|
|
|
|
unsigned long error_code, int signal_code, int brkpt);
|
|
|
|
#else
|
2012-12-20 22:06:44 +08:00
|
|
|
|
|
|
|
extern void do_break(struct pt_regs *regs, unsigned long address,
|
|
|
|
unsigned long error_code);
|
2012-03-29 01:30:02 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _ASM_POWERPC_DEBUG_H */
|