[PATCH] D149106: Factor out split-dwarf test in Generic/empty.ll to it's own test file

Shubham Sandeep Rastogi via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Apr 24 16:08:51 PDT 2023


rastogishubham created this revision.
rastogishubham added reviewers: aprantl, dblaikie, probinson, mehdi_amini.
Herald added a project: All.
rastogishubham requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.

In llvm/test/DebugInfo/Generic/empty.ll, there are two RUN lines. The second one use the option

  -split-dwarf-file=foo.dwo

Since darwin doesn't support split dwarf, we see an assertion when running the test:

  Assertion failed: (Section && "Cannot switch to a null section!"), function switchSection, file /Users/buildslave/jenkins/workspace/clang-stage1-RA/llvm-project/llvm/lib/MC/MCStreamer.cpp, line 1238

While there is an XFAIL for darwin in the test, I don't think it is a good practice to run a test on darwin which causes an assertion. This patch is a small refactoring of the test so that the split-dwarf test can be it's own file with an explicit elf triple.


https://reviews.llvm.org/D149106

Files:
  llvm/test/DebugInfo/Generic/empty.ll
  llvm/test/DebugInfo/X86/empty-split-dwarf.ll


Index: llvm/test/DebugInfo/X86/empty-split-dwarf.ll
===================================================================
--- /dev/null
+++ llvm/test/DebugInfo/X86/empty-split-dwarf.ll
@@ -0,0 +1,18 @@
+; UNSUPPORTED: target={{.*}}-aix{{.*}}
+; RUN: %llc_dwarf -split-dwarf-file=foo.dwo < %s -filetype=obj --mtriple=x86_64-unknown-linux-elf | llvm-dwarfdump -v - | FileCheck --check-prefix=FISSION %s
+
+; Don't emit DW_AT_addr_base when there are no addresses.
+; Also don't emit a split line table when there are no type units.
+; FISSION-NOT: DW_AT_GNU_addr_base [DW_FORM_sec_offset]
+; FISSION-NOT: .debug_line.dwo contents:
+
+!llvm.dbg.cu = !{!0}
+!llvm.module.flags = !{!5}
+
+!0 = distinct !DICompileUnit(language: DW_LANG_C99, producer: "clang version 3.1 (trunk 143523)", isOptimized: true, emissionKind: FullDebug, file: !4, enums: !2, retainedTypes: !6, globals: !2)
+!2 = !{}
+!3 = !DIFile(filename: "empty.c", directory: "/home/nlewycky")
+!4 = !DIFile(filename: "empty.c", directory: "/home/nlewycky")
+!5 = !{i32 1, !"Debug Info Version", i32 3}
+!6 = !{!7}
+!7 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
Index: llvm/test/DebugInfo/Generic/empty.ll
===================================================================
--- llvm/test/DebugInfo/Generic/empty.ll
+++ llvm/test/DebugInfo/Generic/empty.ll
@@ -1,9 +1,5 @@
 ; UNSUPPORTED: target={{.*}}-aix{{.*}}
 ; RUN: %llc_dwarf < %s -filetype=obj | llvm-dwarfdump -v - | FileCheck %s
-; RUN: %llc_dwarf -split-dwarf-file=foo.dwo < %s -filetype=obj | llvm-dwarfdump -v - | FileCheck --check-prefix=FISSION %s
-
-; darwin has a workaround for a linker bug so it always emits one line table entry
-; XFAIL: target={{.*}}-darwin{{.*}}
 
 ; Expect no line table entry since there are no functions and file references in this compile unit
 ; CHECK: .debug_line contents:
@@ -14,11 +10,6 @@
 ; CHECK-NOT: .debug_pubnames contents:
 ; CHECK: contents:
 
-; Don't emit DW_AT_addr_base when there are no addresses.
-; Also don't emit a split line table when there are no type units.
-; FISSION-NOT: DW_AT_GNU_addr_base [DW_FORM_sec_offset]
-; FISSION-NOT: .debug_line.dwo contents:
-
 !llvm.dbg.cu = !{!0}
 !llvm.module.flags = !{!5}
 


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D149106.516564.patch
Type: text/x-patch
Size: 2206 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20230424/6ddb5a63/attachment.bin>


More information about the llvm-commits mailing list