[PATCH] D84944: [JumpThreading] Let SimplifyPartiallyRedundantLoad look into freeze
Juneyoung Lee via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 30 23:27:30 PDT 2020
aqjune updated this revision to Diff 282141.
aqjune added a comment.
Leave pre-load.ll's diff only
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D84944/new/
https://reviews.llvm.org/D84944
Files:
llvm/lib/Transforms/Scalar/JumpThreading.cpp
llvm/test/Transforms/JumpThreading/pre-load.ll
Index: llvm/test/Transforms/JumpThreading/pre-load.ll
===================================================================
--- llvm/test/Transforms/JumpThreading/pre-load.ll
+++ llvm/test/Transforms/JumpThreading/pre-load.ll
@@ -46,19 +46,19 @@
define i32 @pre_freeze(i1 %cond, i32 %n) {
; CHECK-LABEL: @pre_freeze(
-; CHECK-NEXT: br i1 [[COND:%.*]], label [[A:%.*]], label [[C:%.*]]
-; CHECK: A:
+; CHECK-NEXT: br i1 [[COND:%.*]], label [[C_THREAD:%.*]], label [[C:%.*]]
+; CHECK: C.thread:
; CHECK-NEXT: store i32 0, i32* @x, align 4
-; CHECK-NEXT: br label [[C]]
+; CHECK-NEXT: br label [[YES:%.*]]
; CHECK: C:
-; CHECK-NEXT: [[PTR:%.*]] = phi i32* [ @x, [[A]] ], [ @y, [[TMP0:%.*]] ]
-; CHECK-NEXT: [[A:%.*]] = load i32, i32* [[PTR]], align 4
-; CHECK-NEXT: [[COND2:%.*]] = icmp eq i32 [[A]], 0
+; CHECK-NEXT: [[A_PR:%.*]] = load i32, i32* @y, align 4
+; CHECK-NEXT: [[COND2:%.*]] = icmp eq i32 [[A_PR]], 0
; CHECK-NEXT: [[COND2_FR:%.*]] = freeze i1 [[COND2]]
-; CHECK-NEXT: br i1 [[COND2_FR]], label [[YES:%.*]], label [[NO:%.*]]
+; CHECK-NEXT: br i1 [[COND2_FR]], label [[YES]], label [[NO:%.*]]
; CHECK: YES:
+; CHECK-NEXT: [[A5:%.*]] = phi i32 [ 0, [[C_THREAD]] ], [ [[A_PR]], [[C]] ]
; CHECK-NEXT: call void @f()
-; CHECK-NEXT: ret i32 [[A]]
+; CHECK-NEXT: ret i32 [[A5]]
; CHECK: NO:
; CHECK-NEXT: call void @g()
; CHECK-NEXT: ret i32 1
Index: llvm/lib/Transforms/Scalar/JumpThreading.cpp
===================================================================
--- llvm/lib/Transforms/Scalar/JumpThreading.cpp
+++ llvm/lib/Transforms/Scalar/JumpThreading.cpp
@@ -1168,6 +1168,11 @@
// we see one, check to see if it's partially redundant. If so, insert a PHI
// which can then be used to thread the values.
Value *SimplifyValue = CondInst;
+
+ if (auto *FI = dyn_cast<FreezeInst>(SimplifyValue))
+ // Look into freeze's operand
+ SimplifyValue = FI->getOperand(0);
+
if (CmpInst *CondCmp = dyn_cast<CmpInst>(SimplifyValue))
if (isa<Constant>(CondCmp->getOperand(1)))
SimplifyValue = CondCmp->getOperand(0);
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D84944.282141.patch
Type: text/x-patch
Size: 2143 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20200731/814274a0/attachment.bin>
More information about the llvm-commits
mailing list