Bump version to 19.1.0-rc3
[llvm-project.git] / llvm / test / Assembler / opaque-ptr-intrinsic-remangling.ll
blob070bcd40438df2026be9dd3e63b98e915e701b87
1 ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2 ; RUN: opt -S < %s | FileCheck %s
4 ; Make sure that opaque pointer intrinsic remangling upgrade works.
6 %int8x16x2_t = type { <16 x i8>, <16 x i8> }
8 declare ptr @fake_personality_function()
9 declare void @func()
11 ; Upgrading of invoked intrinsic.
12 define void @test_invoke(ptr addrspace(1) %b) gc "statepoint-example" personality ptr @fake_personality_function {
13 ; CHECK-LABEL: @test_invoke(
14 ; CHECK-NEXT:  entry:
15 ; CHECK-NEXT:    [[D:%.*]] = getelementptr i32, ptr addrspace(1) [[B:%.*]], i64 16
16 ; CHECK-NEXT:    [[SAFEPOINT_TOKEN:%.*]] = invoke token (i64, i32, ptr, i32, i32, ...) @llvm.experimental.gc.statepoint.p0(i64 0, i32 0, ptr elementtype(void ()) @func, i32 0, i32 0, i32 0, i32 0) [ "gc-live"(ptr addrspace(1) [[B]], ptr addrspace(1) [[B]], ptr addrspace(1) [[D]], ptr addrspace(1) [[D]]) ]
17 ; CHECK-NEXT:    to label [[NORMAL_DEST:%.*]] unwind label [[UNWIND_DEST:%.*]]
18 ; CHECK:       normal_dest:
19 ; CHECK-NEXT:    ret void
20 ; CHECK:       unwind_dest:
21 ; CHECK-NEXT:    [[LPAD:%.*]] = landingpad token
22 ; CHECK-NEXT:    cleanup
23 ; CHECK-NEXT:    ret void
25 entry:
26   %d = getelementptr i32, ptr addrspace(1) %b, i64 16
27   %safepoint_token = invoke token (i64, i32, ptr, i32, i32, ...) @llvm.experimental.gc.statepoint.p0(i64 0, i32 0, ptr elementtype(void ()) @func, i32 0, i32 0, i32 0, i32 0) ["gc-live" (ptr addrspace(1) %b, ptr addrspace(1) %b, ptr addrspace(1) %d, ptr addrspace(1) %d)]
28   to label %normal_dest unwind label %unwind_dest
30 normal_dest:
31   ret void
33 unwind_dest:
34   %lpad = landingpad token
35   cleanup
36   ret void
39 define ptr @test_ptr_annotation(ptr %p) {
40 ; CHECK-LABEL: @test_ptr_annotation(
41 ; CHECK-NEXT:    [[P2:%.*]] = call ptr @llvm.ptr.annotation.p0.p0(ptr [[P:%.*]], ptr undef, ptr undef, i32 undef, ptr undef)
42 ; CHECK-NEXT:    ret ptr [[P2]]
44   %p2 = call ptr @llvm.ptr.annotation.p0(ptr %p, ptr undef, ptr undef, i32 undef, ptr undef)
45   ret ptr %p2
49 define void @test_struct_return(ptr %res.p, ptr %a) {
50 ; CHECK-LABEL: @test_struct_return(
51 ; CHECK-NEXT:    [[TMP1:%.*]] = call { <16 x i8>, <16 x i8> } @llvm.aarch64.neon.ld1x2.v16i8.p0(ptr [[A:%.*]])
52 ; CHECK-NEXT:    [[TMP2:%.*]] = extractvalue { <16 x i8>, <16 x i8> } [[TMP1]], 0
53 ; CHECK-NEXT:    [[TMP3:%.*]] = insertvalue [[INT8X16X2_T:%.*]] poison, <16 x i8> [[TMP2]], 0
54 ; CHECK-NEXT:    [[TMP4:%.*]] = extractvalue { <16 x i8>, <16 x i8> } [[TMP1]], 1
55 ; CHECK-NEXT:    [[TMP5:%.*]] = insertvalue [[INT8X16X2_T]] [[TMP3]], <16 x i8> [[TMP4]], 1
56 ; CHECK-NEXT:    store [[INT8X16X2_T]] [[TMP5]], ptr [[RES_P:%.*]], align 16
57 ; CHECK-NEXT:    ret void
59   %res = call %int8x16x2_t @llvm.aarch64.neon.ld1x2.v16i8.p0(ptr %a)
60   store %int8x16x2_t %res, ptr %res.p
61   ret void
64 declare token @llvm.experimental.gc.statepoint.p0(i64, i32, ptr, i32, i32, ...)
65 declare ptr @llvm.ptr.annotation.p0(ptr, ptr, ptr, i32, ptr)
66 declare %int8x16x2_t @llvm.aarch64.neon.ld1x2.v16i8.p0(ptr)