[RewriteStatepointsForGC] Fix a bug on creating gc_relocate for pointer to vector...
[oota-llvm.git] / test / Transforms / RewriteStatepointsForGC / gc_relocate_creation.ll
1 ; RUN: opt %s -rewrite-statepoints-for-gc -S 2>&1 | FileCheck %s
2 ; This test is to verify gc.relocate can handle pointer to vector of
3 ; pointers (<2 x i32 addrspace(1)*> addrspace(1)* in this case).
4 ; The old scheme to create a gc.relocate of <2 x i32 addrspace(1)*> addrspace(1)*
5 ; type will fail because llvm does not support mangling vector of pointers.
6 ; The new scheme will create all gc.relocate to i8 addrspace(1)* type and
7 ; then bitcast to the correct type.
8
9 declare void @foo()
10 declare void @use(...)
11 declare i32 @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()*, i32, i32, ...)
12
13 define void @test1(<2 x i32 addrspace(1)*> addrspace(1)* %obj) gc "statepoint-example" {
14 entry:
15   %safepoint_token = call i32 (void ()*, i32, i32, ...) @llvm.experimental.gc.statepoint.p0f_isVoidf(void ()* @foo, i32 0, i32 0, i32 0, i32 0)
16 ; CHECK: %obj.relocated = call coldcc i8 addrspace(1)* @llvm.experimental.gc.relocate.p1i8(i32 %safepoint_token, i32 5, i32 5)
17 ; CHECK-NEXT:  %obj.relocated.casted = bitcast i8 addrspace(1)* %obj.relocated to <2 x i32 addrspace(1)*> addrspace(1)*
18   call void (...) @use(<2 x i32 addrspace(1)*> addrspace(1)* %obj)
19   ret void
20 }