Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: John Baldwin <jhb@freebsd.org>
To: Luis Machado <lgustavo@codesourcery.com>
Cc: gdb-patches@sourceware.org, binutils@sourceware.org
Subject: Re: [PATCH v2 3/3] Add native target for FreeBSD/mips.
Date: Thu, 08 Dec 2016 20:09:00 -0000	[thread overview]
Message-ID: <1801089.38MhW5CcGm@ralph.baldwin.cx> (raw)
In-Reply-To: <472bfba9-72b3-4432-95d9-e4b523667d1f@codesourcery.com>

On Thursday, December 08, 2016 12:53:06 PM Luis Machado wrote:
> On 12/06/2016 03:00 PM, John Baldwin wrote:
> > This supports the o32 and n64 ABIs.
> >
> > gdb/ChangeLog:
> >
> > 	* Makefile.in (ALLDEPFILES): Add mips-fbsd-nat.c.
> > 	* config/mips/fbsd.mh: New file.
> > 	* configure.host: Add mips*-*-freebsd*.
> > 	* mips-fbsd-nat.c: New file.
> > ---
> >  gdb/ChangeLog           |   7 +++
> >  gdb/Makefile.in         |   1 +
> >  gdb/config/mips/fbsd.mh |   3 ++
> >  gdb/configure.host      |   1 +
> >  gdb/mips-fbsd-nat.c     | 141 ++++++++++++++++++++++++++++++++++++++++++++++++
> >  5 files changed, 153 insertions(+)
> >  create mode 100644 gdb/config/mips/fbsd.mh
> >  create mode 100644 gdb/mips-fbsd-nat.c
> >
> > diff --git a/gdb/ChangeLog b/gdb/ChangeLog
> > index 890702e..fc43f81 100644
> > --- a/gdb/ChangeLog
> > +++ b/gdb/ChangeLog
> > @@ -1,5 +1,12 @@
> >  2016-12-06  John Baldwin  <jhb@FreeBSD.org>
> >
> > +	* Makefile.in (ALLDEPFILES): Add mips-fbsd-nat.c.
> > +	* config/mips/fbsd.mh: New file.
> > +	* configure.host: Add mips*-*-freebsd*.
> > +	* mips-fbsd-nat.c: New file.
> > +
> > +2016-12-06  John Baldwin  <jhb@FreeBSD.org>
> > +
> >  	* Makefile.in (ALL_TARGET_OBS): Add mips-fbsd-tdep.o.
> >  	(ALLDEPFILES): Add mips-fbsd-tdep.c.
> >  	* configure.tgt: Add mips*-*-freebsd*.
> > diff --git a/gdb/Makefile.in b/gdb/Makefile.in
> > index e34fa4a..dee9d73 100644
> > --- a/gdb/Makefile.in
> > +++ b/gdb/Makefile.in
> > @@ -2542,6 +2542,7 @@ ALLDEPFILES = \
> >  	microblaze-linux-tdep.c \
> >  	microblaze-tdep.c \
> >  	mingw-hdep.c \
> > +	mips-fbsd-nat.c \
> >  	mips-fbsd-tdep.c \
> >  	mips-linux-nat.c \
> >  	mips-linux-tdep.c \
> > diff --git a/gdb/config/mips/fbsd.mh b/gdb/config/mips/fbsd.mh
> > new file mode 100644
> > index 0000000..f433347
> > --- /dev/null
> > +++ b/gdb/config/mips/fbsd.mh
> > @@ -0,0 +1,3 @@
> > +# Host: FreeBSD/mips
> > +NATDEPFILES= fork-child.o inf-ptrace.o fbsd-nat.o mips-fbsd-nat.o
> > +HAVE_NATIVE_GCORE_HOST = 1
> 
> I suppose you tried the gcore command for native GDB on FreeBSD/MIPS and 
> it worked fine?

It mostly does.  I can read the core fine using native GDB on MIPS, but
an x86 GDB doesn't parse the generated core correctly (though it does
parse a native core from the kernel correctly).  The issue here though
isn't really a MIPS-specific one.  Right now the FreeBSD target-dependent
code uses code from binutils to write out the prpsinfo and prstatus notes
and those write Linux-style "CORE" notes.  I have a todo to fix gcore in
gdb to write out "FreeBSD" process and thread status notes instead which
will fix this (along with a separate, but somewhat similar issue with
gdb's gcore on FreeBSD/powerpc).
 
> > +/* Determine if PT_GETREGS fetches this register.  */
> > +
> > +static bool
> > +getregs_supplies (struct gdbarch *gdbarch, int regnum)
> > +{
> > +  return ((regnum) >= MIPS_ZERO_REGNUM
> > +	  && (regnum) <= gdbarch_pc_regnum (gdbarch));
> > +}
> > +
> 
> Not sure we need the extra ()'s around regnum.

Oops, will fix.

> Otherwise i have no further comments on this one.
> 
> I'm guessing someone from binutils' side will want to validate 1/3.

Yes.

-- 
John Baldwin


  reply	other threads:[~2016-12-08 20:09 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-12-06 21:01 [PATCH v2 0/3] Add FreeBSD/mips targets to GDB John Baldwin
2016-12-06 21:01 ` [PATCH v2 1/3] Use the ELF class to determine the word size for FreeBSD core notes John Baldwin
2016-12-13 11:04   ` Nick Clifton
2016-12-23 20:35     ` John Baldwin
2016-12-06 21:01 ` [PATCH v2 2/3] Add FreeBSD/mips architecture John Baldwin
2016-12-08 18:47   ` Luis Machado
2016-12-08 20:08     ` John Baldwin
2016-12-08 20:13       ` Luis Machado
2016-12-09 19:02         ` John Baldwin
2016-12-16 12:22   ` GDB attribution policy (Re: [PATCH v2 2/3] Add FreeBSD/mips architecture.) Pedro Alves
2017-01-10 16:19     ` Pedro Alves
2016-12-06 21:01 ` [PATCH v2 3/3] Add native target for FreeBSD/mips John Baldwin
2016-12-08 18:53   ` Luis Machado
2016-12-08 20:09     ` John Baldwin [this message]
2016-12-08 20:15       ` Luis Machado
2016-12-16 12:50 ` [PATCH v2 0/3] Add FreeBSD/mips targets to GDB Pedro Alves

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1801089.38MhW5CcGm@ralph.baldwin.cx \
    --to=jhb@freebsd.org \
    --cc=binutils@sourceware.org \
    --cc=gdb-patches@sourceware.org \
    --cc=lgustavo@codesourcery.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox