[ARM] Better OR's for MVE compares
[llvm-core.git] / test / Transforms / RewriteStatepointsForGC / base-pointers-11.ll
blobceb094606b0e210a4952e0a2f1ef1bf136f38ef9
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 %next base %base_obj
6 declare void @do_safepoint()
8 define void @test(i64 addrspace(1)* %base_obj) gc "statepoint-example" {
9 entry:
10   %obj = getelementptr i64, i64 addrspace(1)* %base_obj, i32 1
11   br label %loop
13 loop:                                             ; preds = %loop, %entry
14 ; CHECK-LABEL: loop:
15 ; CHECK: phi i64 addrspace(1)*
16 ; CHECK-DAG:  [ %base_obj.relocated.casted, %loop ] 
17 ; CHECK-DAG:  [ %base_obj, %entry ]
18 ; CHECK:  %current = phi i64 addrspace(1)* 
19 ; CHECK-DAG:  [ %obj, %entry ]
20 ; CHECK-DAG:  [ %next.relocated.casted, %loop ]
21   %current = phi i64 addrspace(1)* [ %obj, %entry ], [ %next, %loop ]
22   %next = getelementptr i64, i64 addrspace(1)* %current, i32 1
23   call void @do_safepoint() [ "deopt"(i32 0, i32 -1, i32 0, i32 0, i32 0) ]
24   br label %loop