summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2011-01-03 23:38:13 +0000
committerChris Lattner <sabre@nondot.org>2011-01-03 23:38:13 +0000
commitbde6ec1db6fd3a2d8d4022baa4e0735b3d01f613 (patch)
treed86c596466a92fffbfe1f0761a590c601ba3f970
parentcd12b63b47aeee69b5c95135e97f0cd058423e7d (diff)
downloadbcm5719-llvm-bde6ec1db6fd3a2d8d4022baa4e0735b3d01f613.tar.gz
bcm5719-llvm-bde6ec1db6fd3a2d8d4022baa4e0735b3d01f613.zip
Duncan deftly points out that readnone functions aren't
invalidated by stores, so they can be handled as 'simple' operations. llvm-svn: 122785
-rw-r--r--llvm/lib/Transforms/Scalar/EarlyCSE.cpp6
-rw-r--r--llvm/test/Transforms/EarlyCSE/basic.ll13
2 files changed, 18 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/EarlyCSE.cpp b/llvm/lib/Transforms/Scalar/EarlyCSE.cpp
index 6c2ea39896a..3d3f17b26fc 100644
--- a/llvm/lib/Transforms/Scalar/EarlyCSE.cpp
+++ b/llvm/lib/Transforms/Scalar/EarlyCSE.cpp
@@ -56,6 +56,9 @@ namespace {
}
static bool canHandle(Instruction *Inst) {
+ // This can only handle non-void readnone functions.
+ if (CallInst *CI = dyn_cast<CallInst>(Inst))
+ return CI->doesNotAccessMemory() && !CI->getType()->isVoidTy();
return isa<CastInst>(Inst) || isa<BinaryOperator>(Inst) ||
isa<GetElementPtrInst>(Inst) || isa<CmpInst>(Inst) ||
isa<SelectInst>(Inst) || isa<ExtractElementInst>(Inst) ||
@@ -105,7 +108,8 @@ unsigned DenseMapInfo<SimpleValue>::getHashValue(SimpleValue Val) {
Res ^= *I;
} else {
// nothing extra to hash in.
- assert((isa<BinaryOperator>(Inst) || isa<GetElementPtrInst>(Inst) ||
+ assert((isa<CallInst>(Inst) ||
+ isa<BinaryOperator>(Inst) || isa<GetElementPtrInst>(Inst) ||
isa<SelectInst>(Inst) || isa<ExtractElementInst>(Inst) ||
isa<InsertElementInst>(Inst) || isa<ShuffleVectorInst>(Inst)) &&
"Invalid/unknown instruction");
diff --git a/llvm/test/Transforms/EarlyCSE/basic.ll b/llvm/test/Transforms/EarlyCSE/basic.ll
index bc152e70624..e3c75f97dcf 100644
--- a/llvm/test/Transforms/EarlyCSE/basic.ll
+++ b/llvm/test/Transforms/EarlyCSE/basic.ll
@@ -106,3 +106,16 @@ define void @test7(i32 *%P) {
; CHECK-NEXT: store i32 45
; CHECK-NEXT: ret void
}
+
+;; Readnone functions aren't invalidated by stores.
+; CHECK: @test8
+define i32 @test8(i32 *%P) {
+ %V1 = call i32 @func(i32* %P) readnone
+ store i32 4, i32* %P
+ %V2 = call i32 @func(i32* %P) readnone
+ %Diff = sub i32 %V1, %V2
+ ret i32 %Diff
+ ; CHECK: ret i32 0
+}
+
+
OpenPOWER on IntegriCloud