mirror of
https://github.com/RPCS3/llvm.git
synced 2025-05-15 01:46:46 +00:00

Summary: The port is nearly straightforward. The only complication is related to the analyses handling, since one of the analyses used in this module pass is domtree, which is a function analysis. That requires asking for the results of each function and disallows a single interface for run-on-module pass action. Decided to copy-paste the main body of this pass. Most of its code is requesting analyses anyway, so not that much of a copy-paste. The rest of the code movement is to transform all the implementation helper functions like stripNonValidData into non-member statics. Extended all the related LLVM tests with new-pass-manager use. No failures. Reviewers: sanjoy, anna, reames Reviewed By: anna Subscribers: skatkov, llvm-commits Differential Revision: https://reviews.llvm.org/D41162 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@320796 91177308-0d34-0410-b5e6-96231b3b80d8
47 lines
1.9 KiB
LLVM
47 lines
1.9 KiB
LLVM
; RUN: opt < %s -rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s
|
|
; RUN: opt < %s -passes=rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s
|
|
|
|
; CHECK: derived %merged_value base %merged_value.base
|
|
|
|
declare void @site_for_call_safpeoint()
|
|
|
|
define i64 addrspace(1)* @test(i64 addrspace(1)* %base_obj_x, i64 addrspace(1)* %base_obj_y, i1 %runtime_condition_x, i1 %runtime_condition_y) gc "statepoint-example" {
|
|
entry:
|
|
br i1 %runtime_condition_x, label %here, label %there
|
|
|
|
here: ; preds = %entry
|
|
br i1 %runtime_condition_y, label %bump_here_a, label %bump_here_b
|
|
|
|
bump_here_a: ; preds = %here
|
|
%x_a = getelementptr i64, i64 addrspace(1)* %base_obj_x, i32 1
|
|
br label %merge_here
|
|
|
|
bump_here_b: ; preds = %here
|
|
%x_b = getelementptr i64, i64 addrspace(1)* %base_obj_y, i32 2
|
|
br label %merge_here
|
|
|
|
merge_here: ; preds = %bump_here_b, %bump_here_a
|
|
; CHECK: merge_here:
|
|
; CHECK-DAG: %x.base
|
|
; CHECK-DAG: phi i64 addrspace(1)*
|
|
; CHECK-DAG: [ %base_obj_x, %bump_here_a ]
|
|
; CHECK-DAG: [ %base_obj_y, %bump_here_b ]
|
|
%x = phi i64 addrspace(1)* [ %x_a, %bump_here_a ], [ %x_b, %bump_here_b ]
|
|
br label %merge
|
|
|
|
there: ; preds = %entry
|
|
%y = getelementptr i64, i64 addrspace(1)* %base_obj_y, i32 1
|
|
br label %merge
|
|
|
|
merge: ; preds = %there, %merge_here
|
|
; CHECK: merge:
|
|
; CHECK-DAG: %merged_value.base
|
|
; CHECK-DAG: phi i64 addrspace(1)*
|
|
; CHECK-DAG: %merge_here
|
|
; CHECK-DAG: [ %base_obj_y, %there ]
|
|
; CHECK: %merged_value = phi i64 addrspace(1)* [ %x, %merge_here ], [ %y, %there ]
|
|
%merged_value = phi i64 addrspace(1)* [ %x, %merge_here ], [ %y, %there ]
|
|
call void @site_for_call_safpeoint() [ "deopt"(i32 0, i32 -1, i32 0, i32 0, i32 0) ]
|
|
ret i64 addrspace(1)* %merged_value
|
|
}
|