public inbox for gdb-patches@sourceware.org
 help / color / mirror / Atom feed
* [PATCH] [gdb/testsuite] Handle older gcc in gdb.ada/import.exp
@ 2023-10-02  6:53 Tom de Vries
  2023-10-02 15:57 ` Tom Tromey
  0 siblings, 1 reply; 2+ messages in thread
From: Tom de Vries @ 2023-10-02  6:53 UTC (permalink / raw)
  To: gdb-patches

When running test-case gdb.ada/import.exp with gcc 7, most test fail:
...
FAIL: gdb.ada/import.exp: print imported_var_ada
FAIL: gdb.ada/import.exp: print local_imported_var
FAIL: gdb.ada/import.exp: print pkg.imported_var_ada
FAIL: gdb.ada/import.exp: print pkg.exported_var_ada
FAIL: gdb.ada/import.exp: print exported_var_ada
FAIL: gdb.ada/import.exp: gdb_breakpoint: set breakpoint at pkg.imported_func_ada
FAIL: gdb.ada/import.exp: gdb_breakpoint: set breakpoint at imported_func_ada
FAIL: gdb.ada/import.exp: gdb_breakpoint: set breakpoint at local_imported_func
...

When running with gcc 8 or 9, only 2 tests fail:
...
FAIL: gdb.ada/import.exp: gdb_breakpoint: set breakpoint at pkg.imported_func_ada
FAIL: gdb.ada/import.exp: gdb_breakpoint: set breakpoint at imported_func_ada
...

The test-case passes fully with gcc 10, 11, 12 and 13.

Debug info for pragma import seems to not have been supported before gcc 8, so
require that version.

The two FAILs with gcc 8 and 9 seem to be due to problems in debug info.  Add
an xfail for these.

Tested on x86_64-linux.
---
 gdb/testsuite/gdb.ada/import.exp | 34 ++++++++++++++++++++++++++++++++
 1 file changed, 34 insertions(+)

diff --git a/gdb/testsuite/gdb.ada/import.exp b/gdb/testsuite/gdb.ada/import.exp
index 90cffa48e9c..73552483463 100644
--- a/gdb/testsuite/gdb.ada/import.exp
+++ b/gdb/testsuite/gdb.ada/import.exp
@@ -17,6 +17,12 @@ load_lib "ada.exp"
 
 require allow_ada_tests
 
+# GCC with commit ff9baa5f1c5 ("DWARF: make it possible to emit debug info for
+# declarations only") is required.  The commit makes sure that file-scope
+# function and variable declarations are emitted in dwarf.  This allows the
+# description of imported entries, making them available to the debugger.
+require {expr [gcc_major_version] >= 8}
+
 standard_ada_testfile prog
 
 set cfile "inc"
@@ -48,8 +54,36 @@ gdb_test "print pkg.imported_var_ada" " = 42"
 gdb_test "print pkg.exported_var_ada" " = 99"
 gdb_test "print exported_var_ada" " = 99"
 
+# This passes with gcc 10 but fails with gcc 9.  With gcc 9, we have:
+#   <1><1659>: Abbrev Number: 4 (DW_TAG_subprogram)
+#      <165a>   DW_AT_external    : 1
+#      <165a>   DW_AT_name        : pkg__imported_func_ada
+#      <165e>   DW_AT_decl_file   : 2
+#      <165f>   DW_AT_decl_line   : 22
+#      <1660>   DW_AT_decl_column : 13
+#      <1661>   DW_AT_linkage_name: imported_func
+#      <1665>   DW_AT_type        : <0x1669>
+# and with gcc 10 instead:
+#   <1><1670>: Abbrev Number: 4 (DW_TAG_subprogram)
+#      <1671>   DW_AT_external    : 1
+#      <1671>   DW_AT_name        : pkg__imported_func_ada
+#      <1675>   DW_AT_decl_file   : 2
+#      <1676>   DW_AT_decl_line   : 22
+#      <1677>   DW_AT_decl_column : 13
+#      <1678>   DW_AT_linkage_name: imported_func
+#      <167c>   DW_AT_type        : <0x1680>
+#      <1680>   DW_AT_declaration : 1
+# The fact that things start to work when adding the DW_AT_declaration is
+# consistent with what is described in commit ff9baa5f1c5, so xfail this
+# (without pinpointing it to a specific gcc PR or commit).
+if { [gcc_major_version] < 10 } {
+    setup_xfail *-*-*
+}
 gdb_breakpoint "pkg.imported_func_ada" message
 gdb_breakpoint "imported_func" message
+if { [gcc_major_version] < 10 } {
+    setup_xfail *-*-*
+}
 gdb_breakpoint "imported_func_ada" message
 
 gdb_breakpoint "local_imported_func" message

base-commit: f31a5e471e762e0d5507b4fa95d0dd114ef61448
-- 
2.35.3


^ permalink raw reply	[flat|nested] 2+ messages in thread

* Re: [PATCH] [gdb/testsuite] Handle older gcc in gdb.ada/import.exp
  2023-10-02  6:53 [PATCH] [gdb/testsuite] Handle older gcc in gdb.ada/import.exp Tom de Vries
@ 2023-10-02 15:57 ` Tom Tromey
  0 siblings, 0 replies; 2+ messages in thread
From: Tom Tromey @ 2023-10-02 15:57 UTC (permalink / raw)
  To: Tom de Vries via Gdb-patches; +Cc: Tom de Vries

>>>>> "Tom" == Tom de Vries via Gdb-patches <gdb-patches@sourceware.org> writes:

Tom> Debug info for pragma import seems to not have been supported before gcc 8, so
Tom> require that version.

Tom> The two FAILs with gcc 8 and 9 seem to be due to problems in debug info.  Add
Tom> an xfail for these.

Thank you.
Approved-By: Tom Tromey <tom@tromey.com>

Tom

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2023-10-02 15:57 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-10-02  6:53 [PATCH] [gdb/testsuite] Handle older gcc in gdb.ada/import.exp Tom de Vries
2023-10-02 15:57 ` Tom Tromey

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).