Sanjoy Das | 0407108 | 2016-01-29 00:28:57 +0000 | [diff] [blame] | 1 | ; RUN: opt < %s -rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s |
Fedor Sergeev | 4b86d79 | 2017-12-15 09:32:11 +0000 | [diff] [blame] | 2 | ; RUN: opt < %s -passes=rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s |
Philip Reames | a5aeaf4 | 2015-02-28 00:20:48 +0000 | [diff] [blame] | 3 | |
| 4 | ; CHECK: derived %merged_value base %base_obj |
| 5 | |
Philip Reames | a5aeaf4 | 2015-02-28 00:20:48 +0000 | [diff] [blame] | 6 | define i64 addrspace(1)* @test(i64 addrspace(1)* %base_obj, i1 %runtime_condition) gc "statepoint-example" { |
| 7 | entry: |
| 8 | br i1 %runtime_condition, label %merge, label %there |
| 9 | |
Sanjoy Das | 0407108 | 2016-01-29 00:28:57 +0000 | [diff] [blame] | 10 | there: ; preds = %entry |
Philip Reames | a5aeaf4 | 2015-02-28 00:20:48 +0000 | [diff] [blame] | 11 | %derived_obj = getelementptr i64, i64 addrspace(1)* %base_obj, i32 1 |
| 12 | br label %merge |
| 13 | |
Sanjoy Das | 0407108 | 2016-01-29 00:28:57 +0000 | [diff] [blame] | 14 | merge: ; preds = %there, %entry |
Philip Reames | a5aeaf4 | 2015-02-28 00:20:48 +0000 | [diff] [blame] | 15 | %merged_value = phi i64 addrspace(1)* [ %base_obj, %entry ], [ %derived_obj, %there ] |
Sanjoy Das | 0407108 | 2016-01-29 00:28:57 +0000 | [diff] [blame] | 16 | call void @foo() [ "deopt"(i32 0, i32 -1, i32 0, i32 0, i32 0) ] |
Philip Reames | a5aeaf4 | 2015-02-28 00:20:48 +0000 | [diff] [blame] | 17 | ret i64 addrspace(1)* %merged_value |
| 18 | } |
| 19 | |
| 20 | declare void @foo() |