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 | 598cc9dc84aeaa66e4a77efa9dc8ff03d5532620 (patch) | |
tree | 893c53ac4f0f6e383420bc890802b740f493e091 /gdb/nds32-tdep.c | |
parent | 8b55a7e4e5b30877e924e4b0ed0437d16ccdcedf (diff) | |
download | gdb-598cc9dc84aeaa66e4a77efa9dc8ff03d5532620.zip gdb-598cc9dc84aeaa66e4a77efa9dc8ff03d5532620.tar.gz gdb-598cc9dc84aeaa66e4a77efa9dc8ff03d5532620.tar.bz2 |
GDBARCH_BREAKPOINT_MANIPULATION and SET_GDBARCH_BREAKPOINT_MANIPULATION
Many archs have only one kind of breakpoint, so their breakpoint_from_pc
implementations are quite similar. This patch uses macro
GDBARCH_BREAKPOINT_MANIPULATION and SET_GDBARCH_BREAKPOINT_MANIPULATION
for breakpoint_from_pc, so that we can easily switch from
breakpoint_from_pc to breakpoint_kind_from_pc and sw_breakpoint_from_kind
later.
gdb:
2016-11-03 Yao Qi <yao.qi@linaro.org>
* arch-utils.h (GDBARCH_BREAKPOINT_MANIPULATION): New macro.
(SET_GDBARCH_BREAKPOINT_MANIPULATION): New macro.
aarch64-tdep.c (aarch64_breakpoint_from_pc): Remove. Use
GDBARCH_BREAKPOINT_MANIPULATION.
(aarch64_gdbarch_init): Replace set_gdbarch_breakpoint_from_pc
with SET_GDBARCH_BREAKPOINT_MANIPULATION.
* alpha-tdep.c: Likewise.
* avr-tdep.c: Likewise.
* frv-tdep.c: Likewise.
* ft32-tdep.c: Likewise.
* h8300-tdep.c: Likewise.
* hppa-tdep.c: Likewise.
* i386-tdep.c: Likewise.
* lm32-tdep.c: Likewise.
* m32c-tdep.c: Likewise.
* m68hc11-tdep.c: Likewise.
* m68k-tdep.c: Likewise.
* m88k-tdep.c: Likewise.
* mep-tdep.c: Likewise.
* microblaze-tdep.c: Likewise.
* mn10300-tdep.c: Likewise.
* moxie-tdep.c: Likewise.
* msp430-tdep.c: Likewise.
* rl78-tdep.c: Likewise.
* rx-tdep.c: Likewise.
* s390-linux-tdep.c: Likewise.
* sparc-tdep.c: Likewise.
* spu-tdep.c: Likewise.
* tilegx-tdep.c: Likewise.
* vax-tdep.c: Likewise.
* xstormy16-tdep.c: Likewise.
Diffstat (limited to 'gdb/nds32-tdep.c')
-rw-r--r-- | gdb/nds32-tdep.c | 22 |
1 files changed, 4 insertions, 18 deletions
diff --git a/gdb/nds32-tdep.c b/gdb/nds32-tdep.c index 0ec443a..618a482 100644 --- a/gdb/nds32-tdep.c +++ b/gdb/nds32-tdep.c @@ -281,24 +281,10 @@ nds32_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp) return align_down (sp, 8); } -/* Implement the "breakpoint_from_pc" gdbarch method. +/* The same insn machine code is used for little-endian and big-endian. */ +static const gdb_byte break_insn[] = { 0xEA, 0x00 }; - Use the program counter to determine the contents and size of a - breakpoint instruction. Return a pointer to a string of bytes that - encode a breakpoint instruction, store the length of the string in - *LENPTR and optionally adjust *PCPTR to point to the correct memory - location for inserting the breakpoint. */ - -static const gdb_byte * -nds32_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR *pcptr, - int *lenptr) -{ - /* The same insn machine code is used for little-endian and big-endian. */ - static const gdb_byte break_insn[] = { 0xEA, 0x00 }; - - *lenptr = sizeof (break_insn); - return break_insn; -} +GDBARCH_BREAKPOINT_MANIPULATION (nds32, break_insn) /* Implement the "dwarf2_reg_to_regnum" gdbarch method. */ @@ -2157,7 +2143,7 @@ nds32_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches) set_gdbarch_skip_prologue (gdbarch, nds32_skip_prologue); set_gdbarch_inner_than (gdbarch, core_addr_lessthan); - set_gdbarch_breakpoint_from_pc (gdbarch, nds32_breakpoint_from_pc); + SET_GDBARCH_BREAKPOINT_MANIPULATION (nds32); set_gdbarch_frame_align (gdbarch, nds32_frame_align); frame_base_set_default (gdbarch, &nds32_frame_base); |