[llvm] 1be6ccf - [DWARF][codegen] Fix for Aranges when split inlining is present

Alexander Yermolovich via llvm-commits llvm-commits at lists.llvm.org
Wed Feb 9 11:52:35 PST 2022


Author: Alexander Yermolovich
Date: 2022-02-09T11:51:43-08:00
New Revision: 1be6ccfc0252f10ff7825ec59377a76c68f0a630

URL: https://github.com/llvm/llvm-project/commit/1be6ccfc0252f10ff7825ec59377a76c68f0a630
DIFF: https://github.com/llvm/llvm-project/commit/1be6ccfc0252f10ff7825ec59377a76c68f0a630.diff

LOG: [DWARF][codegen] Fix for Aranges when split inlining is present

When we enable -fsplit-dwarf-inlining we end up with two entries
in .debug_aranges for each CU. Because it processes Skeleton CU
inline information and DWO CU.

Furthermore address calculations were incorrect because we were processing sections in Skeleton CU.

Reviewed By: dblaikie

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

Added: 
    llvm/test/DebugInfo/X86/fission-inline-aranges.ll
    llvm/test/DebugInfo/X86/fission-no-inline-aranges.ll

Modified: 
    llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp

Removed: 
    


################################################################################
diff  --git a/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
index 5913c687db48f..245b178210443 100644
--- a/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
+++ b/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp
@@ -67,13 +67,13 @@ DwarfCompileUnit::DwarfCompileUnit(unsigned UID, const DICompileUnit *Node,
 /// DW_FORM_addr or DW_FORM_GNU_addr_index.
 void DwarfCompileUnit::addLabelAddress(DIE &Die, dwarf::Attribute Attribute,
                                        const MCSymbol *Label) {
+  if ((Skeleton || !DD->useSplitDwarf()) && Label)
+    DD->addArangeLabel(SymbolCU(this, Label));
+
   // Don't use the address pool in non-fission or in the skeleton unit itself.
   if ((!DD->useSplitDwarf() || !Skeleton) && DD->getDwarfVersion() < 5)
     return addLocalLabelAddress(Die, Attribute, Label);
 
-  if (Label)
-    DD->addArangeLabel(SymbolCU(this, Label));
-
   bool UseAddrOffsetFormOrExpressions =
       DD->useAddrOffsetForm() || DD->useAddrOffsetExpressions();
 
@@ -108,9 +108,6 @@ void DwarfCompileUnit::addLabelAddress(DIE &Die, dwarf::Attribute Attribute,
 void DwarfCompileUnit::addLocalLabelAddress(DIE &Die,
                                             dwarf::Attribute Attribute,
                                             const MCSymbol *Label) {
-  if (Label)
-    DD->addArangeLabel(SymbolCU(this, Label));
-
   if (Label)
     addAttribute(Die, Attribute, dwarf::DW_FORM_addr, DIELabel(Label));
   else
@@ -505,7 +502,7 @@ DIE &DwarfCompileUnit::updateSubprogramScopeDIE(const DISubprogram *SP) {
           // FIXME: when writing dwo, we need to avoid relocations. Probably
           // the "right" solution is to treat globals the way func and data
           // symbols are (with entries in .debug_addr).
-          // For now, since we only ever use index 0, this should work as-is.       
+          // For now, since we only ever use index 0, this should work as-is.
           addUInt(*Loc, dwarf::DW_FORM_data4, FrameBase.Location.WasmLoc.Index);
         }
         addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_stack_value);

diff  --git a/llvm/test/DebugInfo/X86/fission-inline-aranges.ll b/llvm/test/DebugInfo/X86/fission-inline-aranges.ll
new file mode 100644
index 0000000000000..f9190d5978399
--- /dev/null
+++ b/llvm/test/DebugInfo/X86/fission-inline-aranges.ll
@@ -0,0 +1,55 @@
+; RUN: llc -generate-arange-section -split-dwarf-file=foo.dwo -O0 < %s -mtriple=x86_64-unknown-linux-gnu -filetype=obj > %t
+; RUN: llvm-dwarfdump -v -debug-aranges %t | FileCheck %s
+
+; Test that only one entry is emmitted in .debug_aranges per CU.
+
+; struct foo {
+;    static void f2();
+;    static void f3(...);
+;  };
+;
+;  void foo::f3(...) {
+;      f2();
+; }
+
+; Check that we emit only one entry in .debug_aranges
+
+; CHECK:    cu_offset
+; CHECK-NOT: cu_offset
+
+; Function Attrs: mustprogress noinline optnone uwtable
+define dso_local void @_ZN3foo2f3Ez(...) #0 align 2 !dbg !8 {
+entry:
+  call void @_ZN3foo2f2Ev(), !dbg !18
+  ret void, !dbg !19
+}
+
+declare dso_local void @_ZN3foo2f2Ev() #1
+
+attributes #0 = { mustprogress noinline optnone uwtable "frame-pointer"="all" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
+attributes #1 = { "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
+
+!llvm.dbg.cu = !{!0}
+!llvm.module.flags = !{!2, !3, !4, !5, !6}
+!llvm.ident = !{!7}
+
+!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 14.0.0", isOptimized: false, runtimeVersion: 0, splitDebugFilename: "main.dwo", emissionKind: FullDebug, nameTableKind: GNU)
+!1 = !DIFile(filename: "main.cpp", directory: "/tmp/dbginfo")
+!2 = !{i32 7, !"Dwarf Version", i32 5}
+!3 = !{i32 2, !"Debug Info Version", i32 3}
+!4 = !{i32 1, !"wchar_size", i32 4}
+!5 = !{i32 7, !"uwtable", i32 1}
+!6 = !{i32 7, !"frame-pointer", i32 2}
+!7 = !{!"clang version 14.0.0"}
+!8 = distinct !DISubprogram(name: "f3", linkageName: "_ZN3foo2f3Ez", scope: !9, file: !1, line: 6, type: !15, scopeLine: 6, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, declaration: !14, retainedNodes: !17)
+!9 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "foo", file: !1, line: 1, size: 8, flags: DIFlagTypePassByValue, elements: !10, identifier: "_ZTS3foo")
+!10 = !{!11, !14}
+!11 = !DISubprogram(name: "f2", linkageName: "_ZN3foo2f2Ev", scope: !9, file: !1, line: 2, type: !12, scopeLine: 2, flags: DIFlagPrototyped | DIFlagStaticMember, spFlags: 0)
+!12 = !DISubroutineType(types: !13)
+!13 = !{null}
+!14 = !DISubprogram(name: "f3", linkageName: "_ZN3foo2f3Ez", scope: !9, file: !1, line: 3, type: !15, scopeLine: 3, flags: DIFlagPrototyped | DIFlagStaticMember, spFlags: 0)
+!15 = !DISubroutineType(types: !16)
+!16 = !{null, null}
+!17 = !{}
+!18 = !DILocation(line: 7, column: 6, scope: !8)
+!19 = !DILocation(line: 8, column: 2, scope: !8)

diff  --git a/llvm/test/DebugInfo/X86/fission-no-inline-aranges.ll b/llvm/test/DebugInfo/X86/fission-no-inline-aranges.ll
new file mode 100644
index 0000000000000..5c078860c32b4
--- /dev/null
+++ b/llvm/test/DebugInfo/X86/fission-no-inline-aranges.ll
@@ -0,0 +1,55 @@
+; RUN: llc -generate-arange-section -split-dwarf-file=foo.dwo -O0 < %s -mtriple=x86_64-unknown-linux-gnu -filetype=obj > %t
+; RUN: llvm-dwarfdump -v -debug-aranges %t | FileCheck %s
+
+; Test that only one entry is emmitted in .debug_aranges per CU.
+
+; struct foo {
+;    static void f2();
+;    static void f3(...);
+;  };
+;
+;  void foo::f3(...) {
+;      f2();
+; }
+
+; Check that we emit only one entry in .debug_aranges
+
+; CHECK:    cu_offset
+; CHECK-NOT: cu_offset
+
+; Function Attrs: mustprogress noinline optnone uwtable
+define dso_local void @_ZN3foo2f3Ez(...) #0 align 2 !dbg !8 {
+entry:
+  call void @_ZN3foo2f2Ev(), !dbg !18
+  ret void, !dbg !19
+}
+
+declare dso_local void @_ZN3foo2f2Ev() #1
+
+attributes #0 = { mustprogress noinline optnone uwtable "frame-pointer"="all" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
+attributes #1 = { "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" }
+
+!llvm.dbg.cu = !{!0}
+!llvm.module.flags = !{!2, !3, !4, !5, !6}
+!llvm.ident = !{!7}
+
+!0 = distinct !DICompileUnit(language: DW_LANG_C_plus_plus_14, file: !1, producer: "clang version 14.0.0", isOptimized: false, runtimeVersion: 0, splitDebugFilename: "main.dwo", emissionKind: FullDebug, splitDebugInlining: false, nameTableKind: GNU)
+!1 = !DIFile(filename: "main.cpp", directory: "/tmp/dbginfo")
+!2 = !{i32 7, !"Dwarf Version", i32 5}
+!3 = !{i32 2, !"Debug Info Version", i32 3}
+!4 = !{i32 1, !"wchar_size", i32 4}
+!5 = !{i32 7, !"uwtable", i32 1}
+!6 = !{i32 7, !"frame-pointer", i32 2}
+!7 = !{!"clang version 14.0.0"}
+!8 = distinct !DISubprogram(name: "f3", linkageName: "_ZN3foo2f3Ez", scope: !9, file: !1, line: 6, type: !15, scopeLine: 6, flags: DIFlagPrototyped, spFlags: DISPFlagDefinition, unit: !0, declaration: !14, retainedNodes: !17)
+!9 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "foo", file: !1, line: 1, size: 8, flags: DIFlagTypePassByValue, elements: !10, identifier: "_ZTS3foo")
+!10 = !{!11, !14}
+!11 = !DISubprogram(name: "f2", linkageName: "_ZN3foo2f2Ev", scope: !9, file: !1, line: 2, type: !12, scopeLine: 2, flags: DIFlagPrototyped | DIFlagStaticMember, spFlags: 0)
+!12 = !DISubroutineType(types: !13)
+!13 = !{null}
+!14 = !DISubprogram(name: "f3", linkageName: "_ZN3foo2f3Ez", scope: !9, file: !1, line: 3, type: !15, scopeLine: 3, flags: DIFlagPrototyped | DIFlagStaticMember, spFlags: 0)
+!15 = !DISubroutineType(types: !16)
+!16 = !{null, null}
+!17 = !{}
+!18 = !DILocation(line: 7, column: 6, scope: !8)
+!19 = !DILocation(line: 8, column: 2, scope: !8)


        


More information about the llvm-commits mailing list