summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/LoopVectorize
diff options
context:
space:
mode:
authorFlorian Hahn <florian_hahn@apple.com>2019-11-28 22:08:05 +0100
committerFlorian Hahn <florian_hahn@apple.com>2019-11-28 22:18:47 +0100
commitec3efcf11ff2fcdb5a754e3bda942dd5bef0928e (patch)
tree62a27be393d3b2fd02ff30ee33f1236f3c540ba8 /llvm/test/Transforms/LoopVectorize
parentc671639af6a96c31d3c0e5487051bef28bad1640 (diff)
downloadbcm5719-llvm-ec3efcf11ff2fcdb5a754e3bda942dd5bef0928e.tar.gz
bcm5719-llvm-ec3efcf11ff2fcdb5a754e3bda942dd5bef0928e.zip
[IVDescriptors] Skip FOR where we have multiple sink points for now.
This fixes a crash with instructions where multiple operands are first-order-recurrences.
Diffstat (limited to 'llvm/test/Transforms/LoopVectorize')
-rw-r--r--llvm/test/Transforms/LoopVectorize/first-order-recurrence-complex.ll30
1 files changed, 30 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopVectorize/first-order-recurrence-complex.ll b/llvm/test/Transforms/LoopVectorize/first-order-recurrence-complex.ll
index e09804276ec..aa913172f7b 100644
--- a/llvm/test/Transforms/LoopVectorize/first-order-recurrence-complex.ll
+++ b/llvm/test/Transforms/LoopVectorize/first-order-recurrence-complex.ll
@@ -243,3 +243,33 @@ for:
exit:
ret void
}
+
+; TODO: We should be able to sink %tmp38 after %tmp60.
+define void @instruction_with_2_FOR_operands() {
+; CHECK-LABEL: define void @instruction_with_2_FOR_operands(
+; CHECK-NEXT: bb:
+; CHECK-NEXT: br label %bb13
+
+; CHECK-LABEL: bb13:
+; CHECK: br i1 %tmp12, label %bb13, label %bb74
+
+; CHECK-LABEL: bb74:
+; CHECK-NEXT: ret void
+;
+bb:
+ br label %bb13
+
+bb13: ; preds = %bb13, %bb
+ %tmp37 = phi float [ %tmp60, %bb13 ], [ undef, %bb ]
+ %tmp27 = phi float [ %tmp49, %bb13 ], [ undef, %bb ]
+ %indvars.iv = phi i64 [ %indvars.iv.next, %bb13 ], [ 0, %bb ]
+ %tmp38 = fmul fast float %tmp37, %tmp27
+ %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
+ %tmp49 = load float, float* undef, align 4
+ %tmp60 = load float, float* undef, align 4
+ %tmp12 = icmp slt i64 %indvars.iv, undef
+ br i1 %tmp12, label %bb13, label %bb74
+
+bb74: ; preds = %bb13
+ ret void
+}
OpenPOWER on IntegriCloud