summaryrefslogtreecommitdiffstats
path: root/llvm/test
diff options
context:
space:
mode:
authorPeter Collingbourne <peter@pcc.me.uk>2016-05-26 04:58:46 +0000
committerPeter Collingbourne <peter@pcc.me.uk>2016-05-26 04:58:46 +0000
commitb9aa1f4a03a3e1d8e062ceff6eb8ed71b4dd93eb (patch)
treef7e2da340d2843d74a4c5375e9054fd4726bfa52 /llvm/test
parent3bfedcffe09c393b1a94f4f58e2d5717122dd421 (diff)
downloadbcm5719-llvm-b9aa1f4a03a3e1d8e062ceff6eb8ed71b4dd93eb.tar.gz
bcm5719-llvm-b9aa1f4a03a3e1d8e062ceff6eb8ed71b4dd93eb.zip
MemorySSA: Revert r269678 and r268068; replace with special casing in MemorySSA.
It turns out that too many passes are relying on alias analysis results for control dependencies. Until we fix that by introducing a more accurate modelling of control dependencies, special case assume in MemorySSA instead. Also introduce tests to ensure we don't regress the FunctionAttrs or LICM passes. Differential Revision: http://reviews.llvm.org/D20658 llvm-svn: 270823
Diffstat (limited to 'llvm/test')
-rw-r--r--llvm/test/Transforms/FunctionAttrs/assume.ll4
-rw-r--r--llvm/test/Transforms/LICM/assume.ll34
-rw-r--r--llvm/test/Transforms/Util/MemorySSA/assume.ll1
3 files changed, 39 insertions, 0 deletions
diff --git a/llvm/test/Transforms/FunctionAttrs/assume.ll b/llvm/test/Transforms/FunctionAttrs/assume.ll
new file mode 100644
index 00000000000..58200622eab
--- /dev/null
+++ b/llvm/test/Transforms/FunctionAttrs/assume.ll
@@ -0,0 +1,4 @@
+; RUN: opt -S -o - -functionattrs %s | FileCheck %s
+
+; CHECK-NOT: readnone
+declare void @llvm.assume(i1)
diff --git a/llvm/test/Transforms/LICM/assume.ll b/llvm/test/Transforms/LICM/assume.ll
new file mode 100644
index 00000000000..9abf5578287
--- /dev/null
+++ b/llvm/test/Transforms/LICM/assume.ll
@@ -0,0 +1,34 @@
+; RUN: opt -licm -basicaa < %s -S | FileCheck %s
+
+define void @f(i1 %p) nounwind ssp {
+entry:
+ br label %for.body
+
+for.body:
+ br i1 undef, label %if.then, label %for.cond.backedge
+
+for.cond.backedge:
+ br i1 undef, label %for.end104, label %for.body
+
+if.then:
+ br i1 undef, label %if.then27, label %if.end.if.end.split_crit_edge.critedge
+
+if.then27:
+; CHECK: tail call void @llvm.assume
+ tail call void @llvm.assume(i1 %p)
+ br label %for.body61.us
+
+if.end.if.end.split_crit_edge.critedge:
+ br label %for.body61
+
+for.body61.us:
+ br i1 undef, label %for.cond.backedge, label %for.body61.us
+
+for.body61:
+ br i1 undef, label %for.cond.backedge, label %for.body61
+
+for.end104:
+ ret void
+}
+
+declare void @llvm.assume(i1)
diff --git a/llvm/test/Transforms/Util/MemorySSA/assume.ll b/llvm/test/Transforms/Util/MemorySSA/assume.ll
index bdd10fc28b4..8496eb9c12d 100644
--- a/llvm/test/Transforms/Util/MemorySSA/assume.ll
+++ b/llvm/test/Transforms/Util/MemorySSA/assume.ll
@@ -8,6 +8,7 @@ define i32 @foo(i32* %a, i32* %b, i1 %c) {
; CHECK: 1 = MemoryDef(liveOnEntry)
; CHECK-NEXT: store i32 4
store i32 4, i32* %a, align 4
+; CHECK-NOT: MemoryDef
; CHECK: call void @llvm.assume
call void @llvm.assume(i1 %c)
; CHECK: MemoryUse(1)
OpenPOWER on IntegriCloud