* gdb-rhbz1773651-gdb-index-internal-error.patch - Patches added (backport from master): * gdb-support-rseq-auxvs.patch * gdb-symtab-fix-line-number-of-static-const-class-mem.patch * gdb-symtab-fix-too-many-symbols-in-gdbpy_lookup_stat.patch * gdb-symtab-handle-pu-in-iterate_over_some_symtabs.patch * gdb-symtab-work-around-pr-gas-29517.patch * gdb-testsuite-add-kfail-for-pr-ada-30908.patch * gdb-testsuite-add-xfail-for-gdb-29965-in-gdb.threads.patch * gdb-testsuite-fix-gdb.ada-mi_task_arg.exp-with-newer.patch * gdb-testsuite-fix-gdb.arch-i386-signal.exp-on-x86_64.patch * gdb-testsuite-fix-gdb.cp-m-static.exp-regression-on-.patch * gdb-testsuite-fix-gdb.dwarf2-nullptr_t.exp-with-cc-w.patch * gdb-testsuite-fix-regexps-in-gdb.base-step-over-sysc.patch * gdb-symtab-find-main-language-without-symtab-expansi.patch * gdb-testsuite-add-wait-for-index-cache-in-gdb.dwarf2.patch - Patches moved (from "Backport from gdb-patches" to "Backports from master, available in next release"): * gdb-cli-handle-pending-c-after-rl_callback_read_char.patch * gdb-testsuite-add-have_host_locale.patch - Maintenance script qa.sh: * Remove PR28463, PR28108, PR29247 and PR29160 kfails. * Remove PR30540, PR30908, PR29965 kfails. * Remove gdb.ada/mi_task_arg.exp kfail. - Limit "Suggests: %{python}-Pygments" to SLE-15 and later. OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gdb?expand=0&rev=365
65 lines
2.3 KiB
Diff
65 lines
2.3 KiB
Diff
From ad1be044276c4727434f84ac6c554da4f2829aaf Mon Sep 17 00:00:00 2001
|
|
From: Tom de Vries <tdevries@suse.de>
|
|
Date: Tue, 26 Sep 2023 18:57:49 +0200
|
|
Subject: [PATCH 05/12] [gdb/testsuite] Fix gdb.ada/mi_task_arg.exp with newer
|
|
gcc
|
|
|
|
When running test-case gdb.ada/mi_task_arg.exp on openSUSE Tumbleweed using
|
|
gcc 13.2.1, I run into (layout adapted for readability):
|
|
...
|
|
-stack-list-arguments 1^M
|
|
^done,stack-args=[
|
|
frame={level="0",args=[]},
|
|
frame={level="1",args=[{name="<_task>",value="0x464820"},
|
|
{name="<_taskL>",value="129"}]},
|
|
frame={level="2",args=[{name="self_id",value="0x464840"}]},
|
|
frame={level="3",args=[]},
|
|
frame={level="4",args=[]}
|
|
]^M
|
|
(gdb) ^M
|
|
FAIL: gdb.ada/mi_task_arg.exp: -stack-list-arguments 1 (unexpected output)
|
|
...
|
|
|
|
On openSUSE Leap 15.4 with gcc 7.5.0 I get instead:
|
|
...
|
|
-stack-list-arguments 1^M
|
|
^done,stack-args=[
|
|
frame={level="0",args=[]},
|
|
frame={level="1",args=[{name="<_task>",value="0x444830"}]},
|
|
frame={level="2",args=[{name="self_id",value="0x444850"}]},
|
|
frame={level="3",args=[]},
|
|
frame={level="4",args=[]}]^M
|
|
(gdb) ^M
|
|
PASS: gdb.ada/mi_task_arg.exp: -stack-list-arguments 1
|
|
...
|
|
|
|
The difference in gdb output is due to difference in the dwarf generated by
|
|
the compiler, so I don't see a problem with gdb here.
|
|
|
|
Fix this by updating the test-case to accept this output.
|
|
|
|
Tested on x86_64-linux.
|
|
|
|
Approved-By: Tom Tromey <tom@tromey.com>
|
|
---
|
|
gdb/testsuite/gdb.ada/mi_task_arg.exp | 3 ++-
|
|
1 file changed, 2 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/gdb/testsuite/gdb.ada/mi_task_arg.exp b/gdb/testsuite/gdb.ada/mi_task_arg.exp
|
|
index ffee40ad044..2820f2d3722 100644
|
|
--- a/gdb/testsuite/gdb.ada/mi_task_arg.exp
|
|
+++ b/gdb/testsuite/gdb.ada/mi_task_arg.exp
|
|
@@ -49,7 +49,8 @@ if {![mi_runto "task_switch.break_me"]} {
|
|
set frame0 "frame=\{level=\"0\",args=\\\[\\\]\}"
|
|
# Frame for task_switch.caller
|
|
set frame1_args "\{name=\"<_task>\",value=\"$hex\"\}"
|
|
-set frame1 "frame=\{level=\"1\",args=\\\[$frame1_args\\\]\}"
|
|
+set frame1_opt_args "\{name=\"<_taskL>\",value=\"$decimal\"\}"
|
|
+set frame1 "frame=\{level=\"1\",args=\\\[${frame1_args}(,$frame1_opt_args)?\\\]\}"
|
|
# Frame for system.tasking.stages.task_wrapper
|
|
set frame2_args "(\{name=\"self_id\",value=\"($hex|<optimized out>)\"\})?"
|
|
set frame2 "frame=\{level=\"2\",args=\\\[$frame2_args\\\]\}"
|
|
--
|
|
2.35.3
|
|
|