From: Jim Blandy <jimb@redhat.com>
To: Daniel Jacobowitz <drow@false.org>
Cc: Andrew Cagney <cagney@gnu.org>, gdb@sources.redhat.com
Subject: Re: interface to partial support for DW_OP_piece in dwarf2expr.[ch]
Date: Wed, 04 Aug 2004 23:17:00 -0000 [thread overview]
Message-ID: <vt2wu0ejy1q.fsf@zenia.home> (raw)
In-Reply-To: <20040804230242.GA10332@nevyn.them.org>
Daniel Jacobowitz <drow@false.org> writes:
> On Wed, Aug 04, 2004 at 05:19:30PM -0500, Jim Blandy wrote:
> > Well, in the immediate term, dwarf2loc.c should simply reject
> > locations with pieces, and generate an error message. This is the
> > same behavior we have now, but instead of dwarf2expr.c saying
> > "Unrecognized opcode 0x93", dwarf2loc.c can say something more
> > informative like "The value of variable 'foo' is distributed across
> > several locations, and GDB cannot access its value."
> >
> > The next step is to have something that will recognize when a series
> > of pieces is actually a reference to a single register --- presumably
> > one that GDB has a number for, but one that Dwarf only has numbers for
> > pieces of. That needs to be an arch method that recognizes the cases
> > that can be simplified, and passes on the cases it can't handle. This
> > will address all the current uses of DW_OP_piece, I believe.
>
> No, it won't. GCC already generates more than that.
Okay --- that's good to know.
> I'm dubious as to whether this step is even worthwhile. Another
> possible intermediate step is to immediately combine the pieces,
> marking the value as not_lval; read them all and piece them together in
> GDB's memory. Yes, this means that they can't be assigned to, but at
> least we'd be able to inspect them.
It seems worthwhile to me, because it will allow GDB to work
correctly, assignments and all, in the cases where the current value
structures can handle it, and it's very little work. At some point,
resources will materialize to do the larger project, but what's the
harm in getting the best behavior we can out of the current structures
until then?
next prev parent reply other threads:[~2004-08-04 23:17 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-08-03 7:15 Jim Blandy
2004-08-04 16:53 ` Andrew Cagney
[not found] ` <vt2fz7292z3 dot fsf at zenia dot home>
[not found] ` <41112BAE dot 9080304 at gnu dot org>
[not found] ` <vt2hdri4mi1 dot fsf at zenia dot home>
[not found] ` <41115B4F dot 1080700 at gnu dot org>
[not found] ` <vt2pt66zgul dot fsf at zenia dot home>
2004-08-04 18:26 ` Jim Blandy
2004-08-04 18:32 ` Andrew Cagney
2004-08-04 21:35 ` Jim Blandy
2004-08-04 21:55 ` Andrew Cagney
2004-08-04 22:22 ` Jim Blandy
2004-08-04 23:04 ` Daniel Jacobowitz
2004-08-04 23:17 ` Jim Blandy [this message]
2004-08-05 9:54 ` Mark Kettenis
2004-08-05 14:31 ` Jim Blandy
2004-08-05 16:27 ` Joel Brobecker
2004-08-05 18:45 ` Jim Blandy
2004-08-05 18:47 ` Daniel Jacobowitz
2004-08-05 19:56 ` Andrew Cagney
2004-08-05 20:36 ` Daniel Jacobowitz
2004-08-05 20:50 ` Andrew Cagney
2004-08-06 9:39 ` Eli Zaretskii
2004-08-10 19:55 ` Jim Blandy
2004-08-11 20:31 ` Jim Blandy
2004-08-11 20:33 ` Daniel Jacobowitz
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=vt2wu0ejy1q.fsf@zenia.home \
--to=jimb@redhat.com \
--cc=cagney@gnu.org \
--cc=drow@false.org \
--cc=gdb@sources.redhat.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