aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sh/include
diff options
context:
space:
mode:
authorPaul Mundt <lethal@linux-sh.org>2012-04-17 03:22:04 -0400
committerPaul Mundt <lethal@linux-sh.org>2012-04-17 03:22:04 -0400
commit9d773d378d9b7272c6cefad5cb41b5e57c96b7a0 (patch)
treee4f51b9b1d018c10204f35ae89eb955935d67aba /arch/sh/include
parent856cb4bb337ee50427e2b8daaf3a8d61de8a4f44 (diff)
parent21cb20d758254e68a369ba83c721f8ce083e6659 (diff)
Merge branch 'sh/kgdb' into sh-latest
Diffstat (limited to 'arch/sh/include')
-rw-r--r--arch/sh/include/asm/kgdb.h30
1 files changed, 14 insertions, 16 deletions
diff --git a/arch/sh/include/asm/kgdb.h b/arch/sh/include/asm/kgdb.h
index f3613952d1ae..9e7d2d1b03e0 100644
--- a/arch/sh/include/asm/kgdb.h
+++ b/arch/sh/include/asm/kgdb.h
@@ -4,18 +4,6 @@
4#include <asm/cacheflush.h> 4#include <asm/cacheflush.h>
5#include <asm/ptrace.h> 5#include <asm/ptrace.h>
6 6
7/* Same as pt_regs but has vbr in place of syscall_nr */
8struct kgdb_regs {
9 unsigned long regs[16];
10 unsigned long pc;
11 unsigned long pr;
12 unsigned long sr;
13 unsigned long gbr;
14 unsigned long mach;
15 unsigned long macl;
16 unsigned long vbr;
17};
18
19enum regnames { 7enum regnames {
20 GDB_R0, GDB_R1, GDB_R2, GDB_R3, GDB_R4, GDB_R5, GDB_R6, GDB_R7, 8 GDB_R0, GDB_R1, GDB_R2, GDB_R3, GDB_R4, GDB_R5, GDB_R6, GDB_R7,
21 GDB_R8, GDB_R9, GDB_R10, GDB_R11, GDB_R12, GDB_R13, GDB_R14, GDB_R15, 9 GDB_R8, GDB_R9, GDB_R10, GDB_R11, GDB_R12, GDB_R13, GDB_R14, GDB_R15,
@@ -23,17 +11,27 @@ enum regnames {
23 GDB_PC, GDB_PR, GDB_SR, GDB_GBR, GDB_MACH, GDB_MACL, GDB_VBR, 11 GDB_PC, GDB_PR, GDB_SR, GDB_GBR, GDB_MACH, GDB_MACL, GDB_VBR,
24}; 12};
25 13
26#define NUMREGBYTES ((GDB_VBR + 1) * 4) 14#define _GP_REGS 16
15#define _EXTRA_REGS 7
16#define GDB_SIZEOF_REG sizeof(u32)
17
18#define DBG_MAX_REG_NUM (_GP_REGS + _EXTRA_REGS)
19#define NUMREGBYTES (DBG_MAX_REG_NUM * sizeof(GDB_SIZEOF_REG))
27 20
28static inline void arch_kgdb_breakpoint(void) 21static inline void arch_kgdb_breakpoint(void)
29{ 22{
30 __asm__ __volatile__ ("trapa #0x3c\n"); 23 __asm__ __volatile__ ("trapa #0x3c\n");
31} 24}
32 25
33#define BUFMAX 2048
34
35#define CACHE_FLUSH_IS_SAFE 1
36#define BREAK_INSTR_SIZE 2 26#define BREAK_INSTR_SIZE 2
27#define BUFMAX 2048
28
29#ifdef CONFIG_SMP
30# define CACHE_FLUSH_IS_SAFE 0
31#else
32# define CACHE_FLUSH_IS_SAFE 1
33#endif
34
37#define GDB_ADJUSTS_BREAK_OFFSET 35#define GDB_ADJUSTS_BREAK_OFFSET
38 36
39#endif /* __ASM_SH_KGDB_H */ 37#endif /* __ASM_SH_KGDB_H */