[llvm] r312045 - [LoopUnswitch] Fix a simple bug which disables loop unswitch for select statement
Wei Mi via llvm-commits
llvm-commits at lists.llvm.org
Tue Aug 29 14:45:11 PDT 2017
Author: wmi
Date: Tue Aug 29 14:45:11 2017
New Revision: 312045
URL: http://llvm.org/viewvc/llvm-project?rev=312045&view=rev
Log:
[LoopUnswitch] Fix a simple bug which disables loop unswitch for select statement
This is to fix PR34257. rL309059 takes an early return when FindLIVLoopCondition
fails to find a loop invariant condition. This is wrong and it will disable loop
unswitch for select. The patch fixes the bug.
Differential Revision: https://reviews.llvm.org/D36985
Added:
llvm/trunk/test/Transforms/LoopUnswitch/unswitch-select.ll
Modified:
llvm/trunk/lib/Transforms/Scalar/LoopUnswitch.cpp
Modified: llvm/trunk/lib/Transforms/Scalar/LoopUnswitch.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/Scalar/LoopUnswitch.cpp?rev=312045&r1=312044&r2=312045&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/Scalar/LoopUnswitch.cpp (original)
+++ llvm/trunk/lib/Transforms/Scalar/LoopUnswitch.cpp Tue Aug 29 14:45:11 2017
@@ -705,10 +705,8 @@ bool LoopUnswitch::processCurrentLoop()
// unswitch on it if we desire.
Value *LoopCond = FindLIVLoopCondition(BI->getCondition(),
currentLoop, Changed).first;
- if (!LoopCond || EqualityPropUnSafe(*LoopCond))
- continue;
-
- if (UnswitchIfProfitable(LoopCond, ConstantInt::getTrue(Context), TI)) {
+ if (LoopCond && !EqualityPropUnSafe(*LoopCond) &&
+ UnswitchIfProfitable(LoopCond, ConstantInt::getTrue(Context), TI)) {
++NumBranches;
return true;
}
Added: llvm/trunk/test/Transforms/LoopUnswitch/unswitch-select.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/LoopUnswitch/unswitch-select.ll?rev=312045&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/LoopUnswitch/unswitch-select.ll (added)
+++ llvm/trunk/test/Transforms/LoopUnswitch/unswitch-select.ll Tue Aug 29 14:45:11 2017
@@ -0,0 +1,26 @@
+; REQUIRES: asserts
+; RUN: opt < %s -loop-unswitch -disable-output -stats 2>&1| FileCheck %s
+
+; Check the select statement in the loop will be unswitched.
+; CHECK: 1 loop-unswitch - Number of selects unswitched
+define i32 @test(i1 zeroext %x, i32 %a) local_unnamed_addr #0 {
+entry:
+ br label %while.cond
+
+while.cond: ; preds = %while.body, %entry
+ %i.0 = phi i32 [ 0, %entry ], [ %inc, %while.body ]
+ %s.0 = phi i32 [ %a, %entry ], [ %add, %while.body ]
+ %cmp = icmp slt i32 %i.0, 10000
+ br i1 %cmp, label %while.body, label %while.end
+
+while.body: ; preds = %while.cond
+ %cond = select i1 %x, i32 %a, i32 %i.0
+ %add = add nsw i32 %s.0, %cond
+ %inc = add nsw i32 %i.0, 1
+ br label %while.cond
+
+while.end: ; preds = %while.cond
+ %s.0.lcssa = phi i32 [ %s.0, %while.cond ]
+ ret i32 %s.0.lcssa
+}
+
More information about the llvm-commits
mailing list