diff options
author | Yao Qi <yao.qi@linaro.org> | 2016-11-03 14:35:13 +0000 |
---|---|---|
committer | Yao Qi <yao.qi@linaro.org> | 2016-11-03 14:35:13 +0000 |
commit | d19280adb5b2d1470dc39756ccac8a8fa2af8321 (patch) | |
tree | c452ae7ecd2c45f4dfbfe404eb4bd5a7c99aaf28 /gdb/nios2-tdep.c | |
parent | 44f1c4d7b0160a51ecf7fe1af42416f1d2a71356 (diff) | |
download | gdb-d19280adb5b2d1470dc39756ccac8a8fa2af8321.zip gdb-d19280adb5b2d1470dc39756ccac8a8fa2af8321.tar.gz gdb-d19280adb5b2d1470dc39756ccac8a8fa2af8321.tar.bz2 |
Split breakpoint_from_pc to breakpoint_kind_from_pc and sw_breakpoint_from_kind
We convert each ARCH_breakpoint_from_pc to ARCH_breakpoint_kind_from_pc
and ARCH_sw_breakpoint_from_kind. Note that gdbarch doesn't have methods
breakpoint_kind_from_pc and sw_breakpoint_from_kind so far.
gdb:
2016-11-03 Yao Qi <yao.qi@linaro.org>
* arch-utils.h (GDBARCH_BREAKPOINT_FROM_PC): New macro.
(GDBARCH_BREAKPOINT_MANIPULATION_ENDIAN): New macro.
* arm-tdep.c (arm_breakpoint_from_pc): Remove.
(arm_breakpoint_kind_from_pc): New function.
(arm_sw_breakpoint_from_kind): New function.
(arm_breakpoint_from_pc): Call arm_breakpoint_kind_from_pc
and arm_sw_breakpoint_from_kind.
Use GDBARCH_BREAKPOINT_FROM_PC.
(arm_remote_breakpoint_from_pc): Call
arm_breakpoint_kind_from_pc.
(arm_gdbarch_init): Replace set_gdbarch_breakpoint_from_pc
with SET_GDBARCH_BREAKPOINT_MANIPULATION.
* arc-tdep.c: Likewise.
* bfin-tdep.c: Likewise.
* cris-tdep.c: Likewise.
* iq2000-tdep.c: Likewise.
* m32r-tdep.c: Likewise.
* mips-tdep.c: Likewise.
* mt-tdep.c: Likewise.
* nios2-tdep.c: Likewise.
* rs6000-tdep.c: Likewise.
* score-tdep.c: Likewise.
* sh-tdep.c: Likewise.
* sh64-tdep.c: Likewise.
* tic6x-tdep.c: Likewise.
* v850-tdep.c: Likewise.
* xtensa-tdep.c: Likewise.
Diffstat (limited to 'gdb/nios2-tdep.c')
-rw-r--r-- | gdb/nios2-tdep.c | 98 |
1 files changed, 59 insertions, 39 deletions
diff --git a/gdb/nios2-tdep.c b/gdb/nios2-tdep.c index 3ff325f..57fd331 100644 --- a/gdb/nios2-tdep.c +++ b/gdb/nios2-tdep.c @@ -1694,9 +1694,30 @@ nios2_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR start_pc) return nios2_analyze_prologue (gdbarch, start_pc, start_pc, &cache, NULL); } -/* Implement the breakpoint_from_pc gdbarch hook. +static int +nios2_breakpoint_kind_from_pc (struct gdbarch *gdbarch, CORE_ADDR *pcptr) +{ + unsigned long mach = gdbarch_bfd_arch_info (gdbarch)->mach; + + if (mach == bfd_mach_nios2r2) + { + unsigned int insn; + const struct nios2_opcode *op + = nios2_fetch_insn (gdbarch, *pcptr, &insn); + + if (op && op->size == NIOS2_CDX_OPCODE_SIZE) + return NIOS2_CDX_OPCODE_SIZE; + else + return NIOS2_OPCODE_SIZE; + } + else + return NIOS2_OPCODE_SIZE; +} - The Nios II ABI for Linux says: "Userspace programs should not use +static const gdb_byte * +nios2_sw_breakpoint_from_kind (struct gdbarch *gdbarch, int kind, int *size) +{ +/* The Nios II ABI for Linux says: "Userspace programs should not use the break instruction and userspace debuggers should not insert one." and "Userspace breakpoints are accomplished using the trap instruction with immediate operand 31 (all ones)." @@ -1704,54 +1725,53 @@ nios2_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR start_pc) So, we use "trap 31" consistently as the breakpoint on bare-metal as well as Linux targets. */ -static const gdb_byte* -nios2_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR *bp_addr, - int *bp_size) -{ - enum bfd_endian byte_order_for_code = gdbarch_byte_order_for_code (gdbarch); - unsigned long mach = gdbarch_bfd_arch_info (gdbarch)->mach; + /* R2 trap encoding: + ((0x2d << 26) | (0x1f << 21) | (0x1d << 16) | (0x20 << 0)) + 0xb7fd0020 + CDX trap.n encoding: + ((0xd << 12) | (0x1f << 6) | (0x9 << 0)) + 0xd7c9 + Note that code is always little-endian on R2. */ + *size = kind; - if (mach == bfd_mach_nios2r2) + if (kind == NIOS2_CDX_OPCODE_SIZE) { - /* R2 trap encoding: - ((0x2d << 26) | (0x1f << 21) | (0x1d << 16) | (0x20 << 0)) - 0xb7fd0020 - CDX trap.n encoding: - ((0xd << 12) | (0x1f << 6) | (0x9 << 0)) - 0xd7c9 - Note that code is always little-endian on R2. */ - static const gdb_byte r2_breakpoint_le[] = {0x20, 0x00, 0xfd, 0xb7}; static const gdb_byte cdx_breakpoint_le[] = {0xc9, 0xd7}; - unsigned int insn; - const struct nios2_opcode *op - = nios2_fetch_insn (gdbarch, *bp_addr, &insn); - if (op && op->size == NIOS2_CDX_OPCODE_SIZE) + return cdx_breakpoint_le; + } + else + { + unsigned long mach = gdbarch_bfd_arch_info (gdbarch)->mach; + + if (mach == bfd_mach_nios2r2) { - *bp_size = NIOS2_CDX_OPCODE_SIZE; - return cdx_breakpoint_le; + static const gdb_byte r2_breakpoint_le[] = {0x20, 0x00, 0xfd, 0xb7}; + + return r2_breakpoint_le; } else { - *bp_size = NIOS2_OPCODE_SIZE; - return r2_breakpoint_le; + enum bfd_endian byte_order_for_code + = gdbarch_byte_order_for_code (gdbarch); + /* R1 trap encoding: + ((0x1d << 17) | (0x2d << 11) | (0x1f << 6) | (0x3a << 0)) + 0x003b6ffa */ + static const gdb_byte r1_breakpoint_le[] = {0xfa, 0x6f, 0x3b, 0x0}; + static const gdb_byte r1_breakpoint_be[] = {0x0, 0x3b, 0x6f, 0xfa}; + + if (byte_order_for_code == BFD_ENDIAN_BIG) + return r1_breakpoint_be; + else + return r1_breakpoint_le; } } - else - { - /* R1 trap encoding: - ((0x1d << 17) | (0x2d << 11) | (0x1f << 6) | (0x3a << 0)) - 0x003b6ffa */ - static const gdb_byte r1_breakpoint_le[] = {0xfa, 0x6f, 0x3b, 0x0}; - static const gdb_byte r1_breakpoint_be[] = {0x0, 0x3b, 0x6f, 0xfa}; - *bp_size = NIOS2_OPCODE_SIZE; - if (byte_order_for_code == BFD_ENDIAN_BIG) - return r1_breakpoint_be; - else - return r1_breakpoint_le; - } } +/* Implement the breakpoint_from_pc gdbarch hook. */ + +GDBARCH_BREAKPOINT_FROM_PC (nios2) + /* Implement the print_insn gdbarch method. */ static int @@ -2316,7 +2336,7 @@ nios2_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) set_gdbarch_skip_prologue (gdbarch, nios2_skip_prologue); set_gdbarch_stack_frame_destroyed_p (gdbarch, nios2_stack_frame_destroyed_p); - set_gdbarch_breakpoint_from_pc (gdbarch, nios2_breakpoint_from_pc); + SET_GDBARCH_BREAKPOINT_MANIPULATION (nios2); set_gdbarch_dummy_id (gdbarch, nios2_dummy_id); set_gdbarch_unwind_pc (gdbarch, nios2_unwind_pc); |