[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Transforms / RewriteStatepointsForGC / base-pointers-5.ll
blob990a252d489e17782f42ab87f4852393b6a0994b
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 @foo()
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   br label %bump
15 bump:                                             ; preds = %here
16   br label %merge
18 there:                                            ; preds = %entry
19   %y = getelementptr i64, i64 addrspace(1)* %base_obj_y, i32 1
20   br label %merge
22 merge:                                            ; preds = %there, %bump
23 ; CHECK: merge:
24 ; CHECK:  %merged_value.base = phi i64 addrspace(1)* [ %base_obj_x, %bump ], [ %base_obj_y, %there ]
25 ; CHECK-NEXT:  %merged_value = phi i64 addrspace(1)* [ %base_obj_x, %bump ], [ %y, %there ]  
26   %merged_value = phi i64 addrspace(1)* [ %base_obj_x, %bump ], [ %y, %there ]
27   call void @foo() [ "deopt"(i32 0, i32 -1, i32 0, i32 0, i32 0) ]
28   ret i64 addrspace(1)* %merged_value