gdb/testsuite: fix gdb.reverse/solib-*.exp tests when using clang
authorGuinevere Larsen <blarsen@redhat.com>
Fri, 21 Jul 2023 11:45:12 +0000 (13:45 +0200)
committerGuinevere Larsen <blarsen@redhat.com>
Thu, 24 Aug 2023 09:08:35 +0000 (11:08 +0200)
commit890891f14de5f08a5e5bfa4a6907fb6ec409dd45
tree437337a4bedf92a34a933c9d21bd05237fec3649
parenta47dae3f3a6265576a876c9d6229c8e1e29d5636
gdb/testsuite: fix gdb.reverse/solib-*.exp tests when using clang

The tests gdb.reverse/solib-precsave.exp and solib-reverse.exp have the
assumption that line tables will have an entry for the closing } in a
function. Not all compiles do this, one example being clang. To fix
this, this commit changes the function in shr2.c to have multiple lines,
and the test to accept either line as a correct step location.

To properly re-sync the inferiors, the function repeat_cmd_until had to
be slightly changed to work with empty "current locations", so that we
are able to step through multiple lines.

This also changes the annotations used to determine the breakpoint
locations in solib-reverse.c, adding a simple variable assignment right
before the return statement. This way GDB will not set a breakpoint in
the closing } line.

Approved-By: Tom Tromey <tom@tromey.com>
gdb/testsuite/gdb.reverse/shr2.c
gdb/testsuite/gdb.reverse/solib-precsave.exp
gdb/testsuite/gdb.reverse/solib-reverse.c
gdb/testsuite/gdb.reverse/solib-reverse.exp
gdb/testsuite/lib/gdb.exp