From: Joel Brobecker <brobecker@adacore.com>
To: Emi SUZUKI <emi-suzuki@tjsys.co.jp>
Cc: gdb@sourceware.org
Subject: Re: Watchpoint on an unloaded shared library(2)
Date: Mon, 29 Dec 2008 05:14:00 -0000 [thread overview]
Message-ID: <20081229051317.GB16483@adacore.com> (raw)
In-Reply-To: <20081217.154039.01371590.emi-suzuki@tjsys.co.jp>
> The cause of a crash is that print_one_breakpoint_location in breakpoint.c
> doesn't care about whether the expression for the watchpoint is valid:
>
> case bp_watchpoint:
> case bp_hardware_watchpoint:
> case bp_read_watchpoint:
> case bp_access_watchpoint:
> /* Field 4, the address, is omitted (which makes the columns
> not line up too nicely with the headers, but the effect
> is relatively readable). */
> if (opts.addressprint)
> ui_out_field_skip (uiout, "addr");
> annotate_field (5);
> print_expression (b->exp, stb->stream);
> ui_out_field_stream (uiout, "what", stb);
> break;
>
> Here, b->exp for the watchpoints set on an unloaded shared library can
> be NULL, because breakpoint_re_set_one has done it. However, what
> should we do instead?
>
> I have considered two solutions:
>
> a) Print b->exp_string and b->cond_string.
> We might make some effort to display it like as its expression is
> valid for annotations... I have no idea whether it is worthwhile
> to try.
I think that this is the best we can do (print exp_string).
I personally wouldn't worry about trying to massage the string
into something that would look like we're printing an expression.
I'm not even sure why we use "print_expression (b->exp) rather
than printing exp_string directly - perhaps someone does?
> b) Don't set b->exp to NULL in update_watchpoint (called by
> breakpoint_re_set_one), do_enable_breakpoint and so on.
> Maybe we should add some flags to `struct expression' to avoid
> passing invalid symtabs to some interacting functions.
I don't think we can do that. Otherwise, the expression could
reference some symbols that no longer exist.
> "Skip printing" is another possibility, but I'd ignore it: skipping
> means that the user can't refer to the information about what they
> were.
Right, as long as the watchpoint is defined, albeit disabled,
we need to show it in the list. Another alternative of your suggestion
is to not print the "what". But I would find this confusing, since
you would no longer know what the watchpoint entry is watching.
--
Joel
next prev parent reply other threads:[~2008-12-29 5:14 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-12-17 6:41 Emi SUZUKI
2008-12-29 5:14 ` Joel Brobecker [this message]
2008-12-29 13:54 ` Daniel Jacobowitz
2008-12-29 23:45 ` Pedro Alves
2008-12-30 0:01 ` Tom Tromey
2008-12-30 7:04 ` Joel Brobecker
2009-01-06 4:05 ` Emi SUZUKI
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=20081229051317.GB16483@adacore.com \
--to=brobecker@adacore.com \
--cc=emi-suzuki@tjsys.co.jp \
--cc=gdb@sourceware.org \
/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