From: Manuel Jacob Date: Tue, 5 Jan 2016 19:40:58 +0000 (+0000) Subject: [PlaceSafepoints] Add a test. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=32704d03f242e7490c2cf4ad1a3c9b95e4811b5c;p=oota-llvm.git [PlaceSafepoints] Add a test. Calls of functions with the "gc-leaf-function" attribute shouldn't be turned into a safepoint. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@256860 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Transforms/PlaceSafepoints/leaf-function.ll b/test/Transforms/PlaceSafepoints/leaf-function.ll new file mode 100644 index 00000000000..3942abde183 --- /dev/null +++ b/test/Transforms/PlaceSafepoints/leaf-function.ll @@ -0,0 +1,24 @@ +; RUN: opt %s -S -place-safepoints | FileCheck %s + +declare void @foo() "gc-leaf-function" + +; Calls of functions with the "gc-leaf-function" attribute shouldn't get +; safepoints. An entry safepoint should get inserted, though. +define void @test_leaf_function() gc "statepoint-example" { +; CHECK-LABEL: test_leaf_function +; CHECK: gc.statepoint.p0f_isVoidf +; CHECK-NOT: statepoint +; CHECK-NOT: gc.result +entry: + call void @foo() + ret void +} + +; This function is inlined when inserting a poll. +declare void @do_safepoint() +define void @gc.safepoint_poll() { +; CHECK-LABEL: gc.safepoint_poll +entry: + call void @do_safepoint() + ret void +}