From: Tim Newsome <tim@sifive.com>
To: Andrew Burgess <aburgess@redhat.com>
Cc: gdb <gdb@sourceware.org>
Subject: Re: gdb doesn't notice when a target resumes
Date: Fri, 6 May 2022 10:45:47 -0700 [thread overview]
Message-ID: <CAGDihenn5vthxFc6FmjsScz6vxCmVtC6tgXEg2cdod+m8dO2bw@mail.gmail.com> (raw)
In-Reply-To: <87h764mk3j.fsf@redhat.com>
Thanks, Andrew. That's pretty much my understanding too. In an ideal world
gdb would have full control of the hardware, but that's unfortunately not
the world we live in.
Tim
On Thu, May 5, 2022 at 1:58 AM Andrew Burgess <aburgess@redhat.com> wrote:
> Tim Newsome <tim@sifive.com> writes:
>
> > In a setup like this:
> > gdb --- OpenOCD --- hardware target
> >
> > I can download a program, debug, everything is fine. Let's say we're
> halted
> > somewhere.
> > Now something happens that causes the hardware target to be running again
> > and no longer halted. OpenOCD notices quickly because it polls the
> target.
> > But gdb doesn't ever notice that the target was resumed. There doesn't
> > appear to be a notification packet
> > <
> https://sourceware.org/gdb/onlinedocs/gdb/Notification-Packets.html#Notification-Packets
> >
> > for
> > OpenOCD to even communicate to gdb that the target has resumed.
> >
> > Am I missing something? Have people attempted to tackle this problem?
>
> The following is my understanding, others might have a better
> understanding that contradicts what I say here.
>
> GDB expects to be the one driving the state of the target. It's not
> expected that the target will just resume execution without GDB being
> the one to set the target resumed.
>
> And that makes sense I think. GDB is primarily a debugger. If, as a
> user, I stop the target in order to examine the state, and the hardware
> suddenly resumes execution, that's a pretty poor user experience I
> think.
>
> Depending on what the "something" is that sets the target running, you
> might have more luck if that "something" could instead tell GDB to
> resume the target.
>
> Otherwise you'd need to change GDB I think. Maybe non-stop mode could
> support the concept of the targtet asynchronously resuming... but I
> suspect it would not be a trivial addition.
>
> Thanks,
> Andrew
>
>
prev parent reply other threads:[~2022-05-06 17:45 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-05-04 19:46 Tim Newsome
2022-05-05 8:58 ` Andrew Burgess
2022-05-06 17:45 ` Tim Newsome [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=CAGDihenn5vthxFc6FmjsScz6vxCmVtC6tgXEg2cdod+m8dO2bw@mail.gmail.com \
--to=tim@sifive.com \
--cc=aburgess@redhat.com \
--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;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).