[llvm] [CodeGen][X86] LiveRangeShrink: fix increment after end (PR #115276)
via llvm-commits
llvm-commits at lists.llvm.org
Fri Nov 8 11:25:07 PST 2024
https://github.com/MuellerMP updated https://github.com/llvm/llvm-project/pull/115276
>From 5d4a7f1a67a722cebc8abd753424a1523f7fa83f Mon Sep 17 00:00:00 2001
From: MuellerMP <mirkomueller97 at live.de>
Date: Thu, 7 Nov 2024 08:44:14 +0100
Subject: [PATCH] [CodeGen][X86] LiveRangeShrink: fix increment after end
This fixes the infinite loop discovered in #114195.
Since we skip debug instructions at the start of the loop we do not
need to skip them again at the end of the loop.
---
llvm/lib/CodeGen/LiveRangeShrink.cpp | 2 +-
llvm/test/CodeGen/X86/lrshrink-debug.ll | 82 +++++++++++++++++++++++++
2 files changed, 83 insertions(+), 1 deletion(-)
create mode 100755 llvm/test/CodeGen/X86/lrshrink-debug.ll
diff --git a/llvm/lib/CodeGen/LiveRangeShrink.cpp b/llvm/lib/CodeGen/LiveRangeShrink.cpp
index f4bf47c3ae158f..6a0b918d5e6f67 100644
--- a/llvm/lib/CodeGen/LiveRangeShrink.cpp
+++ b/llvm/lib/CodeGen/LiveRangeShrink.cpp
@@ -246,7 +246,7 @@ bool LiveRangeShrink::runOnMachineFunction(MachineFunction &MF) {
if (MI.getOperand(0).isReg())
for (; EndIter != MBB.end() && EndIter->isDebugValue() &&
EndIter->hasDebugOperandForReg(MI.getOperand(0).getReg());
- ++EndIter, ++Next)
+ ++EndIter)
IOM[&*EndIter] = NewOrder;
MBB.splice(I, &MBB, MI.getIterator(), EndIter);
}
diff --git a/llvm/test/CodeGen/X86/lrshrink-debug.ll b/llvm/test/CodeGen/X86/lrshrink-debug.ll
new file mode 100755
index 00000000000000..dd52968529902c
--- /dev/null
+++ b/llvm/test/CodeGen/X86/lrshrink-debug.ll
@@ -0,0 +1,82 @@
+; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
+; RUN: llc %s -o - | FileCheck %s
+target triple = "i686-unknown-linux-gnu"
+
+define noundef i32 @test(i1 %tobool1.not, i32 %sh.012, i1 %cmp, i64 %sh_prom, i64 %shl) {
+; CHECK-LABEL: test:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: pushl %ebp
+; CHECK-NEXT: .cfi_def_cfa_offset 8
+; CHECK-NEXT: pushl %ebx
+; CHECK-NEXT: .cfi_def_cfa_offset 12
+; CHECK-NEXT: pushl %edi
+; CHECK-NEXT: .cfi_def_cfa_offset 16
+; CHECK-NEXT: pushl %esi
+; CHECK-NEXT: .cfi_def_cfa_offset 20
+; CHECK-NEXT: .cfi_offset %esi, -20
+; CHECK-NEXT: .cfi_offset %edi, -16
+; CHECK-NEXT: .cfi_offset %ebx, -12
+; CHECK-NEXT: .cfi_offset %ebp, -8
+; CHECK-NEXT: xorl %esi, %esi
+; CHECK-NEXT: movl {{[0-9]+}}(%esp), %eax
+; CHECK-NEXT: movl {{[0-9]+}}(%esp), %ecx
+; CHECK-NEXT: movzbl {{[0-9]+}}(%esp), %edx
+; CHECK-NEXT: movb {{[0-9]+}}(%esp), %dh
+; CHECK-NEXT: xorl %edi, %edi
+; CHECK-NEXT: jmp .LBB0_1
+; CHECK-NEXT: .p2align 4
+; CHECK-NEXT: .LBB0_4: # %if.end
+; CHECK-NEXT: # in Loop: Header=BB0_1 Depth=1
+; CHECK-NEXT: orl %ecx, %ebx
+; CHECK-NEXT: orl %eax, %ebp
+; CHECK-NEXT: movl %ebx, %esi
+; CHECK-NEXT: movl %ebp, %edi
+; CHECK-NEXT: .LBB0_1: # %for.body
+; CHECK-NEXT: # =>This Inner Loop Header: Depth=1
+; CHECK-NEXT: testb $1, %dh
+; CHECK-NEXT: je .LBB0_1
+; CHECK-NEXT: # %bb.2: # %if.end
+; CHECK-NEXT: # in Loop: Header=BB0_1 Depth=1
+; CHECK-NEXT: xorl %ebx, %ebx
+; CHECK-NEXT: testb $1, %dl
+; CHECK-NEXT: movl $0, %ebp
+; CHECK-NEXT: jne .LBB0_4
+; CHECK-NEXT: # %bb.3: # %if.end
+; CHECK-NEXT: # in Loop: Header=BB0_1 Depth=1
+; CHECK-NEXT: movl %esi, %ebx
+; CHECK-NEXT: movl %edi, %ebp
+; CHECK-NEXT: jmp .LBB0_4
+entry:
+ br label %for.body
+
+for.body: ; preds = %for.inc, %entry
+ %bitmap.013 = phi i64 [ 0, %entry ], [ %bitmap.2, %for.inc ]
+ br i1 %tobool1.not, label %if.end, label %for.inc
+
+if.end: ; preds = %for.body
+ %spec.select10 = select i1 %cmp, i64 0, i64 %bitmap.013
+ %shl6 = shl nuw i64 1, %sh_prom
+ %or = or i64 %shl, %spec.select10
+ tail call void @llvm.dbg.value(metadata i64 %or, metadata !17, metadata !DIExpression()), !dbg !21
+ br label %for.inc
+
+for.inc: ; preds = %if.end, %for.body
+ %bitmap.2 = phi i64 [ %bitmap.013, %for.body ], [ %or, %if.end ]
+ %tobool.not = icmp eq i32 0, 0
+ br label %for.body
+}
+
+declare void @llvm.dbg.value(metadata, metadata, metadata)
+
+!llvm.dbg.cu = !{!0}
+!llvm.module.flags = !{!16}
+
+!0 = distinct !DICompileUnit(language: DW_LANG_C11, file: !1, enums: !2)
+!1 = !DIFile(filename: "test.c", directory: "test")
+!2 = !{}
+!16 = !{i32 2, !"Debug Info Version", i32 3}
+!17 = !DILocalVariable(name: "bitmap", scope: !18, file: !1, line: 8, type: !20)
+!18 = distinct !DISubprogram(name: "test", scope: !1, file: !1, line: 6, type: !19, scopeLine: 6, flags: DIFlagAllCallsDescribed, spFlags: DISPFlagDefinition | DISPFlagOptimized, unit: !0, retainedNodes: !2)
+!19 = !DISubroutineType(types: !2)
+!20 = !DIBasicType(name: "long long", size: 64, encoding: DW_ATE_signed)
+!21 = !DILocation(line: 0, scope: !18)
More information about the llvm-commits
mailing list