This is the mail archive of the
gdb-patches@sourceware.org
mailing list for the GDB project.
Re: [PATCH] Expect SI_KERNEL si_code for a MIPS software breakpoint trap
- From: "Maciej W. Rozycki" <macro at imgtec dot com>
- To: Pedro Alves <palves at redhat dot com>
- Cc: Luis Machado <lgustavo at codesourcery dot com>, "Maciej W. Rozycki" <macro at linux-mips dot org>, <gdb-patches at sourceware dot org>, <linux-mips at linux-mips dot org>
- Date: Fri, 19 Feb 2016 16:21:21 +0000
- Subject: Re: [PATCH] Expect SI_KERNEL si_code for a MIPS software breakpoint trap
- Authentication-results: sourceware.org; auth=none
- References: <1442592647-3051-1-git-send-email-lgustavo at codesourcery dot com> <alpine dot LFD dot 2 dot 20 dot 1509181729100 dot 10647 at eddie dot linux-mips dot org> <56B9F7E6 dot 5010006 at codesourcery dot com> <alpine dot DEB dot 2 dot 00 dot 1602092020150 dot 15885 at tp dot orcam dot me dot uk> <56BB329F dot 3080606 at codesourcery dot com> <alpine dot DEB dot 2 dot 00 dot 1602152315540 dot 15885 at tp dot orcam dot me dot uk> <56C26D8A dot 9070401 at redhat dot com>
On Tue, 16 Feb 2016, Pedro Alves wrote:
> > FWIW, I maintain it's GDB that should be handling it. What if TRAP_BRKPT
> > is reported for a breakpoint that has not been set by GDB in the first
> > place and is still there in code? I take it either GDB or gdbserver, as
> > applicable, will just sit there looping indefinitely in an attempt to
> > discard the event while executing the breakpoint instruction over and over
> > again.
>
> Nope.
>
> > There's nothing stopping the user from having a MIPS `BREAK 5'
> > instruction or say INT3 for the x86 target already present in the
> > executable being debugged.
>
> GDB only ignores the TRAP_BRKPT event if there's no "BREAK 5" instruction
> hardcoded in the binary. If there is, then the program is stopped and
> a SIGTRAP is reported to the user.
Ah, that makes a fundamental difference to me! I missed this detail from
Luis's description and concluded that GDB/gdbserver never passes along
TRAP_BRKPT events it cannot associate with a breakpoint set by itself.
> > What I think GDB ought to be doing here is caching addresses for recently
> > removed breakpoints and discarding spurious hits in that cache.
>
> That does not work in general. The most problematic archs are those that
> leave the PC pointing after the breakpoint instruction, such as x86.
> See more below.
[etc.] Fair enough. Thanks for the extra explanation.
> Remembering whether a breakpoint was inserted was what GDB used to
> do, and it was because it was problematic that "swbreak" was
> invented. See:
>
> https://sourceware.org/ml/gdb-patches/2015-02/msg00726.html
>
> Particularly:
>
> https://sourceware.org/ml/gdb-patches/2015-02/msg00730.html
OK, I can see you peek at target text in `program_breakpoint_here_p' to
see if there's a breakpoint there. With this in mind I think Luis's
change is conceptually good as it stands, although I think we should move
the MIPS case along PowerPC right away, because TRAP_BRKPT is the right
code to use here and the MIPS port has never produced it so far and
therefore there's no backwards compatibility concern if we accept both
SI_KERNEL and TRAP_BRKPT.
Luis, such an updated change is preapproved as far as I am concerned,
feel free to commit it without another review round.
As to the kernel side with the observations made in this discussion I
think we should set the trap code for SIGTRAP signals issued with BREAK
instructions to TRAP_BRKPT unconditionally, regardless of the code used.
This won't of course affect encodings which send a different signal such
as SIGFPE.
We're lacking a code suitable for (conditional) trap instructions. I
think TRAP_TRAP or suchlike needs to be added.
> > But currently there is no easy way to tell a software breakpoint hit and
> > a hardcoded trap (and maybe even a hardware breakpoint hit?) apart.
>
> Software breakpoint hits or hardcoded traps are handled the same. Even if GDB
> plants the breakpoint instruction itself with direct memory pokes (instead of
> z0 packets), the target should report "swbreak" stops, so that gdb can do
> the right thing.
Manual planting is historical AFAIK, gdbserver and other stubs used not
to support `z' packets. Now we have the right infrastructure in place and
GDB passes MIPS breakpoint encoding requirements along (although I note
that the encoding for microMIPS BREAK16 has changed with R6, so this will
have to be updated) so we could have software breakpoint support added to
MIPS gdbserver as well.
> Hardware breakpoint hits are distinguished from software breakpoint hits,
> because they're reported with "hwbreak", not "swbreak":
>
> @item hwbreak
> The packet indicates the target stopped for a hardware breakpoint.
> The @var{r} part must be left empty.
Umm, any requirements for this? We have MIPS data hardware breakpoint
support in the Linux kernel (regrettably not for instructions, but that
could be added sometime), but I can't see TRAP_HWBKPT being set for them,
they just use generic SI_KERNEL as everything else right now.
Thanks for your patience in explaining this all to me.
Maciej