]> granicus.if.org Git - llvm/commitdiff
DWARF v5: emit DW_AT_addr_base if DW_AT_low_pc references .debug_addr
authorFangrui Song <maskray@google.com>
Tue, 14 May 2019 14:37:26 +0000 (14:37 +0000)
committerFangrui Song <maskray@google.com>
Tue, 14 May 2019 14:37:26 +0000 (14:37 +0000)
The condition !AddrPool.empty() is tested before attachRangesOrLowHighPC(), which may add an entry to AddrPool. We emit DW_AT_low_pc (DW_FORM_addrx) but may incorrectly omit DW_AT_addr_base for LineTablesOnly. This can be easily reproduced:

clang -gdwarf-5 -gmlt -c a.cc

Fix this by moving !AddrPool.empty() below.

This was discovered while investigating an lld crash (fixed by D61889) on such object files: ld.lld --gdb-index a.o

Reviewed By: probinson

Differential Revision: https://reviews.llvm.org/D61891

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@360678 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/AsmPrinter/DwarfDebug.cpp
test/DebugInfo/Generic/line-table-addrx.ll [new file with mode: 0644]
test/DebugInfo/X86/convert-debugloc.ll
test/DebugInfo/X86/fission-ranges.ll

index a6b6fbf3f0cf6c4228028b36738d0e71d1a9055d..070b1b64a36bb6805e5005f068543fff50314f7c 100644 (file)
@@ -901,13 +901,6 @@ void DwarfDebug::finalizeModuleInfo() {
     // ranges for all subprogram DIEs for mach-o.
     DwarfCompileUnit &U = SkCU ? *SkCU : TheCU;
 
-    // We don't keep track of which addresses are used in which CU so this
-    // is a bit pessimistic under LTO.
-    if (!AddrPool.isEmpty() &&
-        (getDwarfVersion() >= 5 ||
-         (SkCU && !empty(TheCU.getUnitDie().children()))))
-      U.addAddrTableBase();
-
     if (unsigned NumRanges = TheCU.getRanges().size()) {
       if (NumRanges > 1 && useRangesSection())
         // A DW_AT_low_pc attribute may also be specified in combination with
@@ -920,6 +913,13 @@ void DwarfDebug::finalizeModuleInfo() {
       U.attachRangesOrLowHighPC(U.getUnitDie(), TheCU.takeRanges());
     }
 
+    // We don't keep track of which addresses are used in which CU so this
+    // is a bit pessimistic under LTO.
+    if (!AddrPool.isEmpty() &&
+        (getDwarfVersion() >= 5 ||
+         (SkCU && !empty(TheCU.getUnitDie().children()))))
+      U.addAddrTableBase();
+
     if (getDwarfVersion() >= 5) {
       if (U.hasRangeLists())
         U.addRnglistsBase();
diff --git a/test/DebugInfo/Generic/line-table-addrx.ll b/test/DebugInfo/Generic/line-table-addrx.ll
new file mode 100644 (file)
index 0000000..14dd721
--- /dev/null
@@ -0,0 +1,21 @@
+; RUN: %llc_dwarf -filetype=obj %s -o - | llvm-dwarfdump -v -debug-info - | FileCheck %s
+
+;; In DWARF v5, emit DW_AT_addr_base as DW_AT_addr_base is used for DW_AT_low_pc.
+; CHECK: DW_AT_low_pc [DW_FORM_addrx]
+; CHECK: DW_AT_addr_base
+
+define i64 @foo() !dbg !7 {
+entry:
+  ret i64 0
+}
+
+!llvm.dbg.cu = !{!0}
+!llvm.module.flags = !{!3, !4}
+
+!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus, file: !1, emissionKind: LineTablesOnly, enums: !2, nameTableKind: None)
+!1 = !DIFile(filename: "a.cc", directory: "/tmp")
+!2 = !{}
+!3 = !{i32 2, !"Dwarf Version", i32 5}
+!4 = !{i32 2, !"Debug Info Version", i32 3}
+!7 = distinct !DISubprogram(name: "a", scope: !1, file: !1, line: 22, type: !8, scopeLine: 22, unit: !0, retainedNodes: !2)
+!8 = !DISubroutineType(types: !2)
index 26a19787fce4a9e355799a207ff1455c64209c16..9e770ee3bf89b94b205610fe55f137e4ba3463a4 100644 (file)
@@ -11,9 +11,9 @@
 ; DW5-CHECK-NEXT:               DW_AT_str_offsets_base (0x00000008)
 ; DW5-CHECK-NEXT:               DW_AT_stmt_list        (0x00000000)
 ; DW5-CHECK-NEXT:               DW_AT_comp_dir {{.*}}
-; DW5-CHECK-NEXT:               DW_AT_addr_base        (0x00000008)
 ; DW5-CHECK-NEXT:               DW_AT_low_pc   (0x0000000000000000)
 ; DW5-CHECK-NEXT:               DW_AT_high_pc  (0x0000000000000007)
+; DW5-CHECK-NEXT:               DW_AT_addr_base        (0x00000008)
 ; DW5-CHECK-NEXT:               DW_AT_loclists_base    (0x0000000c)
 ; DW5-CHECK-EMPTY:
 ; DW5-CHECK-NEXT: 0x00000027:   DW_TAG_base_type
index 1a1dc22870adfc3fe6639dd18183e45497da8222..e120fed23ce998bc4c0aa22a6af4f1acfcffecab 100644 (file)
@@ -12,6 +12,8 @@
 ; CHECK-NEXT: DW_AT_GNU_dwo_name
 ; CHECK-NEXT: DW_AT_GNU_dwo_id
 ; CHECK-NEXT: DW_AT_GNU_ranges_base
+; CHECK-NEXT: DW_AT_low_pc
+; CHECK-NEXT: DW_AT_high_pc
 ; CHECK-NEXT: DW_AT_GNU_addr_base [DW_FORM_sec_offset]                   (0x00000000)
 
 ; CHECK: .debug_info.dwo contents: