- Maintenance scripts: * Add KFAILs in qa.sh. * Add missing '-a' in gdb.log greps in qa.sh. - Disable big endian powerpc. - Maintenance scripts: * Fix patch filtering in clean.sh. * Add KFAIL in qa.sh. - Patches added: * gdb-testsuite-add-checks-to-gdb.arch-i386-sse.exp.patch * gdb-testsuite-add-gdb.testsuite-dump-system-info.exp.patch * gdb-testsuite-add-kfail-in-gdb.threads-fork-plus-threads.exp.patch * gdb-testsuite-factor-out-dump_info-in-gdb.testsuite-dump-system-info.exp.patch * gdb-testsuite-fix-fail-in-gdb.threads-fork-and-threads.exp.patch * gdb-testsuite-fix-gdb.threads-linux-dp.exp.patch * gdb-testsuite-fix-port-detection-in-gdb.debuginfod-fetch_src_and_symbols.exp.patch * gdb-testsuite-handle-recursive-internal-problem-in-gdb_internal_error_resync.patch * gdb-testsuite-handle-runto-fail-in-gdb.mi-mi-var-cp.exp.patch * gdb-tui-fix-breakpoint-display-functionality.patch * gdb-testsuite-Fix-gdb.threads-thread-specific-bp.exp.patch - Patches dropped: * fix-gdb.threads-linux-dp.exp.patch - Added maintenance script: * qa.sh - Drop 32bit packages for s390x. - Fix SLE-15 s390x: unresolvable, nothing provides glibc-devel-static-32bit. - Disable test-case gdb.base/break-interp.exp for SLE-11. It causes a "glibc detected *** expect: double free or corruption (out)" in expect and a subsequent runtest abort. This might be the cause of the package build failure due to "Job seems to be stuck here, killed. (after 8hrs of inactivity)" - Patches added: * gdb-testsuite-fix-gdb.base-step-over-syscall.exp-with-m32-amd-case.patch * gdb-testsuite-fix-gdb.ada-big_packed_array.exp-xfail-for-m32.patch * gdb-testsuite-fix-race-in-gdb.threads-detach-step-over.exp.patch * fix-gdb.multi-multi-term-settings.exp-race.patch * gdb-testsuite-update-test-gdb.base-step-over-syscall.exp.patch - Rebase to 11.1 release (as in fedora 35 @ 9cd9368): * GDB now supports general memory tagging functionality if the underlying architecture supports the proper primitives and hooks. Currently this is enabled only for AArch64 MTE. * GDB will now look for the .gdbinit file in a config directory before looking for ~/.gdbinit. The file is searched for in the following locations: $XDG_CONFIG_HOME/gdb/gdbinit, $HOME/.config/gdb/gdbinit, $HOME/.gdbinit. * GDB will now load and process commands from ~/.config/gdb/gdbearlyinit or ~/.gdbearlyinit if these files are present. These files are processed earlier than any of the other initialization files and can affect parts of GDB's startup that previously had already been completed before the initialization files were read, for example styling of the initial GDB greeting. * GDB now has two new options "--early-init-command" and "--early-init-eval-command" with corresponding short options "-eix" and "-eiex" that allow options (that would normally appear in a gdbearlyinit file) to be passed on the command line. * set startup-quietly on|off show startup-quietly When 'on', this causes GDB to act as if "-silent" were passed on the command line. This command needs to be added to an early initialization file (e.g. ~/.config/gdb/gdbearlyinit) in order to affect GDB. * For RISC-V targets, the target feature "org.gnu.gdb.riscv.vector" is now understood by GDB, and can be used to describe the vector registers of a target. * TUI windows now support mouse actions. The mouse wheel scrolls the appropriate window. * Key combinations that do not have a specific action on the focused window are passed to GDB. For example, you now can use Ctrl-Left/Ctrl-Right to move between words in the command window regardless of which window is in focus. Previously you would need to focus on the command window for such key combinations to work. * set python ignore-environment on|off show python ignore-environment When 'on', this causes GDB's builtin Python to ignore any environment variables that would otherwise affect how Python behaves. This command needs to be added to an early initialization file (e.g. ~/.config/gdb/gdbearlyinit) in order to affect GDB. * set python dont-write-bytecode auto|on|off show python dont-write-bytecode When 'on', this causes GDB's builtin Python to not write any byte-code (.pyc files) to disk. This command needs to be added to an early initialization file (e.g. ~/.config/gdb/gdbearlyinit) in order to affect GDB. When 'off' byte-code will always be written. When set to 'auto' (the default) Python will check the PYTHONDONTWRITEBYTECODE environment variable. * break [PROBE_MODIFIER] [LOCATION] [thread THREADNUM] [-force-condition] [if CONDITION] This command would previously refuse setting a breakpoint if the CONDITION expression is invalid at a location. It now accepts and defines the breakpoint if there is at least one location at which the CONDITION is valid. The locations for which the CONDITION is invalid, are automatically disabled. If CONDITION is invalid at all of the locations, setting the breakpoint is still rejected. However, the '-force-condition' flag can be used in this case for forcing GDB to define the breakpoint, making all the current locations automatically disabled. This may be useful if the user knows the condition will become meaningful at a future location, e.g. due to a shared library load. - Update libipt to v2.0.4. Dropped obsoleted patch: * v1.5-libipt-static.patch - Obsoleted fedora patches dropped: * gdb-moribund-utrace-workaround.patch * gdb-save-restore-file-offset-while-reading-notes-in-core-file.patch * gdb-vla-intel-fix-print-char-array.patch * gdb-vla-intel-fortran-strides.patch * gdb-vla-intel-fortran-vla-strings.patch * gdb-vla-intel-stringbt-fix.patch * gdb-vla-intel-tests.patch - Obsoleted fedora fixup patches dropped: * fixup-2-gdb-archer-vla-tests.patch * fixup-2-gdb-rhbz1156192-recursive-dlopen-test.patch * fixup-3-gdb-archer-vla-tests.patch * fixup-gdb-6.3-test-pie-20050107.patch * fixup-gdb-6.3-threaded-watchpoints2-20050225.patch * fixup-gdb-6.5-sharedlibrary-path.patch * fixup-gdb-6.8-bz442765-threaded-exec-test.patch * fixup-gdb-archer-vla-tests.patch * fixup-gdb-base-gnu-ifunc-strstr-workaround-exp.patch * fixup-gdb-btrobust.patch * fixup-gdb-bz634108-solib_address.patch * fixup-gdb-dts-rhel6-python-compat.patch * fixup-gdb-gnat-dwarf-crash-3of3.patch * fixup-gdb-rhbz1156192-recursive-dlopen-test.patch * fixup-gdb-test-ivy-bridge.patch * fixup-gdb-vla-intel-fortran-vla-strings.patch * fixup-gdb-vla-intel-tests.patch - Obsoleted patches dropped: * amd64-linux-siginfo-include-order.patch * gdb-powerpc-remove-512-bytes-region-limit-if-2nd-dawr-is-avaliable.patch * gdb-support-dw-lle-start-end.patch * gdb-symtab-fix-infinite-recursion-in-dwarf2_cu-get_builder-again.patch * gdb-symtab-fix-language-of-frame-without-debug-info.patch * gdb-symtab-read-cu-base-address-for-enqueued-cu.patch * gdb-symtab-use-early-continue-in-find_pc_sect_compunit.patch * gdb-testsuite-catch-condition-evaluation-errors-in-gdb-assert.patch * gdb-testsuite-detect-gdb-prompt-after-monitor-exit.patch * gdb-testsuite-disable-selftests-for-factory.patch * gdb-testsuite-fix-control-flow-in-gdb-reverse-insn-reverse-exp.patch * gdb-testsuite-fix-failure-in-gdb-base-step-over-no-symbols-exp.patch * gdb-testsuite-fix-gdb-dlang-watch-loc-exp-on-ppc64.patch * gdb-testsuite-fix-gdb-reverse-insn-reverse-x86-c-for-m32.patch * gdb-testsuite-fix-gdb.arch-amd64-stap-three-arg-disp.s.patch * gdb-testsuite-fix-unset-of-debuginfod_urls-in-default_gdb_init.patch * gdb-testsuite-fix-xfail-handling-in-gdb.threads-gcore-thread.exp.patch * gdb-testsuite-gdb-base-morestack-exp-no-clang.patch * gdb-testsuite-gdb-tui-new-layout-exp-partly-require-tcl86.patch * gdb-testsuite-handle-sigill-in-gdb-reverse-insn-reverse-exp.patch * gdb-testsuite-ignore-debuginfod_urls.patch * gdb-testsuite-prevent-pagination-in-gdb-internalflags.patch * gdb-threads-fix-lin_thread_get_thread_signals-for-glibc-2.28.patch * gdb-try-to-load-libthread_db-only-after-reading-all-shared-libraries-when-attaching.patch * gdb-tui-fix-len_without_escapes-in-tui-disasm.c.patch - Fedora patches updated: * gdb-6.3-bz140532-ppc-unwinding-test.patch * gdb-6.3-bz202689-exec-from-pthread-test.patch * gdb-6.3-gstack-20050411.patch * gdb-6.3-inheritancetest-20050726.patch * gdb-6.3-mapping-zero-inode-test.patch * gdb-6.3-test-dtorfix-20050121.patch * gdb-6.3-test-movedir-20050125.patch * gdb-6.3-threaded-watchpoints2-20050225.patch * gdb-6.5-bz109921-DW_AT_decl_file-test.patch * gdb-6.5-bz185337-resolve-tls-without-debuginfo-v2.patch * gdb-6.5-bz218379-ppc-solib-trampoline-test.patch * gdb-6.5-bz243845-stale-testing-zombie-test.patch * gdb-6.5-ia64-libunwind-leak-test.patch * gdb-6.5-last-address-space-byte-test.patch * gdb-6.5-readline-long-line-crash-test.patch * gdb-6.5-section-num-fixup-test.patch * gdb-6.5-sharedlibrary-path.patch * gdb-6.6-buildid-locate-rpm-scl.patch * gdb-6.6-buildid-locate-rpm.patch * gdb-6.6-buildid-locate-solib-missing-ids.patch * gdb-6.6-buildid-locate.patch * gdb-6.6-bz229517-gcore-without-terminal.patch * gdb-6.6-bz230000-power6-disassembly-test.patch * gdb-6.6-bz237572-ppc-atomic-sequence-test.patch * gdb-6.8-bz442765-threaded-exec-test.patch * gdb-bz601887-dwarf4-rh-test.patch * gdb-bz634108-solib_address.patch * gdb-ccache-workaround.patch * gdb-container-rh-pkg.patch * gdb-fedora-libncursesw.patch * gdb-fortran-frame-string.patch * gdb-glibc-strstr-workaround.patch * gdb-lineno-makeup-test.patch * gdb-linux_perf-bundle.patch * gdb-physname-pr11734-test.patch * gdb-ppc-power7-test.patch * gdb-rhbz1156192-recursive-dlopen-test.patch * gdb-rhbz1261564-aarch64-hw-watchpoint-test.patch * gdb-rhbz1350436-type-printers-error.patch * gdb-rhbz1398387-tab-crash-test.patch * gdb-test-dw2-aranges.patch * gdb-test-ivy-bridge.patch * gdb-test-pid0-core.patch - Patches updated: * gdb-fix-selftest-fails-with-gdb-build-with-O2-flto.patch * gdb-gcore-bash.patch - Fedora patches added: * gdb-6.3-attach-see-vdso-test.patch * gdb-6.3-inferior-notification-20050721.patch * gdb-6.5-gcore-buffer-limit-test.patch * gdb-6.5-missed-trap-on-step-test.patch * gdb-rhbz1976887-field-location-kind.patch * gdb-rhbz2012976-paper-over-fortran-lex-problems.patch * gdb-test-for-rhbz1976887.patch - Fedora fixup patches added: * fixup-2-gdb-6.6-buildid-locate.patch * fixup-gdb-glibc-strstr-workaround.patch * fixup-gdb-linux_perf-bundle.patch * fixup-gdb-rhbz1325795-framefilters-test.patch * fixup-gdb-rhbz1553104-s390x-arch12-test.patch - Patches added: * fix-gdb.mi-new-ui-mi-sync.exp.patch * fix-gdb.threads-linux-dp.exp.patch * gdb-add-index.sh-fix-bashism.patch * gdb-build-add-cxx_dialect-to-cxx.patch * gdb-build-make-c-exp.y-work-with-bison-3.8.patch * gdb-python-finishbreakpoint-update.patch * gdb-symtab-add-call_site_eq-and-call_site_hash.patch * gdb-symtab-c-ify-call_site.patch * gdb-symtab-fix-htab_find_slot-call-in-read_call_site_scope.patch * gdb-symtab-remove-compunit_call_site_htab.patch * gdb-symtab-use-unrelocated-addresses-in-call_site.patch * gdb-testsuite-add-nopie-in-two-test-cases.patch * gdb-testsuite-fix-fail-in-gdb.base-annota1.exp.patch * gdb-testsuite-fix-fail-in-gdb.tui-corefile-run.exp.patch * gdb-testsuite-fix-gdb.base-dcache-flush.exp.patch * gdb-testsuite-fix-gdb.gdb-selftest.exp.patch * gdb-testsuite-fix-gdb.python-py-events.exp.patch * gdb-testsuite-fix-gdb.server-server-kill.exp-with-m32.patch * gdb-testsuite-fix-gdb.threads-check-libthread-db.exp-with-glibc-2.34.patch * gdb-testsuite-handle-supports_memtag-in-gdb.base-gdb-caching-proc.exp.patch * gdb-testsuite-prevent-compilation-fails-with-unix-fpie-pie.patch * gdb-testsuite-refactor-regexp-in-gdb.base-annota1.exp.patch * gdb-testsuite-support-fpie-fno-pie-pie-no-pie-in-gdb_compile_rust.patch * gdb-testsuite-use-compiler-generated-instead-of-gas-generated-stabs.patch - Fedora patches replaced: * fixup-gdb-6.6-buildid-locate.patch - Added maintenance scripts: * import-patches.sh * clean.sh OBS-URL: https://build.opensuse.org/request/show/927907 OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gdb?expand=0&rev=289
183 lines
6.8 KiB
Diff
183 lines
6.8 KiB
Diff
Fix gdb.multi/multi-term-settings.exp race
|
|
|
|
The gdb.multi/multi-term-settings.exp testcase sometimes fails like so:
|
|
|
|
Running /home/pedro/gdb/mygit/src/gdb/testsuite/gdb.multi/multi-term-settings.exp ...
|
|
FAIL: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: stop with control-c (SIGINT)
|
|
|
|
It's easier to reproduce if you stress the machine at the same time, like e.g.:
|
|
|
|
$ stress -c 24
|
|
|
|
Looking at gdb.log, we see:
|
|
|
|
(gdb) attach 60422
|
|
Attaching to program: build/gdb/testsuite/outputs/gdb.multi/multi-term-settings/multi-term-settings, process 60422
|
|
[New Thread 60422.60422]
|
|
Reading symbols from /lib/x86_64-linux-gnu/libc.so.6...
|
|
Reading symbols from /usr/lib/debug//lib/x86_64-linux-gnu/libc-2.31.so...
|
|
Reading symbols from /lib64/ld-linux-x86-64.so.2...
|
|
(No debugging symbols found in /lib64/ld-linux-x86-64.so.2)
|
|
0x00007f2fc2485334 in __GI___clock_nanosleep (clock_id=<optimized out>, clock_id@entry <mailto:clock_id@entry>=0, flags=flags@entry <mailto:flags@entry>=0, req=req@entry <mailto:req@entry>=0x7ffe23126940, rem=rem@entry <mailto:rem@entry>=0x0) at ../sysdeps/unix/sysv/linux/clock_nanosleep.c:78
|
|
78 ../sysdeps/unix/sysv/linux/clock_nanosleep.c: No such file or directory.
|
|
(gdb) PASS: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: inf2: attach
|
|
set schedule-multiple on
|
|
(gdb) PASS: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: set schedule-multiple on
|
|
info inferiors
|
|
Num Description Connection Executable
|
|
1 process 60404 1 (extended-remote localhost:2349) build/gdb/testsuite/outputs/gdb.multi/multi-term-settings/multi-term-settings
|
|
* 2 process 60422 1 (extended-remote localhost:2349) build/gdb/testsuite/outputs/gdb.multi/multi-term-settings/multi-term-settings
|
|
(gdb) PASS: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: info inferiors
|
|
pid=60422, count=46
|
|
pid=60422, count=47
|
|
pid=60422, count=48
|
|
pid=60422, count=49
|
|
pid=60422, count=50
|
|
pid=60422, count=51
|
|
pid=60422, count=52
|
|
pid=60422, count=53
|
|
pid=60422, count=54
|
|
pid=60422, count=55
|
|
pid=60422, count=56
|
|
pid=60422, count=57
|
|
pid=60422, count=58
|
|
pid=60422, count=59
|
|
pid=60422, count=60
|
|
pid=60422, count=61
|
|
pid=60422, count=62
|
|
pid=60422, count=63
|
|
pid=60422, count=64
|
|
pid=60422, count=65
|
|
pid=60422, count=66
|
|
pid=60422, count=67
|
|
pid=60422, count=68
|
|
pid=60422, count=69
|
|
pid=60404, count=54
|
|
pid=60404, count=55
|
|
pid=60404, count=56
|
|
pid=60404, count=57
|
|
pid=60404, count=58
|
|
PASS: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: continue
|
|
Quit
|
|
(gdb) FAIL: gdb.multi/multi-term-settings.exp: inf1_how=attach: inf2_how=attach: stop with control-c (SIGINT)
|
|
|
|
If you look at the testcase's sources, you'll see that the intention
|
|
is to resumes the program with "continue", wait to see a few of those
|
|
"pid=..., count=..." lines, and then interrupt the program with
|
|
Ctrl-C. But somehow, that resulted in GDB printing "Quit", instead of
|
|
the Ctrl-C stopping the program with SIGINT.
|
|
|
|
Here's what is happening:
|
|
|
|
#1 - those "pid=..., count=..." lines we see above weren't actually
|
|
output by the inferior after it has been continued (see #1).
|
|
Note that "inf1_how" and "inf2_how" are "attach". What happened
|
|
is that those "pid=..., count=..." lines were output by the
|
|
inferiors _before_ they were attached to. We see them at that
|
|
point instead of earlier, because that's where the testcase
|
|
reads from the inferiors' spawn_ids.
|
|
|
|
#2 - The testcase mistakenly thinks those "pid=..., count=..." lines
|
|
happened after the continue was processed by GDB, meaning it has
|
|
waited enough, and so sends the Ctrl-C. GDB hasn't yet passed
|
|
the terminal to the inferior, so the Ctrl-C results in that
|
|
Quit.
|
|
|
|
The fix here is twofold:
|
|
|
|
#1 - flush inferior output right after attaching
|
|
|
|
#2 - consume the "Continuing" printed by "continue", indicating the
|
|
inferior has the terminal. This is the same as done throughout
|
|
the testsuite to handle this exact problem of sending Ctrl-C too
|
|
soon.
|
|
|
|
gdb/testsuite/ChangeLog:
|
|
yyyy-mm-dd Pedro Alves <pedro@palves.net <mailto:pedro@palves.net>>
|
|
|
|
* gdb.multi/multi-term-settings.exp (create_inferior): Flush
|
|
inferior output.
|
|
(coretest): Use $gdb_test_name. After issuing "continue", wait
|
|
for "Continuing".
|
|
|
|
Change-Id: Iba7671dfe1eee6b98d29cfdb05a1b9aa2f9defb9
|
|
|
|
---
|
|
gdb/testsuite/gdb.multi/multi-term-settings.exp | 40 +++++++++++++++++++++----
|
|
1 file changed, 34 insertions(+), 6 deletions(-)
|
|
|
|
diff --git a/gdb/testsuite/gdb.multi/multi-term-settings.exp b/gdb/testsuite/gdb.multi/multi-term-settings.exp
|
|
index 20ec03d94b3..dcc6f2ece0f 100644
|
|
--- a/gdb/testsuite/gdb.multi/multi-term-settings.exp
|
|
+++ b/gdb/testsuite/gdb.multi/multi-term-settings.exp
|
|
@@ -95,6 +95,22 @@ proc create_inferior {which_inf inf_how} {
|
|
if {[gdb_test "attach $testpid" \
|
|
"Attaching to program: .*, process $testpid.*(in|at).*" \
|
|
"attach"] == 0} {
|
|
+
|
|
+ # The program is now stopped, but if testing against
|
|
+ # gdbserver, then the inferior's output emmitted before it
|
|
+ # stopped isn't flushed unless we explicitly do so,
|
|
+ # because it is on a different spawn_id. Do it now, to
|
|
+ # avoid confusing tests further below.
|
|
+ gdb_test_multiple "" "flush inferior output" {
|
|
+ -timeout 1
|
|
+ -i $test_spawn_id -re "pid=" {
|
|
+ exp_continue
|
|
+ }
|
|
+ timeout {
|
|
+ pass $gdb_test_name
|
|
+ }
|
|
+ }
|
|
+
|
|
return $test_spawn_id
|
|
}
|
|
} else {
|
|
@@ -179,9 +195,9 @@ proc coretest {inf1_how inf2_how} {
|
|
uplevel 1 {
|
|
if {$count1 >= 3 && $count2 >= 3} {
|
|
if $expect_ttou {
|
|
- fail "$test (expected SIGTTOU)"
|
|
+ fail "$gdb_test_name (expected SIGTTOU)"
|
|
} else {
|
|
- pass $test
|
|
+ pass $gdb_test_name
|
|
}
|
|
} else {
|
|
exp_continue
|
|
@@ -195,8 +211,20 @@ proc coretest {inf1_how inf2_how} {
|
|
set count1 0
|
|
set count2 0
|
|
|
|
- set test "continue"
|
|
- gdb_test_multiple $test $test {
|
|
+ # We're going to interrupt with Ctrl-C. For this to work we must
|
|
+ # be sure to consume the "Continuing." message first, or GDB may
|
|
+ # still own the terminal. Also, note that in the attach case, we
|
|
+ # flushed inferior output right after attaching, so that we're
|
|
+ # sure that the "pid=" lines we see are emitted by the inferior
|
|
+ # after it is continued, instead of having been emitted before it
|
|
+ # was attached to.
|
|
+ gdb_test_multiple "continue" "continue, hand over terminal" {
|
|
+ -re "Continuing" {
|
|
+ pass $gdb_test_name
|
|
+ }
|
|
+ }
|
|
+
|
|
+ gdb_test_multiple "" "continue" {
|
|
-i $infs_spawn_ids -re "pid=$pid1, count=" {
|
|
incr count1
|
|
pass_or_exp_continue
|
|
@@ -207,9 +235,9 @@ proc coretest {inf1_how inf2_how} {
|
|
}
|
|
-i $gdb_spawn_id -re "received signal SIGTTOU.*$gdb_prompt " {
|
|
if $expect_ttou {
|
|
- pass "$test (expected SIGTTOU)"
|
|
+ pass "$gdb_test_name (expected SIGTTOU)"
|
|
} else {
|
|
- fail "$test (SIGTTOU)"
|
|
+ fail "$gdb_test_name (SIGTTOU)"
|
|
}
|
|
}
|
|
}
|