[llvm] r264345 - LiveInterval: Fix Distribute() failing on liveranges with unused VNInfos
Matthias Braun via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 24 14:41:39 PDT 2016
Author: matze
Date: Thu Mar 24 16:41:38 2016
New Revision: 264345
URL: http://llvm.org/viewvc/llvm-project?rev=264345&view=rev
Log:
LiveInterval: Fix Distribute() failing on liveranges with unused VNInfos
This fixes http://llvm.org/PR26991
Added:
llvm/trunk/test/CodeGen/AMDGPU/coalescer_distribute.ll
Modified:
llvm/trunk/lib/CodeGen/LiveInterval.cpp
Modified: llvm/trunk/lib/CodeGen/LiveInterval.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/LiveInterval.cpp?rev=264345&r1=264344&r2=264345&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/LiveInterval.cpp (original)
+++ llvm/trunk/lib/CodeGen/LiveInterval.cpp Thu Mar 24 16:41:38 2016
@@ -1483,15 +1483,20 @@ void ConnectedVNInfoEqClasses::Distribut
SubRanges.resize(NumComponents-1, nullptr);
for (unsigned I = 0; I < NumValNos; ++I) {
const VNInfo &VNI = *SR.valnos[I];
- const VNInfo *MainRangeVNI = LI.getVNInfoAt(VNI.def);
- assert(MainRangeVNI != nullptr
- && "SubRange def must have corresponding main range def");
- unsigned ComponentNum = getEqClass(MainRangeVNI);
- VNIMapping.push_back(ComponentNum);
- if (ComponentNum > 0 && SubRanges[ComponentNum-1] == nullptr) {
- SubRanges[ComponentNum-1]
- = LIV[ComponentNum-1]->createSubRange(Allocator, SR.LaneMask);
+ unsigned ComponentNum;
+ if (VNI.isUnused()) {
+ ComponentNum = 0;
+ } else {
+ const VNInfo *MainRangeVNI = LI.getVNInfoAt(VNI.def);
+ assert(MainRangeVNI != nullptr
+ && "SubRange def must have corresponding main range def");
+ ComponentNum = getEqClass(MainRangeVNI);
+ if (ComponentNum > 0 && SubRanges[ComponentNum-1] == nullptr) {
+ SubRanges[ComponentNum-1]
+ = LIV[ComponentNum-1]->createSubRange(Allocator, SR.LaneMask);
+ }
}
+ VNIMapping.push_back(ComponentNum);
}
DistributeRange(SR, SubRanges.data(), VNIMapping);
}
Added: llvm/trunk/test/CodeGen/AMDGPU/coalescer_distribute.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/AMDGPU/coalescer_distribute.ll?rev=264345&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/AMDGPU/coalescer_distribute.ll (added)
+++ llvm/trunk/test/CodeGen/AMDGPU/coalescer_distribute.ll Thu Mar 24 16:41:38 2016
@@ -0,0 +1,53 @@
+; RUN: llc -o /dev/null %s
+; This testcase produces a situation with unused value numbers in subregister
+; liveranges that get distributed by ConnectedVNInfoEqClasses.
+target triple = "amdgcn--"
+
+define spir_kernel void @hoge() {
+bb:
+ %tmp = tail call i32 @llvm.r600.read.tidig.x()
+ br i1 undef, label %bb2, label %bb23
+
+bb2:
+ br i1 undef, label %bb6, label %bb8
+
+bb6:
+ %tmp7 = or i64 undef, undef
+ br label %bb8
+
+bb8:
+ %tmp9 = phi i64 [ %tmp7, %bb6 ], [ undef, %bb2 ]
+ %tmp10 = icmp eq i32 %tmp, 0
+ br i1 %tmp10, label %bb11, label %bb23
+
+bb11:
+ br i1 undef, label %bb20, label %bb17
+
+bb17:
+ br label %bb20
+
+bb20:
+ %tmp21 = phi i64 [ undef, %bb17 ], [ %tmp9, %bb11 ]
+ %tmp22 = trunc i64 %tmp21 to i32
+ br label %bb23
+
+bb23:
+ %tmp24 = phi i32 [ %tmp22, %bb20 ], [ undef, %bb8 ], [ undef, %bb ]
+ br label %bb25
+
+bb25:
+ %tmp26 = phi i32 [ %tmp24, %bb23 ], [ undef, %bb25 ]
+ br i1 undef, label %bb25, label %bb30
+
+bb30:
+ br i1 undef, label %bb32, label %bb34
+
+bb32:
+ %tmp33 = zext i32 %tmp26 to i64
+ br label %bb34
+
+bb34:
+ ret void
+}
+
+declare i32 @llvm.r600.read.tidig.x()
More information about the llvm-commits
mailing list