Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Verifier / intrinsic-arg-overloading-struct-ret.ll
blob7427a01d32e74596e9aa9fb50fa62e9c0b06adb5
1 ; RUN: not opt -passes=verify -S < %s 2>&1 | FileCheck %s
3 ; LD2 and LD2LANE
5 ; CHECK: Intrinsic has incorrect return type
6 ; CHECK-NEXT: llvm.aarch64.neon.ld2.v4i32
7 define { <4 x i64>, <4 x i32> } @test_ld2_ret(ptr %ptr) {
8   %res = call { <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld2.v4i32(ptr %ptr)
9   ret{ <4 x i64>, <4 x i32> } %res
11 declare { <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld2.v4i32(ptr %ptr)
13 ; CHECK: Intrinsic has incorrect return type
14 ; CHECK-NEXT: llvm.aarch64.neon.ld2lane.v4i64
15 define { <4 x i64>, <4 x i32> } @test_ld2lane_ret(ptr %ptr, <4 x i64> %a, <4 x i64> %b) {
16   %res = call { <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld2lane.v4i64(<4 x i64> %a, <4 x i64> %b, i64 0, ptr %ptr)
17   ret{ <4 x i64>, <4 x i32> } %res
19 declare { <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld2lane.v4i64(<4 x i64>, <4 x i64>, i64, ptr)
21 ; CHECK: Intrinsic has incorrect argument type
22 ; CHECK-NEXT: llvm.aarch64.neon.ld2lane.v4i32
23 define { <4 x i32>, <4 x i32> } @test_ld2lane_arg(ptr %ptr, <4 x i64> %a, <4 x i32> %b) {
24   %res = call { <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld2lane.v4i32(<4 x i64> %a, <4 x i32> %b, i64 0, ptr %ptr)
25   ret{ <4 x i32>, <4 x i32> } %res
27 declare { <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld2lane.v4i32(<4 x i64>, <4 x i32>, i64, ptr)
29 ; LD3 and LD3LANE
31 ; CHECK: Intrinsic has incorrect return type
32 ; CHECK-NEXT: llvm.aarch64.neon.ld3.v4i32
33 define { <4 x i32>, <4 x i64>, <4 x i32> } @test_ld3_ret(ptr %ptr) {
34   %res = call { <4 x i32>, <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld3.v4i32(ptr %ptr)
35   ret{ <4 x i32>, <4 x i64>, <4 x i32> } %res
37 declare { <4 x i32>, <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld3.v4i32(ptr %ptr)
39 ; CHECK: Intrinsic has incorrect return type
40 ; CHECK-NEXT: llvm.aarch64.neon.ld3lane.v4i64
41 define { <4 x i64>, <4 x i32>, <4 x i64> } @test_ld3lane_ret(ptr %ptr, <4 x i64> %a, <4 x i64> %b, <4 x i64> %c) {
42   %res = call { <4 x i64>, <4 x i32>, <4 x i64> } @llvm.aarch64.neon.ld3lane.v4i64(<4 x i64> %a, <4 x i64> %b, <4 x i64> %c, i64 0, ptr %ptr)
43   ret{ <4 x i64>, <4 x i32>, <4 x i64> } %res
45 declare { <4 x i64>, <4 x i32>, <4 x i64> } @llvm.aarch64.neon.ld3lane.v4i64(<4 x i64>, <4 x i64>, <4 x i64>, i64, ptr)
47 ; CHECK: Intrinsic has incorrect argument type
48 ; CHECK-NEXT: llvm.aarch64.neon.ld3lane.v4i32
49 define { <4 x i32>, <4 x i32>, <4 x i32> } @test_ld3lane_arg(ptr %ptr, <4 x i64> %a, <4 x i32> %b, <4 x i32> %c) {
50   %res = call { <4 x i32>, <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld3lane.v4i32(<4 x i64> %a, <4 x i32> %b, <4 x i32> %c, i64 0, ptr %ptr)
51   ret{ <4 x i32>, <4 x i32>, <4 x i32> } %res
53 declare { <4 x i32>, <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld3lane.v4i32(<4 x i64>, <4 x i32>, <4 x i32>, i64, ptr)
55 ; LD4 and LD4LANE
57 ; CHECK: Intrinsic has incorrect return type
58 ; CHECK-NEXT: llvm.aarch64.neon.ld4.v4i32
59 define { <4 x i32>, <4 x i32>, <4 x i64>, <4 x i32> } @test_ld4_ret(ptr %ptr) {
60   %res = call { <4 x i32>, <4 x i32>, <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld4.v4i32(ptr %ptr)
61   ret{ <4 x i32>, <4 x i32>, <4 x i64>, <4 x i32> } %res
63 declare { <4 x i32>, <4 x i32>, <4 x i64>, <4 x i32> } @llvm.aarch64.neon.ld4.v4i32(ptr %ptr)
65 ; CHECK: Intrinsic has incorrect return type
66 ; CHECK-NEXT: llvm.aarch64.neon.ld4lane.v4i64
67 define { <4 x i64>, <4 x i64>, <4 x i32>, <4 x i64> } @test_ld4lane_ret(ptr %ptr, <4 x i64> %a, <4 x i64> %b, <4 x i64> %c, <4 x i64> %d) {
68   %res = call { <4 x i64>, <4 x i64>, <4 x i32>, <4 x i64> } @llvm.aarch64.neon.ld4lane.v4i64(<4 x i64> %a, <4 x i64> %b, <4 x i64> %c, <4 x i64> %d, i64 0, ptr %ptr)
69   ret{ <4 x i64>, <4 x i64>, <4 x i32>, <4 x i64> } %res
71 declare { <4 x i64>, <4 x i64>, <4 x i32>, <4 x i64> } @llvm.aarch64.neon.ld4lane.v4i64(<4 x i64>, <4 x i64>, <4 x i64>, <4 x i64>, i64, ptr)
73 ; CHECK: Intrinsic has incorrect argument type
74 ; CHECK-NEXT: llvm.aarch64.neon.ld4lane.v4i32
75 define { <4 x i32>, <4 x i32>, <4 x i32>, <4 x i32> } @test_ld4lane_arg(ptr %ptr, <4 x i64> %a, <4 x i32> %b, <4 x i32> %c, <4 x i32> %d) {
76   %res = call { <4 x i32>, <4 x i32>, <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld4lane.v4i32(<4 x i64> %a, <4 x i32> %b, <4 x i32> %c, <4 x i32> %d, i64 0, ptr %ptr)
77   ret{ <4 x i32>, <4 x i32>, <4 x i32>, <4 x i32> } %res
79 declare { <4 x i32>, <4 x i32>, <4 x i32>, <4 x i32> } @llvm.aarch64.neon.ld4lane.v4i32(<4 x i64>, <4 x i32>, <4 x i32>, <4 x i32>, i64, ptr)