Subject: gdb attach
To: None <tech-toolchain@netbsd.org, tech-kern@netbsd.org>
From: Nick Hudson <nick.hudson@dsl.pipex.com>
List: tech-kern
Date: 11/17/2006 07:39:11
--Boundary-00=_fcWXFlxSnO60NkX
Content-Type: text/plain;
charset="us-ascii"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline
Hi,
Here's a patch to make gdb6 attach work in a similar way to the fix I applied
to gdb5 for i386 only so far.
The difference is that gdb6 likes to have the filename to display and re-open
the filename after the process dies so I've added an exe symlink to procfs in
the same as Linux. I'm avoiding the discussion as to whether this is the best
way to get the filename from a pid. ;) FWIW, FreeBSD does this as well.
Any comments before I commit?
Thanks,
Nick
--Boundary-00=_fcWXFlxSnO60NkX
Content-Type: text/x-diff;
charset="us-ascii";
name="attach.diff"
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment;
filename="attach.diff"
Index: sys/miscfs/procfs/procfs_vnops.c
===================================================================
RCS file: /cvsroot/src/sys/miscfs/procfs/procfs_vnops.c,v
retrieving revision 1.137
diff -u -p -u -r1.137 procfs_vnops.c
--- sys/miscfs/procfs/procfs_vnops.c 29 Oct 2006 22:35:35 -0000 1.137
+++ sys/miscfs/procfs/procfs_vnops.c 17 Nov 2006 07:22:29 -0000
@@ -142,7 +142,7 @@ static const struct proc_target {
{ DT_REG, N("map"), PFSmap, procfs_validmap },
{ DT_REG, N("maps"), PFSmaps, procfs_validmap },
{ DT_REG, N("cmdline"), PFScmdline, NULL },
- { DT_REG, N("exe"), PFSexe, procfs_validfile_linux },
+ { DT_REG, N("exe"), PFSexe, procfs_validfile },
{ DT_LNK, N("cwd"), PFScwd, NULL },
{ DT_LNK, N("root"), PFSchroot, NULL },
{ DT_LNK, N("emul"), PFSemul, NULL },
Index: gnu/dist/gdb6/gdb/Makefile.in
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/gdb/Makefile.in,v
retrieving revision 1.1.1.2
diff -u -p -u -r1.1.1.2 Makefile.in
--- gnu/dist/gdb6/gdb/Makefile.in 2 Jul 2006 20:13:07 -0000 1.1.1.2
+++ gnu/dist/gdb6/gdb/Makefile.in 17 Nov 2006 07:23:21 -0000
@@ -748,6 +748,7 @@ mipsnbsd_tdep_h = mipsnbsd-tdep.h
mips_tdep_h = mips-tdep.h
mn10300_tdep_h = mn10300-tdep.h
monitor_h = monitor.h
+nbsd_nat_h = nbsd-nat.h
nbsd_tdep_h = nbsd-tdep.h
nto_tdep_h = nto-tdep.h $(defs_h) $(solist_h) $(osabi_h) $(regset_h)
objc_lang_h = objc-lang.h
@@ -1439,7 +1440,7 @@ ALLDEPFILES = \
mips-tdep.c mipsv4-nat.c \
mipsnbsd-nat.c mipsnbsd-tdep.c \
mips64obsd-nat.c mips64obsd-tdep.c \
- nbsd-tdep.c obsd-tdep.c \
+ nbsd-nat.c nbsd-tdep.c obsd-tdep.c \
solib-osf.c \
somread.c solib-som.c $(HPREAD_SOURCE) \
posix-hdep.c \
@@ -2356,6 +2357,7 @@ ms1-tdep.o: ms1-tdep.c $(defs_h) $(frame
$(gdb_string_h) $(regcache_h) $(reggroups_h) $(gdbcore_h) \
$(trad_frame_h) $(inferior_h) $(dwarf2_frame_h) $(infcall_h) \
$(gdb_assert_h)
+nbsd-nat.o: nbsd-nat.c $(defs_h) $(nbsd_nat_h)
nbsd-tdep.o: nbsd-tdep.c $(defs_h) $(gdb_string_h) $(solib_svr4_h)
nlmread.o: nlmread.c $(defs_h) $(bfd_h) $(symtab_h) $(symfile_h) \
$(objfiles_h) $(buildsym_h) $(stabsread_h) $(block_h)
Index: gnu/dist/gdb6/gdb/i386nbsd-nat.c
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/gdb/i386nbsd-nat.c,v
retrieving revision 1.1.1.2
diff -u -p -u -r1.1.1.2 i386nbsd-nat.c
--- gnu/dist/gdb6/gdb/i386nbsd-nat.c 2 Jul 2006 20:14:16 -0000 1.1.1.2
+++ gnu/dist/gdb6/gdb/i386nbsd-nat.c 17 Nov 2006 07:23:22 -0000
@@ -33,6 +33,7 @@
#include <machine/frame.h>
#include <machine/pcb.h>
+#include "nbsd-nat.h"
#include "bsd-kvm.h"
static int
@@ -79,9 +80,13 @@ void _initialize_i386nbsd_nat (void);
void
_initialize_i386nbsd_nat (void)
{
- /* We've got nothing to add to the common *BSD/i386 target. */
- add_target (i386bsd_target ());
+ struct target_ops *t;
+ /* Add some extra features to the common *BSD/i386 target. */
+ t = i386bsd_target ();
+ t->to_pid_to_exec_file = nbsd_pid_to_exec_file;
+ add_target (t);
+
/* Support debugging kernel virtual memory images. */
bsd_kvm_add_target (i386nbsd_supply_pcb);
}
Index: gnu/dist/gdb6/gdb/config/i386/nbsdelf.mh
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/gdb/config/i386/nbsdelf.mh,v
retrieving revision 1.1.1.1
diff -u -p -u -r1.1.1.1 nbsdelf.mh
--- gnu/dist/gdb6/gdb/config/i386/nbsdelf.mh 15 May 2006 14:12:03 -0000 1.1.1.1
+++ gnu/dist/gdb6/gdb/config/i386/nbsdelf.mh 17 Nov 2006 07:23:25 -0000
@@ -1,6 +1,6 @@
# Host: NetBSD/i386 ELF
NATDEPFILES= fork-child.o inf-ptrace.o \
- i386bsd-nat.o i386nbsd-nat.o bsd-kvm.o
+ nbsd-nat.o i386bsd-nat.o i386nbsd-nat.o bsd-kvm.o
NAT_FILE= solib.h
LOADLIBES= -lkvm
--Boundary-00=_fcWXFlxSnO60NkX
Content-Type: text/x-csrc;
charset="us-ascii";
name="nbsd-nat.c"
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment;
filename="nbsd-nat.c"
/* NetBSD-specific methods for using the /proc file system.
Copyright 2006 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
(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, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330,
Boston, MA 02111-1307, USA. */
#include <sys/param.h>
#include "defs.h"
#include "nbsd-nat.h"
char *
nbsd_pid_to_exec_file (int pid)
{
size_t len = MAXPATHLEN;
char *buf = xcalloc (len, sizeof (char));
char *path;
path = xstrprintf ("/proc/%d/exe", pid);
if (readlink (path, buf, MAXPATHLEN) == -1)
{
xfree (buf);
buf = NULL;
}
xfree (path);
return buf;
}
--Boundary-00=_fcWXFlxSnO60NkX
Content-Type: text/x-chdr;
charset="us-ascii";
name="nbsd-nat.h"
Content-Transfer-Encoding: 7bit
Content-Disposition: attachment;
filename="nbsd-nat.h"
/* Native-dependent code for NetBSD.
Copyright (C) 2006 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
(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, write to the Free Software
Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA. */
#ifndef NBSD_NAT_H
#define NBSD_NAT_H
/* Return a the name of file that can be opened to get the symbols for
the child process identified by PID. */
extern char *nbsd_pid_to_exec_file (int pid);
#endif /* nbsd-nat.h */
--Boundary-00=_fcWXFlxSnO60NkX--