[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Transforms / RewriteStatepointsForGC / base-pointers-1.ll
blobbc8a863896be42a16f8322be609615ad677e3210
1 ; RUN: opt < %s -rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s
2 ; RUN: opt < %s -passes=rewrite-statepoints-for-gc -spp-print-base-pointers -S 2>&1 | FileCheck %s
4 ; CHECK: derived %merged_value base %merged_value.base
6 declare void @site_for_call_safpeoint()
8 define i64 addrspace(1)* @test(i64 addrspace(1)* %base_obj_x, i64 addrspace(1)* %base_obj_y, i1 %runtime_condition) gc "statepoint-example" {
9 entry:
10   br i1 %runtime_condition, label %here, label %there
12 here:                                             ; preds = %entry
13   %x = getelementptr i64, i64 addrspace(1)* %base_obj_x, i32 1
14   br label %merge
16 there:                                            ; preds = %entry
17   %y = getelementptr i64, i64 addrspace(1)* %base_obj_y, i32 1
18   br label %merge
20 merge:                                            ; preds = %there, %here
21 ; CHECK-LABEL: merge:
22 ; CHECK:   %merged_value.base = phi i64 addrspace(1)* [ %base_obj_x, %here ], [ %base_obj_y, %there ]
23   %merged_value = phi i64 addrspace(1)* [ %x, %here ], [ %y, %there ]
24   call void @site_for_call_safpeoint() [ "deopt"(i32 0, i32 -1, i32 0, i32 0, i32 0) ]
25   ret i64 addrspace(1)* %merged_value