[PATCH] D27469: [LoopVersioning] Check if exit block dominates runtime check block.
Florian Hahn via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Dec 6 10:13:51 PST 2016
fhahn created this revision.
fhahn added reviewers: anemet, silviu.baranga.
fhahn added a subscriber: llvm-commits.
Without this check, loop versioning will create an invalid dominator
tree in case the exit block dominates the runtime check block.
This patch closes #30958 (https://llvm.org/bugs/show_bug.cgi?id=30958).
https://reviews.llvm.org/D27469
Files:
lib/Transforms/Utils/LoopVersioning.cpp
test/Transforms/LoopVersioning/exit-block-dominates-rt-check-block.ll
Index: test/Transforms/LoopVersioning/exit-block-dominates-rt-check-block.ll
===================================================================
--- /dev/null
+++ test/Transforms/LoopVersioning/exit-block-dominates-rt-check-block.ll
@@ -0,0 +1,33 @@
+; This test ensures loop versioning does not produce an invalid dominator tree
+; if the exit block of the loop (bb0) dominates the runtime check block
+; (bb1 will become the runtime check block).
+
+; RUN: opt -loop-versioning -verify-dom-info -S -o - %s > %t
+; RUN: FileCheck -input-file %t %s
+
+ at c1 = external global i16
+
+define void @f(i16 %a) {
+ br label %bb0
+
+bb0:
+ br label %bb1
+
+bb1:
+ %tmp1 = load i16, i16* @c1
+ br label %bb2
+
+bb2:
+ %tmp2 = phi i16 [ %tmp1, %bb1 ], [ %tmp3, %bb2 ]
+ %tmp4 = getelementptr inbounds [1 x i32], [1 x i32]* undef, i32 0, i32 4
+ store i32 1, i32* %tmp4
+ %tmp5 = getelementptr inbounds [1 x i32], [1 x i32]* undef, i32 0, i32 9
+ store i32 0, i32* %tmp5
+ %tmp3 = add i16 %tmp2, 1
+ store i16 %tmp2, i16* @c1
+ %tmp6 = icmp sle i16 %tmp3, 0
+ br i1 %tmp6, label %bb2, label %bb0
+}
+
+; Simple check to make sure loop versioning happened.
+; CHECK-LABEL: bb2.lver.check
Index: lib/Transforms/Utils/LoopVersioning.cpp
===================================================================
--- lib/Transforms/Utils/LoopVersioning.cpp
+++ lib/Transforms/Utils/LoopVersioning.cpp
@@ -112,9 +112,11 @@
VersionedLoop->getLoopPreheader(), RuntimeCheck, OrigTerm);
OrigTerm->eraseFromParent();
- // The loops merge in the original exit block. This is now dominated by the
- // memchecking block.
- DT->changeImmediateDominator(VersionedLoop->getExitBlock(), RuntimeCheckBB);
+ // The loops merge in the original exit block. The exit block is now
+ // dominated by the memchecking block, if the exit block did not dominate
+ // the memchecking block initially.
+ if (!DT->dominates(VersionedLoop->getExitBlock(), RuntimeCheckBB))
+ DT->changeImmediateDominator(VersionedLoop->getExitBlock(), RuntimeCheckBB);
// Adds the necessary PHI nodes for the versioned loops based on the
// loop-defined values used outside of the loop.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D27469.80442.patch
Type: text/x-patch
Size: 2180 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20161206/7b2ee2e4/attachment.bin>
More information about the llvm-commits
mailing list