[MIParser] Set RegClassOrRegBank during instruction parsing
[llvm-complete.git] / test / Transforms / RewriteStatepointsForGC / base-pointers-12.ll
blobbf107694d990405771186048e418de6431805417
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 %select base null
6 @global = external addrspace(1) global i8
8 define i8 @test(i1 %cond) gc "statepoint-example" {
9   %derived1 = getelementptr i8, i8 addrspace(1)* @global, i64 1
10   %derived2 = getelementptr i8, i8 addrspace(1)* @global, i64 2
11   %select = select i1 %cond, i8 addrspace(1)* %derived1, i8 addrspace(1)* %derived2
12   call void @extern()
13 ; CHECK-NOT: relocate
14 ; CHECK: %load = load i8, i8 addrspace(1)* %select
15   %load = load i8, i8 addrspace(1)* %select
16   ret i8 %load
19 declare void @extern() gc "statepoint-example"
21 declare token @llvm.experimental.gc.statepoint.p0f_isVoidf(i64, i32, void ()*, i32, i32, ...)