X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gdb%2Finf-child.h;h=6316f3062da106d9257b23319509770cb821e2fa;hb=bcb430e4cd5bcd913813236536031f1fc7f72aee;hp=4473cff5a8df55a4c2191c700186c7393d8a69bc;hpb=91f83b0228f795e4acb8ac6e6690c6276cbec599;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/inf-child.h b/gdb/inf-child.h index 4473cff5a8..6316f3062d 100644 --- a/gdb/inf-child.h +++ b/gdb/inf-child.h @@ -1,6 +1,6 @@ /* Base/prototype target for default child (native) targets. - Copyright (C) 2004-2014 Free Software Foundation, Inc. + Copyright (C) 2004-2018 Free Software Foundation, Inc. This file is part of GDB. @@ -20,14 +20,109 @@ #ifndef INF_CHILD_H #define INF_CHILD_H -/* Create a prototype child target. The client can override it with - local methods. */ +#include "target.h" -extern struct target_ops *inf_child_target (void); +/* A prototype child target. The client can override it with local + methods. */ + +class inf_child_target + : public memory_breakpoint_target +{ +public: + inf_child_target (); + ~inf_child_target () override = 0; + + const target_info &info () const override; + + void close () override; + + void disconnect (const char *, int) override; + + void fetch_registers (struct regcache *, int) override = 0; + void store_registers (struct regcache *, int) override = 0; + + void prepare_to_store (struct regcache *) override; + + bool supports_terminal_ours () override; + void terminal_init () override; + void terminal_inferior () override; + void terminal_ours_for_output () override; + void terminal_ours () override; + void terminal_info (const char *, int) override; + + void interrupt () override; + void pass_ctrlc () override; + + void post_startup_inferior (ptid_t) override; + + void mourn_inferior () override; + + bool can_run () override; + + bool can_create_inferior () override; + void create_inferior (const char *, const std::string &, + char **, int) override = 0; + + bool can_attach () override; + void attach (const char *, int) override = 0; + + void post_attach (int) override; + + /* We must default these because they must be implemented by any + target that can run. */ + bool can_async_p () override { return false; } + bool supports_non_stop () override { return false; } + bool supports_disable_randomization () override { return false; } + + char *pid_to_exec_file (int pid) override; + + bool has_all_memory () override; + bool has_memory () override; + bool has_stack () override; + bool has_registers () override; + bool has_execution (ptid_t) override; + + int fileio_open (struct inferior *inf, const char *filename, + int flags, int mode, int warn_if_slow, + int *target_errno) override; + int fileio_pwrite (int fd, const gdb_byte *write_buf, int len, + ULONGEST offset, int *target_errno) override; + int fileio_pread (int fd, gdb_byte *read_buf, int len, + ULONGEST offset, int *target_errno) override; + int fileio_fstat (int fd, struct stat *sb, int *target_errno) override; + int fileio_close (int fd, int *target_errno) override; + int fileio_unlink (struct inferior *inf, + const char *filename, + int *target_errno) override; + gdb::optional fileio_readlink (struct inferior *inf, + const char *filename, + int *target_errno) override; + bool use_agent (bool use) override; + + bool can_use_agent () override; + +protected: + /* Unpush the target if it wasn't explicitly open with "target native" + and there are no live inferiors left. Note: if calling this as a + result of a mourn or detach, the current inferior shall already + have its PID cleared, so it isn't counted as live. That's usually + done by calling either generic_mourn_inferior or + detach_inferior. */ + void maybe_unpush_target (); +}; /* Functions for helping to write a native target. */ /* This is for native targets which use a unix/POSIX-style waitstatus. */ extern void store_waitstatus (struct target_waitstatus *, int); +/* Register TARGET as native target and set it up to respond to the + "target native" command. */ +extern void add_inf_child_target (inf_child_target *target); + +/* target_open_ftype callback for inf-child targets. Used by targets + that want to register an alternative target_info object. Most + targets use add_inf_child_target instead. */ +extern void inf_child_open_target (const char *arg, int from_tty); + #endif