From: Andrew Cagney <cagney@gnu.org>
To: Joel Brobecker <brobecker@gnat.com>
Cc: gdb-patches@sources.redhat.com
Subject: Re: gdb_assert will never be triggered
Date: Thu, 29 Jul 2004 22:56:00 -0000 [thread overview]
Message-ID: <410980B2.3060308@gnu.org> (raw)
In-Reply-To: <20040722032458.GW1278@gnat.com>
>>>It looks like the assertion will always be true, due to the block
>>>> >above... Do we want to keep this gdb_assert() call nonetheless?
>>
>>>
>>> Yes. Can you post the snipped comments (both of them :-).
>
>
> Here is everything:
(catching up with the backlog)
Right. PREV_FRAME should never be NULL. Unfortunatly breakage
elsewhere means that it occasionally is :-( If we fix the breakage we
can delete that if() and then the assert will make sense :-)
Andrew
> /* Return the inner-most frame, when the caller passes in NULL. */
> /* NOTE: cagney/2002-11-09: Not sure how this would happen. The
> caller should have previously obtained a valid frame using
> get_selected_frame() and then called this code - only possibility
> I can think of is code behaving badly.
>
> NOTE: cagney/2003-01-10: Talk about code behaving badly. Check
> block_innermost_frame(). It does the sequence: frame = NULL;
> while (1) { frame = get_prev_frame (frame); .... }. Ulgh! Why
> it couldn't be written better, I don't know.
>
> NOTE: cagney/2003-01-11: I suspect what is happening in
> block_innermost_frame() is, when the target has no state
> (registers, memory, ...), it is still calling this function. The
> assumption being that this function will return NULL indicating
> that a frame isn't possible, rather than checking that the target
> has state and then calling get_current_frame() and
> get_prev_frame(). This is a guess mind. */
> if (this_frame == NULL)
> {
> /* NOTE: cagney/2002-11-09: There was a code segment here that
> would error out when CURRENT_FRAME was NULL. The comment
> that went with it made the claim ...
>
> ``This screws value_of_variable, which just wants a nice
> clean NULL return from block_innermost_frame if there are no
> frames. I don't think I've ever seen this message happen
> otherwise. And returning NULL here is a perfectly legitimate
> thing to do.''
>
> Per the above, this code shouldn't even be called with a NULL
> THIS_FRAME. */
> frame_debug_got_null_frame (gdb_stdlog, this_frame, "this_frame NULL");
> return current_frame;
> }
>
> /* There is always a frame. If this assertion fails, suspect that
> something should be calling get_selected_frame() or
> get_current_frame(). */
> gdb_assert (this_frame != NULL);
>
>>>>>
>
>
> -- Joel
prev parent reply other threads:[~2004-07-29 22:56 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2004-07-22 2:39 Joel Brobecker
2004-07-22 3:20 ` Andrew Cagney
2004-07-22 3:25 ` Joel Brobecker
2004-07-29 22:56 ` Andrew Cagney [this message]
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=410980B2.3060308@gnu.org \
--to=cagney@gnu.org \
--cc=brobecker@gnat.com \
--cc=gdb-patches@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