*** empty log message ***
[deliverable/binutils-gdb.git] / gdb / linux-nat.h
index da62c76d58b9e27c1d59ba8c9f501daa3730832d..82cf51b9bf29106bd74d0ef604028065be572872 100644 (file)
@@ -1,11 +1,13 @@
 /* Native debugging support for GNU/Linux (LWP layer).
-   Copyright 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
+
+   Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
+   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 2 of the License, or
+   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,
@@ -14,9 +16,9 @@
    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, write to the Free Software
-   Foundation, Inc., 59 Temple Place - Suite 330,
-   Boston, MA 02111-1307, USA.  */
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+#include "target.h"
 
 /* Structure describing an LWP.  */
 
@@ -52,30 +54,47 @@ struct lwp_info
   /* Non-zero if we were stepping this LWP.  */
   int step;
 
+  /* If WAITSTATUS->KIND != TARGET_WAITKIND_SPURIOUS, the waitstatus
+     for this LWP's last event.  This may correspond to STATUS above,
+     or to a local variable in lin_lwp_wait.  */
+  struct target_waitstatus waitstatus;
+
   /* Next LWP in list.  */
   struct lwp_info *next;
 };
 
-/* Read/write to target memory via the Linux kernel's "proc file
-   system".  */
-struct mem_attrib;
-struct target_ops;
+/* Attempt to initialize libthread_db.  */
+void check_for_thread_db (void);
 
-extern int linux_proc_xfer_memory (CORE_ADDR addr, char *myaddr, int len,
-                                  int write, struct mem_attrib *attrib,
-                                  struct target_ops *target);
+/* Tell the thread_db layer what native target operations to use.  */
+void thread_db_init (struct target_ops *);
 
 /* Find process PID's pending signal set from /proc/pid/status.  */
 void linux_proc_pending_signals (int pid, sigset_t *pending, sigset_t *blocked, sigset_t *ignored);
 
 /* linux-nat functions for handling fork events.  */
-extern void linux_record_stopped_pid (int pid);
 extern void linux_enable_event_reporting (ptid_t ptid);
-extern ptid_t linux_handle_extended_wait (int pid, int status,
-                                         struct target_waitstatus *ourstatus);
-extern void linux_child_post_startup_inferior (ptid_t ptid);
+
+extern int lin_lwp_attach_lwp (ptid_t ptid, int verbose);
 
 /* Iterator function for lin-lwp's lwp list.  */
 struct lwp_info *iterate_over_lwps (int (*callback) (struct lwp_info *, 
                                                     void *), 
                                    void *data);
+
+/* Create a prototype generic GNU/Linux target.  The client can
+   override it with local methods.  */
+struct target_ops * linux_target (void);
+
+/* Create a generic GNU/Linux target using traditional 
+   ptrace register access.  */
+struct target_ops *
+linux_trad_target (CORE_ADDR (*register_u_offset)(struct gdbarch *, int, int));
+
+/* Register the customized GNU/Linux target.  This should be used
+   instead of calling add_target directly.  */
+void linux_nat_add_target (struct target_ops *);
+
+/* Update linux-nat internal state when changing from one fork
+   to another.  */
+void linux_nat_switch_fork (ptid_t new_ptid);
This page took 0.025976 seconds and 4 git commands to generate.