summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll
diff options
context:
space:
mode:
authorPhilip Reames <listmail@philipreames.com>2015-04-10 22:07:04 +0000
committerPhilip Reames <listmail@philipreames.com>2015-04-10 22:07:04 +0000
commit85b36a8157eef76096d4a8e93f74eb05c8dcbc53 (patch)
tree342b3df705f2ab2deeddd807d5ac59ff3274852e /llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll
parent942d51a25f6e7b4fdb9515b5388aaab41ab75bcb (diff)
downloadbcm5719-llvm-85b36a8157eef76096d4a8e93f74eb05c8dcbc53.tar.gz
bcm5719-llvm-85b36a8157eef76096d4a8e93f74eb05c8dcbc53.zip
[RewriteStatepointsForGC] Preprocess the IR to remove unreachable blocks and single entry phis
Two related small changes: Various dominance based queries about liveness can get confused if we're talking about unreachable blocks. To avoid reasoning about such cases, just remove them before rewriting statepoints. Remove single entry phis (likely left behind by LCSSA) to reduce the number of live values. Both of these are motivated by http://reviews.llvm.org/D8674 which will be submitted shortly. Differential Revision: http://reviews.llvm.org/D8675 llvm-svn: 234651
Diffstat (limited to 'llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll')
-rw-r--r--llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll65
1 files changed, 65 insertions, 0 deletions
diff --git a/llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll b/llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll
new file mode 100644
index 00000000000..6027b2d5ecc
--- /dev/null
+++ b/llvm/test/Transforms/RewriteStatepointsForGC/preprocess.ll
@@ -0,0 +1,65 @@
+; RUN: opt -rewrite-statepoints-for-gc -S < %s | FileCheck %s
+
+declare void @consume(...)
+
+; Test to make sure we destroy LCSSA's single entry phi nodes before
+; running liveness
+define void @test6(i64 addrspace(1)* %obj) gc "statepoint-example" {
+; CHECK-LABEL: @test6
+entry:
+ br label %next
+
+next:
+; CHECK-LABEL: next:
+; CHECK-NEXT: gc.statepoint
+; CHECK-NEXT: gc.relocate
+; CHECK-NEXT: @consume(i64 addrspace(1)* %obj.relocated)
+; CHECK-NEXT: @consume(i64 addrspace(1)* %obj.relocated)
+ %obj2 = phi i64 addrspace(1)* [ %obj, %entry ]
+ call i32 (void ()*, i32, i32, ...)* @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()* @foo, i32 0, i32 0, i32 0)
+ call void (...)* @consume(i64 addrspace(1)* %obj2)
+ call void (...)* @consume(i64 addrspace(1)* %obj)
+ ret void
+}
+
+declare void @some_call(i64 addrspace(1)*)
+
+; Need to delete unreachable gc.statepoint call
+define void @test7() gc "statepoint-example" {
+; CHECK-LABEL: test7
+; CHECK-NOT: gc.statepoint
+ ret void
+
+unreached:
+ %obj = phi i64 addrspace(1)* [null, %unreached]
+ call i32 (void ()*, i32, i32, ...)* @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()* @foo, i32 0, i32 0, i32 0)
+ call void (...)* @consume(i64 addrspace(1)* %obj)
+ br label %unreached
+}
+
+; Need to delete unreachable gc.statepoint invoke - tested seperately given
+; a correct implementation could only remove the instructions, not the block
+define void @test8() gc "statepoint-example" {
+; CHECK-LABEL: test8
+; CHECK-NOT: gc.statepoint
+ ret void
+
+unreached:
+ invoke i32 (void ()*, i32, i32, ...)* @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()* @foo, i32 0, i32 0, i32 0)
+ to label %normal_return unwind label %exceptional_return
+
+normal_return: ; preds = %entry
+ ret void
+
+exceptional_return: ; preds = %entry
+ %landing_pad4 = landingpad { i8*, i32 } personality i32 ()* undef
+ cleanup
+ ret void
+}
+
+declare void @foo()
+; Bound the last check-not
+; CHECK-LABEL: @foo
+
+declare i32 @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()*, i32, i32, ...)
+
OpenPOWER on IntegriCloud