| /* Low level child interface to ptrace. | 
 |  | 
 |    Copyright (C) 2004-2023 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 INF_PTRACE_H | 
 | #define INF_PTRACE_H | 
 |  | 
 | #include "gdbsupport/event-pipe.h" | 
 | #include "inf-child.h" | 
 |  | 
 | /* An abstract prototype ptrace target.  The client can override it | 
 |    with local methods.  */ | 
 |  | 
 | struct inf_ptrace_target : public inf_child_target | 
 | { | 
 |   ~inf_ptrace_target () override = 0; | 
 |  | 
 |   void attach (const char *, int) override; | 
 |  | 
 |   void detach (inferior *inf, int) override; | 
 |  | 
 |   void close () override; | 
 |  | 
 |   void resume (ptid_t, int, enum gdb_signal) override; | 
 |  | 
 |   ptid_t wait (ptid_t, struct target_waitstatus *, target_wait_flags) override; | 
 |  | 
 |   void files_info () override; | 
 |  | 
 |   void kill () override; | 
 |  | 
 |   void create_inferior (const char *, const std::string &, | 
 | 			char **, int) override; | 
 |  | 
 |   void mourn_inferior () override; | 
 |  | 
 |   bool thread_alive (ptid_t ptid) override; | 
 |  | 
 |   std::string pid_to_str (ptid_t) override; | 
 |  | 
 |   enum target_xfer_status xfer_partial (enum target_object object, | 
 | 					const char *annex, | 
 | 					gdb_byte *readbuf, | 
 | 					const gdb_byte *writebuf, | 
 | 					ULONGEST offset, ULONGEST len, | 
 | 					ULONGEST *xfered_len) override; | 
 |  | 
 |   bool is_async_p () override | 
 |   { return m_event_pipe.is_open (); } | 
 |  | 
 |   int async_wait_fd () override | 
 |   { return m_event_pipe.event_fd (); } | 
 |  | 
 |   /* Helper routine used from SIGCHLD handlers to signal the async | 
 |      event pipe.  */ | 
 |   static void async_file_mark_if_open () | 
 |   { | 
 |     if (m_event_pipe.is_open ()) | 
 |       m_event_pipe.mark (); | 
 |   } | 
 |  | 
 | protected: | 
 |   /* Helper routines for interacting with the async event pipe.  */ | 
 |   bool async_file_open () | 
 |   { return m_event_pipe.open_pipe (); } | 
 |   void async_file_close () | 
 |   { m_event_pipe.close_pipe (); } | 
 |   void async_file_flush () | 
 |   { m_event_pipe.flush (); } | 
 |   void async_file_mark () | 
 |   { m_event_pipe.mark (); } | 
 |  | 
 |   /* Cleanup the inferior after a successful ptrace detach.  */ | 
 |   void detach_success (inferior *inf); | 
 |  | 
 |   /* Some targets don't allow us to request notification of inferior events | 
 |      such as fork and vfork immediately after the inferior is created. | 
 |      (This is because of how gdb creates inferiors via invoking a shell to | 
 |      do it.  In such a scenario, if the shell init file has commands in it, | 
 |      the shell will fork and exec for each of those commands, and we will | 
 |      see each such fork event.  Very bad.) | 
 |  | 
 |      Such targets will supply an appropriate definition for this | 
 |      function.  */ | 
 |   virtual void post_startup_inferior (ptid_t ptid) = 0; | 
 |  | 
 | private: | 
 |   static event_pipe m_event_pipe; | 
 | }; | 
 |  | 
 | #ifndef __NetBSD__ | 
 | /* Return which PID to pass to ptrace in order to observe/control the | 
 |    tracee identified by PTID. | 
 |  | 
 |    Unlike most other Operating Systems, NetBSD tracks both pid and lwp | 
 |    and avoids this function.  */ | 
 |  | 
 | extern pid_t get_ptrace_pid (ptid_t); | 
 | #endif | 
 |  | 
 | #endif |