[llvm] r360780 - [JumpThreading] A bug fix for stale loop info after unfold select
Hiroshi Yamauchi via llvm-commits
llvm-commits at lists.llvm.org
Wed May 15 08:15:16 PDT 2019
Author: yamauchi
Date: Wed May 15 08:15:16 2019
New Revision: 360780
URL: http://llvm.org/viewvc/llvm-project?rev=360780&view=rev
Log:
[JumpThreading] A bug fix for stale loop info after unfold select
Summary:
The return value of a TryToUnfoldSelect call was not checked, which led to an
incorrectly preserved loop info and some crash.
The original crash was reported on https://reviews.llvm.org/D59514.
Reviewers: davidxl, amehsan
Reviewed By: davidxl
Subscribers: fhahn, brzycki, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D61920
Added:
llvm/trunk/test/Transforms/JumpThreading/stale-loop-info-after-unfold-select.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/JumpThreading.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/JumpThreading.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/JumpThreading.cpp?rev=360780&r1=360779&r2=360780&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/JumpThreading.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/JumpThreading.cpp Wed May 15 08:15:16 2019
@@ -1174,7 +1174,8 @@ bool JumpThreadingPass::ProcessBlock(Bas
}
if (SwitchInst *SI = dyn_cast<SwitchInst>(BB->getTerminator()))
- TryToUnfoldSelect(SI, BB);
+ if (TryToUnfoldSelect(SI, BB))
+ return true;
// Check for some cases that are worth simplifying. Right now we want to look
// for loads that are used by a switch or by the condition for the branch. If
Added: llvm/trunk/test/Transforms/JumpThreading/stale-loop-info-after-unfold-select.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/JumpThreading/stale-loop-info-after-unfold-select.ll?rev=360780&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/JumpThreading/stale-loop-info-after-unfold-select.ll (added)
+++ llvm/trunk/test/Transforms/JumpThreading/stale-loop-info-after-unfold-select.ll Wed May 15 08:15:16 2019
@@ -0,0 +1,30 @@
+; RUN: opt -passes='require<loops>,jump-threading,verify<loops>' -S < %s
+
+%"type1" = type { i8 }
+%"type2" = type opaque
+
+define dso_local i16* @func2(%"type1"* %this, %"type2"*) {
+entry:
+ br label %while.cond
+
+while.cond: ; preds = %func1.exit, %entry
+ %month.0 = phi i32 [ undef, %entry ], [ %month.0.be, %func1.exit ]
+ switch i32 %month.0, label %if.end.i [
+ i32 4, label %func1.exit
+ i32 1, label %func1.exit
+ ]
+
+if.end.i: ; preds = %while.cond
+ br label %func1.exit
+
+func1.exit: ; preds = %if.end.i, %while.cond, %while.cond
+ %retval.0.i = phi i32 [ 9, %if.end.i ], [ 0, %while.cond ], [ 0, %while.cond ]
+ %call2 = tail call signext i32 @func3(i32 signext %retval.0.i, i32 signext 1, i32 signext 3)
+ %cmp = icmp slt i32 %call2, 1
+ %add = add nsw i32 %call2, 2
+ %month.0.be = select i1 %cmp, i32 %add, i32 %call2
+ br label %while.cond
+}
+
+declare i32 @func3(i32, i32, i32)
+
More information about the llvm-commits
mailing list