diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2012-04-17 03:22:04 -0400 |
|---|---|---|
| committer | Paul Mundt <lethal@linux-sh.org> | 2012-04-17 03:22:04 -0400 |
| commit | 9d773d378d9b7272c6cefad5cb41b5e57c96b7a0 (patch) | |
| tree | e4f51b9b1d018c10204f35ae89eb955935d67aba /arch/sh/include/asm | |
| parent | 856cb4bb337ee50427e2b8daaf3a8d61de8a4f44 (diff) | |
| parent | 21cb20d758254e68a369ba83c721f8ce083e6659 (diff) | |
Merge branch 'sh/kgdb' into sh-latest
Diffstat (limited to 'arch/sh/include/asm')
| -rw-r--r-- | arch/sh/include/asm/kgdb.h | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/arch/sh/include/asm/kgdb.h b/arch/sh/include/asm/kgdb.h index f3613952d1a..9e7d2d1b03e 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 */ | ||
| 8 | struct 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 | |||
| 19 | enum regnames { | 7 | enum 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 | ||
| 28 | static inline void arch_kgdb_breakpoint(void) | 21 | static 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 */ |
