[llvm] ad68e5d - [LiveDebugVariables] Use bundle-aware iterators consistently (#159471)

via llvm-commits llvm-commits at lists.llvm.org
Thu Sep 18 07:47:11 PDT 2025


Author: Scott Linder
Date: 2025-09-18T10:47:07-04:00
New Revision: ad68e5d56c0258cf6c20657bebc9ef0ad5b20551

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

LOG: [LiveDebugVariables] Use bundle-aware iterators consistently (#159471)

Most of the pass works in terms of MachineBasicBlock::iterator
(MachineInstrBundleIterator), but here one is constructed from an
arbitrary instruction which may be within a bundle, causing an
assertion.

Added: 
    llvm/test/DebugInfo/X86/live-debug-vars-bundle.mir

Modified: 
    llvm/lib/CodeGen/LiveDebugVariables.cpp

Removed: 
    


################################################################################
diff  --git a/llvm/lib/CodeGen/LiveDebugVariables.cpp b/llvm/lib/CodeGen/LiveDebugVariables.cpp
index b049491b531fe..001ba5250f77e 100644
--- a/llvm/lib/CodeGen/LiveDebugVariables.cpp
+++ b/llvm/lib/CodeGen/LiveDebugVariables.cpp
@@ -1973,8 +1973,8 @@ void LiveDebugVariables::LDVImpl::emitDebugValues(VirtRegMap *VRM) {
 
     if (MachineInstr *Pos = Slots->getInstructionFromIndex(Idx)) {
       // Insert at the end of any debug instructions.
-      auto PostDebug = std::next(Pos->getIterator());
-      PostDebug = skipDebugInstructionsForward(PostDebug, MBB->instr_end());
+      auto PostDebug = std::next(MachineBasicBlock::iterator(Pos));
+      PostDebug = skipDebugInstructionsForward(PostDebug, MBB->end());
       EmitInstsHere(PostDebug);
     } else {
       // Insert position disappeared; walk forwards through slots until we

diff  --git a/llvm/test/DebugInfo/X86/live-debug-vars-bundle.mir b/llvm/test/DebugInfo/X86/live-debug-vars-bundle.mir
new file mode 100644
index 0000000000000..8a7eff5519869
--- /dev/null
+++ b/llvm/test/DebugInfo/X86/live-debug-vars-bundle.mir
@@ -0,0 +1,48 @@
+# RUN: llc -run-pass=livedebugvars -run-pass=virtregrewriter -o - %s | FileCheck %s
+
+# Regression test for a bug where LiveDebugVariables used the wrong instruction
+# iterator type when debugInstrRef=true, and triggered an assertion.
+
+--- |
+  target triple = "x86_64-unknown-linux-gnu"
+
+  define i32 @foo(i32 %a, i32 %b) !dbg !4 {
+  entry:
+    ret i32 0, !dbg !10
+  }
+
+  !llvm.dbg.cu = !{!0}
+  !llvm.module.flags = !{!3}
+
+  !0 = distinct !DICompileUnit(language: DW_LANG_C99, file: !1, isOptimized: true, runtimeVersion: 0, emissionKind: FullDebug, enums: !2)
+  !1 = !DIFile(filename: "-", directory: "./")
+  !2 = !{}
+  !3 = !{i32 2, !"Debug Info Version", i32 3}
+  !4 = distinct !DISubprogram(name: "foo", scope: !1, file: !1, line: 1, type: !5, isLocal: false, isDefinition: true, scopeLine: 2, isOptimized: true, unit: !0, retainedNodes: !2)
+  !5 = !DISubroutineType(types: !6)
+  !6 = !{!7, !7, !7}
+  !7 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
+  !8 = !DILocalVariable(name: "local_var", scope: !4, file: !1, line: 7, type: !7)
+  !9 = !DILocation(line: 7, column: 1, scope: !4)
+  !10 = !DILocation(line: 8, column: 3, scope: !4)
+
+...
+---
+name:            foo
+tracksRegLiveness: true
+debugInstrRef: true
+body:             |
+  bb.0:
+    $esi = MOV32ri 2, debug-instr-number 1
+    BUNDLE {
+      NOOP
+    }
+    DBG_INSTR_REF !8, !DIExpression(), dbg-instr-ref(1, 0), debug-location !9
+    RET 0, undef $eax, debug-location !10
+...
+
+# CHECK-LABEL: name:            foo
+# CHECK: bb.0:
+# CHECK: BUNDLE {
+# CHECK: }
+# CHECK: DBG_INSTR_REF


        


More information about the llvm-commits mailing list