Mirror of the gdb mailing list
 help / color / mirror / Atom feed
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


  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