]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
[gdb/symtab] Work around PR gas/29517, dwarf2 case
authorTom de Vries <tdevries@suse.de>
Thu, 2 May 2024 07:34:46 +0000 (09:34 +0200)
committerTom de Vries <tdevries@suse.de>
Thu, 2 May 2024 07:34:46 +0000 (09:34 +0200)
In commit 1d45d90934b ("[gdb/symtab] Work around PR gas/29517") we added a
workaround for PR gas/29517.

The problem is present in gas version 2.39, and fixed in 2.40, so the
workaround is only active for gas version == 2.39.

However, the problem in gas is only fixed for dwarf version >= 3, which
supports DW_TAG_unspecified_type.

Fix this by also activating the workaround for dwarf version == 2.

Tested on x86_64-linux.

Approved-by: Kevin Buettner <kevinb@redhat.com>
PR symtab/31689
https://sourceware.org/bugzilla/show_bug.cgi?id=31689

gdb/dwarf2/read.c
gdb/testsuite/gdb.dwarf2/dw2-unspecified-type-foo.c
gdb/testsuite/gdb.dwarf2/dw2-unspecified-type.c
gdb/testsuite/gdb.dwarf2/dw2-unspecified-type.exp

index 7eacafc25b5e5f5202769b18175ed510a6787489..00e8608f9ce4d770f12391435c875611357e2878 100644 (file)
@@ -14549,10 +14549,13 @@ read_subroutine_type (struct die_info *die, struct dwarf2_cu *cu)
 
   type = die_type (die, cu);
 
+  /* PR gas/29517 occurs in 2.39, and is fixed in 2.40, but it's only fixed
+     for dwarf version >= 3 which supports DW_TAG_unspecified_type.  */
   if (type->code () == TYPE_CODE_VOID
       && !type->is_stub ()
       && die->child == nullptr
-      && producer_is_gas_2_39 (cu))
+      && (cu->per_cu->version () == 2
+         || producer_is_gas_2_39 (cu)))
     {
       /* Work around PR gas/29517, pretend we have an DW_TAG_unspecified_type
         return type.  */
index 46c543b7b5984c62882fc7431d4ba1d726ae3fd3..76b8b15a7b9f28a9d26c29648bd69a5072fc3b82 100644 (file)
@@ -21,3 +21,10 @@ foo (void)
   asm ("foo_label: .globl foo_label");
   return 0;
 }
+
+int
+foo2 (void)
+{
+  asm ("foo2_label: .globl foo2_label");
+  return 0;
+}
index 666c7b70bba078e3618a67a26c49048b611953cd..7f3add04c1bf67e806b946fdaf3c8eedecd2086e 100644 (file)
@@ -16,6 +16,7 @@
    along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
 
 extern int foo (void);
+extern int foo2 (void);
 
 int
 bar (void)
@@ -27,6 +28,6 @@ bar (void)
 int
 main (void)
 {
-  int res = foo () + bar ();
+  int res = foo () + bar () + foo2 ();
   return res;
 }
index 84c27fc2e1d37539d0eb0de1835f58360710f869..82b5bf8f003b0b47189e76a38915bff1252d25d3 100644 (file)
@@ -34,11 +34,19 @@ lassign $bar_res \
     bar_start bar_len
 set bar_end "$bar_start + $bar_len"
 
+set foo2_res \
+    [function_range foo2 \
+        [list ${srcdir}/${subdir}/$srcfile ${srcdir}/${subdir}/$srcfile2]]
+lassign $foo2_res \
+    foo2_start foo2_len
+set foo2_end "$foo2_start + $foo2_len"
+
 # Create the DWARF.
 set asm_file [standard_output_file $srcfile3]
 Dwarf::assemble $asm_file {
     global foo_start foo_end
     global bar_start bar_end
+    global foo2_start foo2_end
     declare_labels unspecified_type_label
 
     cu {} {
@@ -68,6 +76,19 @@ Dwarf::assemble $asm_file {
            }
        }
     }
+
+    cu { version 2 } {
+       compile_unit {
+           {language @DW_LANG_Mips_Assembler}
+           {producer "GNU AS 2.40.0"}
+       } {
+           DW_TAG_subprogram {
+               {name foo2}
+               {low_pc $foo2_start addr}
+               {high_pc $foo2_end addr}
+           }
+       }
+    }
 }
 
 if [prepare_for_testing "failed to prepare" $testfile \
@@ -79,7 +100,7 @@ if ![runto_main] {
     return -1
 }
 
-foreach f {foo bar} {
+foreach f {foo bar foo2} {
     # Print the function type.  Return type should be stub type, which is printed
     # as void.
     gdb_test "ptype $f" "type = void \\(void\\)"