X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gdbserver%2Flinux-nios2-low.cc;h=693af71f29ec3daa416f55df4821520e640d3136;hb=3ca4edb6617353defacd3bf3a4ee3d458238419e;hp=a58d9ca99fb142feed4b890e90460c9ed0a74427;hpb=bd70b1f240b24d8c9b08868ca777f5a81d13c0c2;p=deliverable%2Fbinutils-gdb.git diff --git a/gdbserver/linux-nios2-low.cc b/gdbserver/linux-nios2-low.cc index a58d9ca99f..693af71f29 100644 --- a/gdbserver/linux-nios2-low.cc +++ b/gdbserver/linux-nios2-low.cc @@ -39,6 +39,8 @@ public: const regs_info *get_regs_info () override; + const gdb_byte *sw_breakpoint_from_kind (int kind, int *size) override; + protected: void low_arch_setup () override; @@ -46,12 +48,36 @@ protected: bool low_cannot_fetch_register (int regno) override; bool low_cannot_store_register (int regno) override; + + bool low_supports_breakpoints () override; + + CORE_ADDR low_get_pc (regcache *regcache) override; + + void low_set_pc (regcache *regcache, CORE_ADDR newpc) override; }; /* The singleton target ops object. */ static nios2_target the_nios2_target; +bool +nios2_target::low_supports_breakpoints () +{ + return true; +} + +CORE_ADDR +nios2_target::low_get_pc (regcache *regcache) +{ + return linux_get_pc_32bit (regcache); +} + +void +nios2_target::low_set_pc (regcache *regcache, CORE_ADDR pc) +{ + linux_set_pc_32bit (regcache, pc); +} + /* The following definition must agree with the number of registers defined in "struct user_regs" in GLIBC (sysdeps/unix/sysv/linux/nios2/sys/user.h), and also with @@ -128,10 +154,10 @@ nios2_target::low_cannot_store_register (int regno) static const unsigned int nios2_breakpoint = NIOS2_BREAKPOINT; #define nios2_breakpoint_len 4 -/* Implementation of linux_target_ops method "sw_breakpoint_from_kind". */ +/* Implementation of target ops method "sw_breakpoint_from_kind". */ -static const gdb_byte * -nios2_sw_breakpoint_from_kind (int kind, int *size) +const gdb_byte * +nios2_target::sw_breakpoint_from_kind (int kind, int *size) { *size = nios2_breakpoint_len; return (const gdb_byte *) &nios2_breakpoint; @@ -251,10 +277,6 @@ nios2_target::get_regs_info () struct linux_target_ops the_low_target = { - linux_get_pc_32bit, - linux_set_pc_32bit, - NULL, /* breakpoint_kind_from_pc */ - nios2_sw_breakpoint_from_kind, NULL, /* get_next_pcs */ 0, nios2_breakpoint_at,