[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