Mirror of the gdb-patches mailing list
 help / color / mirror / Atom feed
From: Michael Snyder <msnyder@cygnus.com>
To: Daniel Jacobowitz <dmj+@andrew.cmu.edu>
Cc: gdb-patches@sources.redhat.com
Subject: Re: [PATCH/RFC] Improve the "thread_step_needed" logic
Date: Fri, 15 Jun 2001 18:13:00 -0000	[thread overview]
Message-ID: <3B2AB2D4.F8C95E0D@cygnus.com> (raw)
In-Reply-To: <20010615164433.A29314@nevyn.them.org>

Daniel Jacobowitz wrote:
> 
> On Fri, Jun 15, 2001 at 04:35:09PM -0700, Michael Snyder wrote:
> > This is a fairly significant change, that both simplifies and
> > improves the logic for deciding when a single thread should be
> > stepped (to get past a breakpoint), rather than stepping all threads.
> > In a nutshell, this replaces the state variable "thread_step_needed"
> > with the following logic in resume():
> 
> <sigh>
> 
> While you're fixing this, could you please address my issue from last
> week with this code?  Checking "step" at this point in resume() is not
> correct, since it will have been cleared if SOFTWARE_SINGLE_STEP_P ().
> 
> > --- 879,913 ----
> >     if (should_resume)
> >       {
> >         ptid_t resume_ptid;
> > +
> > +       resume_ptid = RESUME_ALL;             /* Default */
> >
> > !       if ((step || singlestep_breakpoints_inserted_p) &&
> > !       !breakpoints_inserted && breakpoint_here_p (read_pc ()))
> 
> > +
> > + #ifdef CANNOT_STEP_BREAKPOINT
> > +       /* Most targets can step a breakpoint instruction, thus executing it
> > +      normally.  But if this one cannot, just continue and we will hit
> > +      it anyway.  */
> > +       if (step && breakpoints_inserted && breakpoint_here_p (read_pc ()))
> > +     step = 0;
> > + #endif
> 
> Specifically, those bits.

Oh, sorry, I missed this part of your msg.  
Well, this isn't related to SOFTWARE_SINGLESTEP_P, 
it's a separate issue.  But if you'll notice, I believe this is also 
handled correctly, because my "thread_step_needed" test includes
(NOT breakpoints_inserted), while this CANNOT_STEP_BREAKPOINT clause
will only be taken if breakpoints_inserted is true.  So they are
mutually exclusive, if you will.  I tested this on Alpha Linux, which
does NOT use software single step, but DOES use CANNOT_STEP_BREAKPOINT,
and it works.

Michael


  parent reply	other threads:[~2001-06-15 18:13 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2001-06-15 16:35 Michael Snyder
2001-06-15 16:44 ` Daniel Jacobowitz
2001-06-15 18:05   ` Michael Snyder
2001-06-15 18:13   ` Michael Snyder [this message]
2001-06-16 11:58     ` Daniel Jacobowitz
2001-06-18  9:11       ` Michael Snyder
2001-06-18 10:37         ` Daniel Jacobowitz
2001-06-25 17:26 ` Michael Snyder

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=3B2AB2D4.F8C95E0D@cygnus.com \
    --to=msnyder@cygnus.com \
    --cc=dmj+@andrew.cmu.edu \
    --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