[PATCH] D40184: [LICM] Fix PR35342

Jun Bum Lim via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Nov 17 10:05:44 PST 2017


junbuml created this revision.

This change fix PR35342 by rebuilding user_iterator which is invalidated after replacing users with undef in unreachable blocks.


https://reviews.llvm.org/D40184

Files:
  lib/Transforms/Scalar/LICM.cpp
  test/Transforms/LICM/pr35342.ll


Index: test/Transforms/LICM/pr35342.ll
===================================================================
--- /dev/null
+++ test/Transforms/LICM/pr35342.ll
@@ -0,0 +1,27 @@
+; RUN: opt -licm -S < %s | FileCheck %s
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128-ni:1"
+target triple = "x86_64-unknown-linux-gnu"
+
+; CHECK-LABEL: @f1
+; CHECK-LABEL: bci_524:
+; CHECK: add i32 undef, undef
+define void @f1(i32 %v) {
+not_zero.lr.ph:
+  br label %not_zero
+
+not_zero:
+  br i1 undef, label %bci_748 ,  label %bci_314
+
+bci_314:
+  %0 = select i1 undef, i32 undef, i32 undef
+  br label %not_zero
+
+bci_524:                   ; No predecessors!
+  %add = add i32 %0, %0
+  br label %bci_748
+
+bci_748:
+  ret void
+}
+
Index: lib/Transforms/Scalar/LICM.cpp
===================================================================
--- lib/Transforms/Scalar/LICM.cpp
+++ lib/Transforms/Scalar/LICM.cpp
@@ -907,6 +907,8 @@
 
     if (!DT->isReachableFromEntry(User->getParent())) {
       User->replaceUsesOfWith(&I, UndefValue::get(I.getType()));
+      UI = I.user_begin();
+      UE = I.user_end();
       continue;
     }
 
@@ -919,6 +921,8 @@
     BasicBlock *BB = PN->getIncomingBlock(U);
     if (!DT->isReachableFromEntry(BB)) {
       U = UndefValue::get(I.getType());
+      UI = I.user_begin();
+      UE = I.user_end();
       continue;
     }
 


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D40184.123372.patch
Type: text/x-patch
Size: 1368 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20171117/4496ecb0/attachment.bin>


More information about the llvm-commits mailing list