diff options
author | Sanjoy Das <sanjoy@playingwithpointers.com> | 2015-10-16 02:41:23 +0000 |
---|---|---|
committer | Sanjoy Das <sanjoy@playingwithpointers.com> | 2015-10-16 02:41:23 +0000 |
commit | 58fae7cf6bb3d76e8ee993abf1ddc485574b9ef7 (patch) | |
tree | dbdeca1b7edf4285c06abef3098f320324df1873 /llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll | |
parent | 810a59d037dc4247ca52ab4e29f70ce611d574fc (diff) | |
download | bcm5719-llvm-58fae7cf6bb3d76e8ee993abf1ddc485574b9ef7.tar.gz bcm5719-llvm-58fae7cf6bb3d76e8ee993abf1ddc485574b9ef7.zip |
[RS4GC] Dont' propagate call attrs related to patchable statepoints
The `"statepoint-id"` and `"statepoint-num-patch-bytes"` attributes are
used solely to determine properties of the `gc.statepoint` being
created. Once the `gc.statepoint` is in place, these should be removed.
llvm-svn: 250491
Diffstat (limited to 'llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll')
-rw-r--r-- | llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll b/llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll new file mode 100644 index 00000000000..0c6a20295a6 --- /dev/null +++ b/llvm/test/Transforms/RewriteStatepointsForGC/deopt-bundles/patchable-statepoints.ll @@ -0,0 +1,44 @@ +; RUN: opt -S -rewrite-statepoints-for-gc -rs4gc-use-deopt-bundles < %s | FileCheck %s + +declare void @f() +declare i32 @personality_function() + +define void @test_id() gc "statepoint-example" personality i32 ()* @personality_function { +; CHECK-LABEL: @test_id( +entry: +; CHECK-LABEL: entry: +; CHECK: invoke i32 (i64, i32, void ()*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidf(i64 100, i32 0, void ()* @f + invoke void @f() "statepoint-id"="100" to label %normal_return unwind label %exceptional_return + +normal_return: + ret void + +exceptional_return: + %landing_pad4 = landingpad {i8*, i32} cleanup + ret void +} + +define void @test_num_patch_bytes() gc "statepoint-example" personality i32 ()* @personality_function { +; CHECK-LABEL: @test_num_patch_bytes( +entry: +; CHECK-LABEL: entry: +; CHECK: invoke i32 (i64, i32, void ()*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidf(i64 2882400000, i32 99, void ()* @f, + invoke void @f() "statepoint-num-patch-bytes"="99" to label %normal_return unwind label %exceptional_return + +normal_return: + ret void + +exceptional_return: + %landing_pad4 = landingpad {i8*, i32} cleanup + ret void +} + +declare void @do_safepoint() +define void @gc.safepoint_poll() { +entry: + call void @do_safepoint() + ret void +} + +; CHECK-NOT: statepoint-id +; CHECK-NOT: statepoint-num-patch_bytes |