[PATCH] D40886: [LVI] Support for ashr in LVI
Surya Kumari Jangala via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Mon Dec 18 04:47:04 PST 2017
jskumari updated this revision to Diff 127337.
jskumari added a comment.
Updating the patch to reflect correct path names.
https://reviews.llvm.org/D40886
Files:
lib/Analysis/LazyValueInfo.cpp
test/Analysis/LazyValueAnalysis/lvi-for-ashr.ll
Index: test/Analysis/LazyValueAnalysis/lvi-for-ashr.ll
===================================================================
--- /dev/null
+++ test/Analysis/LazyValueAnalysis/lvi-for-ashr.ll
@@ -0,0 +1,27 @@
+; RUN: opt -correlated-propagation -S %s | FileCheck %s
+; CHECK-LABEL: @test-ashr
+; CHECK: bb_then
+; CHECK: %. = select i1 true, i32 3, i32 2
+define i32 @test-ashr(i32 %c) {
+chk65:
+ %cmp = icmp sgt i32 %c, 65
+ br i1 %cmp, label %return, label %chk0
+
+chk0:
+ %cmp1 = icmp slt i32 %c, 0
+ br i1 %cmp, label %return, label %bb_if
+
+bb_if:
+ %ashr.val = ashr exact i32 %c, 2
+ %cmp2 = icmp sgt i32 %ashr.val, 15
+ br i1 %cmp2, label %bb_then, label %return
+
+bb_then:
+ %cmp3 = icmp eq i32 %ashr.val, 16
+ %. = select i1 %cmp3, i32 3, i32 2
+ br label %return
+
+return:
+ %retval = phi i32 [0, %chk65], [1, %chk0], [%., %bb_then], [4, %bb_if]
+ ret i32 %retval
+}
Index: lib/Analysis/LazyValueInfo.cpp
===================================================================
--- lib/Analysis/LazyValueInfo.cpp
+++ lib/Analysis/LazyValueInfo.cpp
@@ -1003,6 +1003,7 @@
case Instruction::UDiv:
case Instruction::Shl:
case Instruction::LShr:
+ case Instruction::AShr:
case Instruction::And:
case Instruction::Or:
// continue into the code below
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D40886.127337.patch
Type: text/x-patch
Size: 1285 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20171218/a68bbf82/attachment-0001.bin>
More information about the llvm-commits
mailing list