kgdb.h 10.2 KB
Newer Older
J
Jason Wessel 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
/*
 * This provides the callbacks and functions that KGDB needs to share between
 * the core, I/O and arch-specific portions.
 *
 * Author: Amit Kale <amitkale@linsyssoft.com> and
 *         Tom Rini <trini@kernel.crashing.org>
 *
 * 2001-2004 (c) Amit S. Kale and 2003-2005 (c) MontaVista Software, Inc.
 * This file is licensed under the terms of the GNU General Public License
 * version 2. This program is licensed "as is" without any warranty of any
 * kind, whether express or implied.
 */
#ifndef _KGDB_H_
#define _KGDB_H_

#include <linux/serial_8250.h>
#include <linux/linkage.h>
#include <linux/init.h>
A
Arun Sharma 已提交
19
#include <linux/atomic.h>
J
Jason Wessel 已提交
20
#ifdef CONFIG_HAVE_ARCH_KGDB
J
Jason Wessel 已提交
21
#include <asm/kgdb.h>
J
Jason Wessel 已提交
22
#endif
J
Jason Wessel 已提交
23

J
Jason Wessel 已提交
24
#ifdef CONFIG_KGDB
J
Jason Wessel 已提交
25 26
struct pt_regs;

J
Jason Wessel 已提交
27 28
/**
 *	kgdb_skipexception - (optional) exit kgdb_handle_exception early
J
Jason Wessel 已提交
29 30 31
 *	@exception: Exception vector number
 *	@regs: Current &struct pt_regs.
 *
J
Jason Wessel 已提交
32 33
 *	On some architectures it is required to skip a breakpoint
 *	exception when it occurs after a breakpoint has been removed.
34
 *	This can be implemented in the architecture specific portion of kgdb.
J
Jason Wessel 已提交
35 36 37 38 39 40 41
 */
extern int kgdb_skipexception(int exception, struct pt_regs *regs);

struct tasklet_struct;
struct task_struct;
struct uart_port;

J
Jason Wessel 已提交
42 43 44
/**
 *	kgdb_breakpoint - compiled in breakpoint
 *
45
 *	This will be implemented as a static inline per architecture.  This
J
Jason Wessel 已提交
46 47 48 49
 *	function is called by the kgdb core to execute an architecture
 *	specific trap to cause kgdb to enter the exception processing.
 *
 */
J
Jason Wessel 已提交
50 51 52
void kgdb_breakpoint(void);

extern int kgdb_connected;
53
extern int kgdb_io_module_registered;
J
Jason Wessel 已提交
54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82

extern atomic_t			kgdb_setting_breakpoint;
extern atomic_t			kgdb_cpu_doing_single_step;

extern struct task_struct	*kgdb_usethread;
extern struct task_struct	*kgdb_contthread;

enum kgdb_bptype {
	BP_BREAKPOINT = 0,
	BP_HARDWARE_BREAKPOINT,
	BP_WRITE_WATCHPOINT,
	BP_READ_WATCHPOINT,
	BP_ACCESS_WATCHPOINT
};

enum kgdb_bpstate {
	BP_UNDEFINED = 0,
	BP_REMOVED,
	BP_SET,
	BP_ACTIVE
};

struct kgdb_bkpt {
	unsigned long		bpt_addr;
	unsigned char		saved_instr[BREAK_INSTR_SIZE];
	enum kgdb_bptype	type;
	enum kgdb_bpstate	state;
};

83 84 85 86 87 88 89 90 91 92 93 94 95
struct dbg_reg_def_t {
	char *name;
	int size;
	int offset;
};

#ifndef DBG_MAX_REG_NUM
#define DBG_MAX_REG_NUM 0
#else
extern struct dbg_reg_def_t dbg_reg_def[];
extern char *dbg_get_reg(int regno, void *mem, struct pt_regs *regs);
extern int dbg_set_reg(int regno, void *mem, struct pt_regs *regs);
#endif
J
Jason Wessel 已提交
96 97 98 99 100 101 102 103 104 105
#ifndef KGDB_MAX_BREAKPOINTS
# define KGDB_MAX_BREAKPOINTS	1000
#endif

#define KGDB_HW_BREAKPOINT	1

/*
 * Functions each KGDB-supporting architecture must provide:
 */

J
Jason Wessel 已提交
106
/**
J
Jason Wessel 已提交
107 108 109 110 111 112 113
 *	kgdb_arch_init - Perform any architecture specific initalization.
 *
 *	This function will handle the initalization of any architecture
 *	specific callbacks.
 */
extern int kgdb_arch_init(void);

J
Jason Wessel 已提交
114
/**
J
Jason Wessel 已提交
115 116 117 118 119 120 121
 *	kgdb_arch_exit - Perform any architecture specific uninitalization.
 *
 *	This function will handle the uninitalization of any architecture
 *	specific callbacks, for dynamic registration and unregistration.
 */
extern void kgdb_arch_exit(void);

J
Jason Wessel 已提交
122
/**
J
Jason Wessel 已提交
123 124 125 126 127 128 129 130 131
 *	pt_regs_to_gdb_regs - Convert ptrace regs to GDB regs
 *	@gdb_regs: A pointer to hold the registers in the order GDB wants.
 *	@regs: The &struct pt_regs of the current process.
 *
 *	Convert the pt_regs in @regs into the format for registers that
 *	GDB expects, stored in @gdb_regs.
 */
extern void pt_regs_to_gdb_regs(unsigned long *gdb_regs, struct pt_regs *regs);

J
Jason Wessel 已提交
132
/**
J
Jason Wessel 已提交
133 134 135 136 137 138 139 140 141 142 143 144 145 146
 *	sleeping_thread_to_gdb_regs - Convert ptrace regs to GDB regs
 *	@gdb_regs: A pointer to hold the registers in the order GDB wants.
 *	@p: The &struct task_struct of the desired process.
 *
 *	Convert the register values of the sleeping process in @p to
 *	the format that GDB expects.
 *	This function is called when kgdb does not have access to the
 *	&struct pt_regs and therefore it should fill the gdb registers
 *	@gdb_regs with what has	been saved in &struct thread_struct
 *	thread field during switch_to.
 */
extern void
sleeping_thread_to_gdb_regs(unsigned long *gdb_regs, struct task_struct *p);

J
Jason Wessel 已提交
147
/**
J
Jason Wessel 已提交
148 149 150 151 152 153 154 155 156
 *	gdb_regs_to_pt_regs - Convert GDB regs to ptrace regs.
 *	@gdb_regs: A pointer to hold the registers we've received from GDB.
 *	@regs: A pointer to a &struct pt_regs to hold these values in.
 *
 *	Convert the GDB regs in @gdb_regs into the pt_regs, and store them
 *	in @regs.
 */
extern void gdb_regs_to_pt_regs(unsigned long *gdb_regs, struct pt_regs *regs);

J
Jason Wessel 已提交
157
/**
J
Jason Wessel 已提交
158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178
 *	kgdb_arch_handle_exception - Handle architecture specific GDB packets.
 *	@vector: The error vector of the exception that happened.
 *	@signo: The signal number of the exception that happened.
 *	@err_code: The error code of the exception that happened.
 *	@remcom_in_buffer: The buffer of the packet we have read.
 *	@remcom_out_buffer: The buffer of %BUFMAX bytes to write a packet into.
 *	@regs: The &struct pt_regs of the current process.
 *
 *	This function MUST handle the 'c' and 's' command packets,
 *	as well packets to set / remove a hardware breakpoint, if used.
 *	If there are additional packets which the hardware needs to handle,
 *	they are handled here.  The code should return -1 if it wants to
 *	process more packets, and a %0 or %1 if it wants to exit from the
 *	kgdb callback.
 */
extern int
kgdb_arch_handle_exception(int vector, int signo, int err_code,
			   char *remcom_in_buffer,
			   char *remcom_out_buffer,
			   struct pt_regs *regs);

J
Jason Wessel 已提交
179
/**
J
Jason Wessel 已提交
180 181 182 183
 *	kgdb_roundup_cpus - Get other CPUs into a holding pattern
 *	@flags: Current IRQ state
 *
 *	On SMP systems, we need to get the attention of the other CPUs
184
 *	and get them into a known state.  This should do what is needed
J
Jason Wessel 已提交
185 186 187 188 189 190 191 192 193 194 195 196
 *	to get the other CPUs to call kgdb_wait(). Note that on some arches,
 *	the NMI approach is not used for rounding up all the CPUs. For example,
 *	in case of MIPS, smp_call_function() is used to roundup CPUs. In
 *	this case, we have to make sure that interrupts are enabled before
 *	calling smp_call_function(). The argument to this function is
 *	the flags that will be used when restoring the interrupts. There is
 *	local_irq_save() call before kgdb_roundup_cpus().
 *
 *	On non-SMP systems, this is not called.
 */
extern void kgdb_roundup_cpus(unsigned long flags);

197 198 199 200 201 202 203 204 205 206 207
/**
 *	kgdb_arch_set_pc - Generic call back to the program counter
 *	@regs: Current &struct pt_regs.
 *  @pc: The new value for the program counter
 *
 *	This function handles updating the program counter and requires an
 *	architecture specific implementation.
 */
extern void kgdb_arch_set_pc(struct pt_regs *regs, unsigned long pc);


J
Jason Wessel 已提交
208 209 210 211 212
/* Optional functions. */
extern int kgdb_validate_break_address(unsigned long addr);
extern int kgdb_arch_set_breakpoint(unsigned long addr, char *saved_instr);
extern int kgdb_arch_remove_breakpoint(unsigned long addr, char *bundle);

213 214 215 216 217 218 219 220 221 222 223
/**
 *	kgdb_arch_late - Perform any architecture specific initalization.
 *
 *	This function will handle the late initalization of any
 *	architecture specific callbacks.  This is an optional function for
 *	handling things like late initialization of hw breakpoints.  The
 *	default implementation does nothing.
 */
extern void kgdb_arch_late(void);


J
Jason Wessel 已提交
224
/**
J
Jason Wessel 已提交
225 226 227 228 229 230 231 232 233 234 235
 * struct kgdb_arch - Describe architecture specific values.
 * @gdb_bpt_instr: The instruction to trigger a breakpoint.
 * @flags: Flags for the breakpoint, currently just %KGDB_HW_BREAKPOINT.
 * @set_breakpoint: Allow an architecture to specify how to set a software
 * breakpoint.
 * @remove_breakpoint: Allow an architecture to specify how to remove a
 * software breakpoint.
 * @set_hw_breakpoint: Allow an architecture to specify how to set a hardware
 * breakpoint.
 * @remove_hw_breakpoint: Allow an architecture to specify how to remove a
 * hardware breakpoint.
236 237
 * @disable_hw_break: Allow an architecture to specify how to disable
 * hardware breakpoints for a single cpu.
J
Jason Wessel 已提交
238 239 240 241 242 243 244 245 246 247 248 249 250
 * @remove_all_hw_break: Allow an architecture to specify how to remove all
 * hardware breakpoints.
 * @correct_hw_break: Allow an architecture to specify how to correct the
 * hardware debug registers.
 */
struct kgdb_arch {
	unsigned char		gdb_bpt_instr[BREAK_INSTR_SIZE];
	unsigned long		flags;

	int	(*set_breakpoint)(unsigned long, char *);
	int	(*remove_breakpoint)(unsigned long, char *);
	int	(*set_hw_breakpoint)(unsigned long, int, enum kgdb_bptype);
	int	(*remove_hw_breakpoint)(unsigned long, int, enum kgdb_bptype);
251
	void	(*disable_hw_break)(struct pt_regs *regs);
J
Jason Wessel 已提交
252 253 254 255
	void	(*remove_all_hw_break)(void);
	void	(*correct_hw_break)(void);
};

J
Jason Wessel 已提交
256
/**
J
Jason Wessel 已提交
257 258 259 260 261 262 263 264 265 266
 * struct kgdb_io - Describe the interface for an I/O driver to talk with KGDB.
 * @name: Name of the I/O driver.
 * @read_char: Pointer to a function that will return one char.
 * @write_char: Pointer to a function that will write one char.
 * @flush: Pointer to a function that will flush any pending writes.
 * @init: Pointer to a function that will initialize the device.
 * @pre_exception: Pointer to a function that will do any prep work for
 * the I/O driver.
 * @post_exception: Pointer to a function that will do any cleanup work
 * for the I/O driver.
267 268
 * @is_console: 1 if the end device is a console 0 if the I/O device is
 * not a console
J
Jason Wessel 已提交
269 270 271 272 273 274 275 276 277
 */
struct kgdb_io {
	const char		*name;
	int			(*read_char) (void);
	void			(*write_char) (u8);
	void			(*flush) (void);
	int			(*init) (void);
	void			(*pre_exception) (void);
	void			(*post_exception) (void);
278
	int			is_console;
J
Jason Wessel 已提交
279 280 281 282
};

extern struct kgdb_arch		arch_kgdb_ops;

283 284
extern unsigned long __weak kgdb_arch_pc(int exception, struct pt_regs *regs);

J
Jason Wessel 已提交
285 286
extern int kgdb_register_io_module(struct kgdb_io *local_kgdb_io_ops);
extern void kgdb_unregister_io_module(struct kgdb_io *local_kgdb_io_ops);
287
extern struct kgdb_io *dbg_io_ops;
J
Jason Wessel 已提交
288

289
extern int kgdb_hex2long(char **ptr, unsigned long *long_val);
290
extern char *kgdb_mem2hex(char *mem, char *buf, int count);
J
Jason Wessel 已提交
291 292 293
extern int kgdb_hex2mem(char *buf, char *mem, int count);

extern int kgdb_isremovedbreak(unsigned long addr);
294
extern void kgdb_schedule_breakpoint(void);
J
Jason Wessel 已提交
295 296 297 298 299

extern int
kgdb_handle_exception(int ex_vector, int signo, int err_code,
		      struct pt_regs *regs);
extern int kgdb_nmicallback(int cpu, void *regs);
300
extern void gdbstub_exit(int status);
J
Jason Wessel 已提交
301 302 303

extern int			kgdb_single_step;
extern atomic_t			kgdb_active;
J
Jason Wessel 已提交
304 305
#define in_dbg_master() \
	(raw_smp_processor_id() == atomic_read(&kgdb_active))
306 307
extern bool dbg_is_early;
extern void __init dbg_late_init(void);
J
Jason Wessel 已提交
308 309
#else /* ! CONFIG_KGDB */
#define in_dbg_master() (0)
310
#define dbg_late_init()
J
Jason Wessel 已提交
311
#endif /* ! CONFIG_KGDB */
J
Jason Wessel 已提交
312
#endif /* _KGDB_H_ */