2005-04-17 00:20:36 +02:00
|
|
|
/*
|
|
|
|
* May be copied or modified under the terms of the GNU General Public
|
|
|
|
* License. See linux/COPYING for more information.
|
|
|
|
*
|
|
|
|
* Based on original code by Glenn Engel, Jim Kingdon,
|
|
|
|
* David Grothe <dave@gcom.com>, Tigran Aivazian, <tigran@sco.com> and
|
|
|
|
* Amit S. Kale <akale@veritas.com>
|
|
|
|
*
|
|
|
|
* Super-H port based on sh-stub.c (Ben Lee and Steve Chamberlain) by
|
|
|
|
* Henry Bell <henry.bell@st.com>
|
|
|
|
*
|
|
|
|
* Header file for low-level support for remote debug using GDB.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __KGDB_H
|
|
|
|
#define __KGDB_H
|
|
|
|
|
|
|
|
#include <asm/ptrace.h>
|
2007-03-08 09:27:37 +01:00
|
|
|
#include <asm/cacheflush.h>
|
2005-04-17 00:20:36 +02:00
|
|
|
|
|
|
|
struct console;
|
|
|
|
|
|
|
|
/* Same as pt_regs but has vbr in place of syscall_nr */
|
|
|
|
struct kgdb_regs {
|
|
|
|
unsigned long regs[16];
|
|
|
|
unsigned long pc;
|
|
|
|
unsigned long pr;
|
|
|
|
unsigned long sr;
|
|
|
|
unsigned long gbr;
|
|
|
|
unsigned long mach;
|
|
|
|
unsigned long macl;
|
|
|
|
unsigned long vbr;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* State info */
|
|
|
|
extern char kgdb_in_gdb_mode;
|
|
|
|
extern int kgdb_done_init;
|
|
|
|
extern int kgdb_enabled;
|
|
|
|
extern int kgdb_nofault; /* Ignore bus errors (in gdb mem access) */
|
|
|
|
extern int kgdb_halt; /* Execute initial breakpoint at startup */
|
|
|
|
extern char in_nmi; /* Debounce flag to prevent NMI reentry*/
|
|
|
|
|
|
|
|
/* SCI */
|
|
|
|
extern int kgdb_portnum;
|
|
|
|
extern int kgdb_baud;
|
|
|
|
extern char kgdb_parity;
|
|
|
|
extern char kgdb_bits;
|
|
|
|
|
|
|
|
/* Init and interface stuff */
|
|
|
|
extern int kgdb_init(void);
|
|
|
|
extern int (*kgdb_getchar)(void);
|
|
|
|
extern void (*kgdb_putchar)(int);
|
|
|
|
|
|
|
|
/* Trap functions */
|
2007-03-08 09:27:37 +01:00
|
|
|
typedef void (kgdb_debug_hook_t)(struct pt_regs *regs);
|
2005-04-17 00:20:36 +02:00
|
|
|
typedef void (kgdb_bus_error_hook_t)(void);
|
|
|
|
extern kgdb_debug_hook_t *kgdb_debug_hook;
|
|
|
|
extern kgdb_bus_error_hook_t *kgdb_bus_err_hook;
|
|
|
|
|
|
|
|
/* Console */
|
|
|
|
void kgdb_console_write(struct console *co, const char *s, unsigned count);
|
2007-03-08 09:27:37 +01:00
|
|
|
extern int kgdb_console_setup(struct console *, char *);
|
2005-04-17 00:20:36 +02:00
|
|
|
|
|
|
|
/* Prototypes for jmp fns */
|
|
|
|
#define _JBLEN 9
|
|
|
|
typedef int jmp_buf[_JBLEN];
|
|
|
|
extern void longjmp(jmp_buf __jmpb, int __retval);
|
|
|
|
extern int setjmp(jmp_buf __jmpb);
|
|
|
|
|
|
|
|
/* Forced breakpoint */
|
2007-03-08 09:27:37 +01:00
|
|
|
#define breakpoint() \
|
2006-12-13 09:40:05 +01:00
|
|
|
do { \
|
|
|
|
if (kgdb_enabled) \
|
|
|
|
__asm__ __volatile__("trapa #0x3c"); \
|
2005-04-17 00:20:36 +02:00
|
|
|
} while (0)
|
|
|
|
|
|
|
|
/* KGDB should be able to flush all kernel text space */
|
|
|
|
#if defined(CONFIG_CPU_SH4)
|
|
|
|
#define kgdb_flush_icache_range(start, end) \
|
|
|
|
{ \
|
|
|
|
__flush_purge_region((void*)(start), (int)(end) - (int)(start));\
|
|
|
|
flush_icache_range((start), (end)); \
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#define kgdb_flush_icache_range(start, end) do { } while (0)
|
|
|
|
#endif
|
|
|
|
|
2006-09-27 09:24:55 +02:00
|
|
|
/* Taken from sh-stub.c of GDB 4.18 */
|
|
|
|
static const char hexchars[] = "0123456789abcdef";
|
|
|
|
|
|
|
|
/* Get high hex bits */
|
|
|
|
static inline char highhex(const int x)
|
|
|
|
{
|
|
|
|
return hexchars[(x >> 4) & 0xf];
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Get low hex bits */
|
|
|
|
static inline char lowhex(const int x)
|
|
|
|
{
|
|
|
|
return hexchars[x & 0xf];
|
|
|
|
}
|
2005-04-17 00:20:36 +02:00
|
|
|
#endif
|