Change gdb.base/skip-solib.exp deal with lack of epilogue information
authorBruno Larsen <blarsen@redhat.com>
Tue, 13 Sep 2022 16:47:05 +0000 (18:47 +0200)
committerBruno Larsen <blarsen@redhat.com>
Thu, 22 Sep 2022 09:04:17 +0000 (11:04 +0200)
commitd5bcff0343ae1a4a8be76fd8646b22f20f9ed94a
tree702c108dd57867bdc3c3c3870fdd7607000bef1b
parent07bb02de7232c7d0974007296540d9887532b952
Change gdb.base/skip-solib.exp deal with lack of epilogue information

When running gdb.base/skip-solib.exp, the backtrace tests could fail with
compilers that associated epilogue instructions with the last statement
line of the function, instead of associating it with the closing brace,
despite the feature being fully functional.  As an example, when testing
skipping the function square, the testsuite would show

Breakpoint 1, main () at (...)/binutils-gdb/gdb/testsuite/gdb.base/skip-solib-main.c:5
5         return square(0);
(gdb) step
0x00007ffff7cef560 in __libc_start_call_main () from /lib64/libc.so.6
(gdb) PASS: gdb.base/skip-solib.exp: ignoring solib file: step
bt
 #0  0x00007ffff7cef560 in __libc_start_call_main () from /lib64/libc.so.6
 #1  0x00007ffff7cef60c in __libc_start_main_impl () from /lib64/libc.so.6
 #2  0x0000000000401065 in _start ()
(gdb) FAIL: gdb.base/skip-solib.exp: ignoring solib file: bt

Which means that the feature is working, the testsuite is just
mis-identifying it.  To avoid this problem, the skipped function calls
have been sent to a line before `return`, so epilogues won't factor in.
gdb/testsuite/gdb.base/skip-solib-lib.c
gdb/testsuite/gdb.base/skip-solib-main.c