Add minimal and functional NetBSD/amd64 gdbserver
Implement the following functionality: create_inferior,
post_create_inferior, attach, kill, detach, mourn, join, thread_alive,
resume, wait, fetch_registers, store_registers, read_memory, write_memory,
request_interrupt, supports_read_auxv, read_auxv,
supports_hardware_single_step, sw_breakpoint_from_kind,
supports_z_point_type, insert_point, remove_point,
stopped_by_sw_breakpoint, supports_qxfer_siginfo, qxfer_siginfo,
supports_stopped_by_sw_breakpoint, supports_non_stop,
supports_multi_process, supports_fork_events, supports_vfork_events,
supports_exec_events, supports_disable_randomization,
supports_qxfer_libraries_svr4, qxfer_libraries_svr4,
supports_pid_to_exec_file, pid_to_exec_file, thread_name,
supports_catch_syscall.
The only CPU architecture supported: x86_64.
Implement only support for hardware assisted single step and
software breakpoint.
Implement support only for regular X86 registers, thus no FPU.
gdbserver/ChangeLog:
* netbsd-low.cc: Add.
* netbsd-low.h: Likewise.
* netbsd-amd64-low.cc: Likewise.
* Makefile.in (SFILES): Register "netbsd-low.cc", "netbsd-low.h",
"netbsd-amd64-low.cc".
* configure.srv: Add x86_64-*-netbsd*.
2020-09-03 01:35:42 +08:00
|
|
|
/* Copyright (C) 2020 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
|
|
#ifndef GDBSERVER_NETBSD_LOW_H
|
|
|
|
#define GDBSERVER_NETBSD_LOW_H
|
|
|
|
|
|
|
|
struct regcache;
|
|
|
|
struct target_desc;
|
|
|
|
|
|
|
|
/* Some information relative to a given register set. */
|
|
|
|
|
|
|
|
struct netbsd_regset_info
|
|
|
|
{
|
|
|
|
/* The ptrace request needed to get/set registers of this set. */
|
|
|
|
int get_request, set_request;
|
|
|
|
/* The size of the register set. */
|
|
|
|
int size;
|
|
|
|
/* Fill the buffer BUF from the contents of the given REGCACHE. */
|
|
|
|
void (*fill_function) (struct regcache *regcache, char *buf);
|
|
|
|
/* Store the register value in BUF in the given REGCACHE. */
|
|
|
|
void (*store_function) (struct regcache *regcache, const char *buf);
|
|
|
|
};
|
|
|
|
|
|
|
|
/* A list of regsets for the target being debugged, terminated by an entry
|
|
|
|
where the size is negative.
|
|
|
|
|
|
|
|
This list should be created by the target-specific code. */
|
|
|
|
|
|
|
|
extern struct netbsd_regset_info netbsd_target_regsets[];
|
|
|
|
|
|
|
|
/* The target-specific operations for NetBSD support. */
|
|
|
|
|
|
|
|
struct netbsd_target_ops
|
|
|
|
{
|
|
|
|
/* Architecture-specific setup. */
|
|
|
|
void (*arch_setup) ();
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Target ops definitions for a NetBSD target. */
|
|
|
|
|
|
|
|
class netbsd_process_target : public process_stratum_target
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
|
|
|
int create_inferior (const char *program,
|
|
|
|
const std::vector<char *> &program_args) override;
|
|
|
|
|
|
|
|
void post_create_inferior () override;
|
|
|
|
|
|
|
|
int attach (unsigned long pid) override;
|
|
|
|
|
|
|
|
int kill (process_info *proc) override;
|
|
|
|
|
|
|
|
int detach (process_info *proc) override;
|
|
|
|
|
|
|
|
void mourn (process_info *proc) override;
|
|
|
|
|
|
|
|
void join (int pid) override;
|
|
|
|
|
|
|
|
bool thread_alive (ptid_t pid) override;
|
|
|
|
|
|
|
|
void resume (thread_resume *resume_info, size_t n) override;
|
|
|
|
|
|
|
|
ptid_t wait (ptid_t ptid, target_waitstatus *status,
|
Make target_wait options use enum flags
This changes TARGET_WNOHANG to be a member of an enum, rather than a
define, and also adds a DEF_ENUM_FLAGS_TYPE for this type. Then, it
changes target_wait and the various target wait methods to use this
type rather than "int".
This didn't catch any bugs, but it seems like a decent cleanup
nevertheless.
I did not change deprecated_target_wait_hook, since that's only used
out-of-tree (by Insight), and there didn't seem to be a need.
I can't build some of these targets, so I modified them on a
best-effort basis. I don't think this patch should go in before the
release branch is made.
gdb/ChangeLog
2020-09-18 Tom Tromey <tromey@adacore.com>
* windows-nat.c (struct windows_nat_target) <wait>: Update.
(windows_nat_target::wait): Update.
* target/wait.h (enum target_wait_flag): New. Use
DEF_ENUM_FLAGS_TYPE.
* target/target.h (target_wait): Change type of options.
* target.h (target_options_to_string, default_target_wait):
Update.
(struct target_ops) <wait>: Change type of options.
* target.c (target_wait, default_target_wait, do_option): Change
type of "options".
(target_options_to_string): Likewise.
* target-delegates.c: Rebuild.
* target-debug.h (target_debug_print_target_wait_flags): Rename
from target_debug_print_options.
* sol-thread.c (class sol_thread_target) <wait>: Update.
(sol_thread_target::wait): Update.
* rs6000-nat.c (class rs6000_nat_target) <wait>: Update.
(rs6000_nat_target::wait): Update.
* remote.c (class remote_target) <wait, wait_ns, wait_as>:
Update.
(remote_target::wait_ns, remote_target::wait_as): Change type of
"options".
(remote_target::wait): Update.
* remote-sim.c (struct gdbsim_target) <wait>: Update.
(gdbsim_target::wait): Update.
* record-full.c (class record_full_base_target) <wait>: Update.
(record_full_wait_1): Change type of "options".
(record_full_base_target::wait): Update.
* record-btrace.c (class record_btrace_target) <wait>: Update.
(record_btrace_target::wait): Update.
* ravenscar-thread.c (struct ravenscar_thread_target) <wait>:
Update.
(ravenscar_thread_target::wait): Update.
* procfs.c (class procfs_target) <wait>: Update.
(procfs_target::wait): Update.
* obsd-nat.h (class obsd_nat_target) <wait>: Update.
* obsd-nat.c (obsd_nat_target::wait): Update.
* nto-procfs.c (struct nto_procfs_target) <wait>: Update.
(nto_procfs_target::wait): Update.
* nbsd-nat.h (struct nbsd_nat_target) <wait>: Update.
* nbsd-nat.c (nbsd_wait): Change type of "options".
(nbsd_nat_target::wait): Update.
* linux-thread-db.c (class thread_db_target) <wait>: Update.
(thread_db_target::wait): Update.
* linux-nat.h (class linux_nat_target) <wait>: Update.
* linux-nat.c (linux_nat_target::wait): Update.
(linux_nat_wait_1): Update.
* infrun.c (do_target_wait_1, do_target_wait): Change type of
"options".
* inf-ptrace.h (struct inf_ptrace_target) <wait>: Update.
* inf-ptrace.c (inf_ptrace_target::wait): Update.
* go32-nat.c (struct go32_nat_target) <wait>: Update.
(go32_nat_target::wait): Update.
* gnu-nat.h (struct gnu_nat_target) <wait>: Update.
* gnu-nat.c (gnu_nat_target::wait): Update.
* fbsd-nat.h (class fbsd_nat_target) <wait>: Update.
* fbsd-nat.c (fbsd_nat_target::wait): Update.
* darwin-nat.h (class darwin_nat_target) <wait>: Update.
* darwin-nat.c (darwin_nat_target::wait): Update.
* bsd-uthread.c (struct bsd_uthread_target) <wait>: Update.
(bsd_uthread_target::wait): Update.
* aix-thread.c (class aix_thread_target) <wait>: Update.
(aix_thread_target::wait): Update.
gdbserver/ChangeLog
2020-09-18 Tom Tromey <tromey@adacore.com>
* netbsd-low.h (class netbsd_process_target) <wait>: Update.
* netbsd-low.cc (netbsd_waitpid, netbsd_wait)
(netbsd_process_target::wait): Change type of target_options.
* win32-low.h (class win32_process_target) <wait>: Update.
* win32-low.cc (win32_process_target::wait): Update.
* target.h (class process_stratum_target) <wait>: Update.
(mywait): Update.
* target.cc (mywait, target_wait): Change type of "options".
* linux-low.h (class linux_process_target) <wait, wait_1>:
Update.
* linux-low.cc (linux_process_target::wait)
(linux_process_target::wait_1): Update.
2020-09-19 04:20:44 +08:00
|
|
|
target_wait_flags options) override;
|
Add minimal and functional NetBSD/amd64 gdbserver
Implement the following functionality: create_inferior,
post_create_inferior, attach, kill, detach, mourn, join, thread_alive,
resume, wait, fetch_registers, store_registers, read_memory, write_memory,
request_interrupt, supports_read_auxv, read_auxv,
supports_hardware_single_step, sw_breakpoint_from_kind,
supports_z_point_type, insert_point, remove_point,
stopped_by_sw_breakpoint, supports_qxfer_siginfo, qxfer_siginfo,
supports_stopped_by_sw_breakpoint, supports_non_stop,
supports_multi_process, supports_fork_events, supports_vfork_events,
supports_exec_events, supports_disable_randomization,
supports_qxfer_libraries_svr4, qxfer_libraries_svr4,
supports_pid_to_exec_file, pid_to_exec_file, thread_name,
supports_catch_syscall.
The only CPU architecture supported: x86_64.
Implement only support for hardware assisted single step and
software breakpoint.
Implement support only for regular X86 registers, thus no FPU.
gdbserver/ChangeLog:
* netbsd-low.cc: Add.
* netbsd-low.h: Likewise.
* netbsd-amd64-low.cc: Likewise.
* Makefile.in (SFILES): Register "netbsd-low.cc", "netbsd-low.h",
"netbsd-amd64-low.cc".
* configure.srv: Add x86_64-*-netbsd*.
2020-09-03 01:35:42 +08:00
|
|
|
|
|
|
|
void fetch_registers (regcache *regcache, int regno) override;
|
|
|
|
|
|
|
|
void store_registers (regcache *regcache, int regno) override;
|
|
|
|
|
|
|
|
int read_memory (CORE_ADDR memaddr, unsigned char *myaddr,
|
|
|
|
int len) override;
|
|
|
|
|
|
|
|
int write_memory (CORE_ADDR memaddr, const unsigned char *myaddr,
|
|
|
|
int len) override;
|
|
|
|
|
|
|
|
void request_interrupt () override;
|
|
|
|
|
|
|
|
bool supports_read_auxv () override;
|
|
|
|
|
|
|
|
int read_auxv (CORE_ADDR offset, unsigned char *myaddr,
|
|
|
|
unsigned int len) override;
|
|
|
|
|
|
|
|
bool supports_hardware_single_step () override;
|
|
|
|
|
|
|
|
const gdb_byte *sw_breakpoint_from_kind (int kind, int *size) override;
|
|
|
|
|
|
|
|
bool supports_z_point_type (char z_type) override;
|
|
|
|
|
|
|
|
int insert_point (enum raw_bkpt_type type, CORE_ADDR addr,
|
|
|
|
int size, struct raw_breakpoint *bp) override;
|
|
|
|
|
|
|
|
int remove_point (enum raw_bkpt_type type, CORE_ADDR addr,
|
|
|
|
int size, struct raw_breakpoint *bp) override;
|
|
|
|
|
|
|
|
bool stopped_by_sw_breakpoint () override;
|
|
|
|
|
|
|
|
bool supports_qxfer_siginfo () override;
|
|
|
|
|
|
|
|
int qxfer_siginfo (const char *annex, unsigned char *readbuf,
|
|
|
|
unsigned const char *writebuf, CORE_ADDR offset,
|
|
|
|
int len) override;
|
|
|
|
|
|
|
|
bool supports_stopped_by_sw_breakpoint () override;
|
|
|
|
|
|
|
|
bool supports_non_stop () override;
|
|
|
|
|
|
|
|
bool supports_multi_process () override;
|
|
|
|
|
|
|
|
bool supports_fork_events () override;
|
|
|
|
|
|
|
|
bool supports_vfork_events () override;
|
|
|
|
|
|
|
|
bool supports_exec_events () override;
|
|
|
|
|
|
|
|
bool supports_disable_randomization () override;
|
|
|
|
|
|
|
|
bool supports_qxfer_libraries_svr4 () override;
|
|
|
|
|
|
|
|
int qxfer_libraries_svr4 (const char*, unsigned char*, const unsigned char*,
|
|
|
|
CORE_ADDR, int) override;
|
|
|
|
|
|
|
|
bool supports_pid_to_exec_file () override;
|
|
|
|
|
|
|
|
char *pid_to_exec_file (int pid) override;
|
|
|
|
|
|
|
|
const char *thread_name (ptid_t thread) override;
|
|
|
|
|
|
|
|
bool supports_catch_syscall () override;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* The inferior's target description. This is a global because the
|
|
|
|
NetBSD ports support neither bi-arch nor multi-process. */
|
|
|
|
|
|
|
|
extern struct netbsd_target_ops the_low_target;
|
|
|
|
|
|
|
|
/* XXX: multilib */
|
|
|
|
extern const struct target_desc *netbsd_tdesc;
|
|
|
|
|
|
|
|
#endif /* GDBSERVER_NETBSD_LOW_H */
|