1 // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
2 // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve2 -S -O1 -Werror -Wall -emit-llvm -o - %s | FileCheck %s
3 // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sve2 -S -O1 -Werror -Wall -emit-llvm -o - -x c++ %s | FileCheck %s -check-prefix=CPP-CHECK
4 // RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve2 -S -O1 -Werror -Wall -emit-llvm -o - %s | FileCheck %s
5 // RUN: %clang_cc1 -DSVE_OVERLOADED_FORMS -triple aarch64-none-linux-gnu -target-feature +sve2 -S -O1 -Werror -Wall -emit-llvm -o - -x c++ %s | FileCheck %s -check-prefix=CPP-CHECK
7 // REQUIRES: aarch64-registered-target
11 #ifdef SVE_OVERLOADED_FORMS
12 // A simple used,unused... macro, long enough to represent any SVE builtin.
13 #define SVE_ACLE_FUNC(A1,A2_UNUSED,A3,A4_UNUSED) A1##A3
15 #define SVE_ACLE_FUNC(A1,A2,A3,A4) A1##A2##A3##A4
18 // CHECK-LABEL: @test_svwhilege_b8_s32(
20 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilege.nxv16i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
21 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
23 // CPP-CHECK-LABEL: @_Z21test_svwhilege_b8_s32ii(
24 // CPP-CHECK-NEXT: entry:
25 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilege.nxv16i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
26 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
28 svbool_t
test_svwhilege_b8_s32(int32_t op1
, int32_t op2
)
30 return SVE_ACLE_FUNC(svwhilege_b8
,_s32
,,)(op1
, op2
);
33 // CHECK-LABEL: @test_svwhilege_b16_s32(
35 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilege.nxv8i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
36 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
37 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
39 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b16_s32ii(
40 // CPP-CHECK-NEXT: entry:
41 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilege.nxv8i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
42 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
43 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
45 svbool_t
test_svwhilege_b16_s32(int32_t op1
, int32_t op2
)
47 return SVE_ACLE_FUNC(svwhilege_b16
,_s32
,,)(op1
, op2
);
50 // CHECK-LABEL: @test_svwhilege_b32_s32(
52 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilege.nxv4i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
53 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
54 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
56 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b32_s32ii(
57 // CPP-CHECK-NEXT: entry:
58 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilege.nxv4i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
59 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
60 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
62 svbool_t
test_svwhilege_b32_s32(int32_t op1
, int32_t op2
)
64 return SVE_ACLE_FUNC(svwhilege_b32
,_s32
,,)(op1
, op2
);
67 // CHECK-LABEL: @test_svwhilege_b64_s32(
69 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilege.nxv2i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
70 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
71 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
73 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b64_s32ii(
74 // CPP-CHECK-NEXT: entry:
75 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilege.nxv2i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
76 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
77 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
79 svbool_t
test_svwhilege_b64_s32(int32_t op1
, int32_t op2
)
81 return SVE_ACLE_FUNC(svwhilege_b64
,_s32
,,)(op1
, op2
);
84 // CHECK-LABEL: @test_svwhilege_b8_u32(
86 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilehs.nxv16i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
87 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
89 // CPP-CHECK-LABEL: @_Z21test_svwhilege_b8_u32jj(
90 // CPP-CHECK-NEXT: entry:
91 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilehs.nxv16i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
92 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
94 svbool_t
test_svwhilege_b8_u32(uint32_t op1
, uint32_t op2
)
96 return SVE_ACLE_FUNC(svwhilege_b8
,_u32
,,)(op1
, op2
);
99 // CHECK-LABEL: @test_svwhilege_b16_u32(
100 // CHECK-NEXT: entry:
101 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilehs.nxv8i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
102 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
103 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
105 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b16_u32jj(
106 // CPP-CHECK-NEXT: entry:
107 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilehs.nxv8i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
108 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
109 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
111 svbool_t
test_svwhilege_b16_u32(uint32_t op1
, uint32_t op2
)
113 return SVE_ACLE_FUNC(svwhilege_b16
,_u32
,,)(op1
, op2
);
116 // CHECK-LABEL: @test_svwhilege_b32_u32(
117 // CHECK-NEXT: entry:
118 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilehs.nxv4i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
119 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
120 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
122 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b32_u32jj(
123 // CPP-CHECK-NEXT: entry:
124 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilehs.nxv4i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
125 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
126 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
128 svbool_t
test_svwhilege_b32_u32(uint32_t op1
, uint32_t op2
)
130 return SVE_ACLE_FUNC(svwhilege_b32
,_u32
,,)(op1
, op2
);
133 // CHECK-LABEL: @test_svwhilege_b64_u32(
134 // CHECK-NEXT: entry:
135 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilehs.nxv2i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
136 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
137 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
139 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b64_u32jj(
140 // CPP-CHECK-NEXT: entry:
141 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilehs.nxv2i1.i32(i32 [[OP1:%.*]], i32 [[OP2:%.*]])
142 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
143 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
145 svbool_t
test_svwhilege_b64_u32(uint32_t op1
, uint32_t op2
)
147 return SVE_ACLE_FUNC(svwhilege_b64
,_u32
,,)(op1
, op2
);
150 // CHECK-LABEL: @test_svwhilege_b8_s64(
151 // CHECK-NEXT: entry:
152 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilege.nxv16i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
153 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
155 // CPP-CHECK-LABEL: @_Z21test_svwhilege_b8_s64ll(
156 // CPP-CHECK-NEXT: entry:
157 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilege.nxv16i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
158 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
160 svbool_t
test_svwhilege_b8_s64(int64_t op1
, int64_t op2
)
162 return SVE_ACLE_FUNC(svwhilege_b8
,_s64
,,)(op1
, op2
);
165 // CHECK-LABEL: @test_svwhilege_b16_s64(
166 // CHECK-NEXT: entry:
167 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilege.nxv8i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
168 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
169 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
171 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b16_s64ll(
172 // CPP-CHECK-NEXT: entry:
173 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilege.nxv8i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
174 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
175 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
177 svbool_t
test_svwhilege_b16_s64(int64_t op1
, int64_t op2
)
179 return SVE_ACLE_FUNC(svwhilege_b16
,_s64
,,)(op1
, op2
);
182 // CHECK-LABEL: @test_svwhilege_b32_s64(
183 // CHECK-NEXT: entry:
184 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilege.nxv4i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
185 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
186 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
188 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b32_s64ll(
189 // CPP-CHECK-NEXT: entry:
190 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilege.nxv4i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
191 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
192 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
194 svbool_t
test_svwhilege_b32_s64(int64_t op1
, int64_t op2
)
196 return SVE_ACLE_FUNC(svwhilege_b32
,_s64
,,)(op1
, op2
);
199 // CHECK-LABEL: @test_svwhilege_b64_s64(
200 // CHECK-NEXT: entry:
201 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilege.nxv2i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
202 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
203 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
205 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b64_s64ll(
206 // CPP-CHECK-NEXT: entry:
207 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilege.nxv2i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
208 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
209 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
211 svbool_t
test_svwhilege_b64_s64(int64_t op1
, int64_t op2
)
213 return SVE_ACLE_FUNC(svwhilege_b64
,_s64
,,)(op1
, op2
);
216 // CHECK-LABEL: @test_svwhilege_b8_u64(
217 // CHECK-NEXT: entry:
218 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilehs.nxv16i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
219 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
221 // CPP-CHECK-LABEL: @_Z21test_svwhilege_b8_u64mm(
222 // CPP-CHECK-NEXT: entry:
223 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.whilehs.nxv16i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
224 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP0]]
226 svbool_t
test_svwhilege_b8_u64(uint64_t op1
, uint64_t op2
)
228 return SVE_ACLE_FUNC(svwhilege_b8
,_u64
,,)(op1
, op2
);
231 // CHECK-LABEL: @test_svwhilege_b16_u64(
232 // CHECK-NEXT: entry:
233 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilehs.nxv8i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
234 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
235 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
237 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b16_u64mm(
238 // CPP-CHECK-NEXT: entry:
239 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 8 x i1> @llvm.aarch64.sve.whilehs.nxv8i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
240 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1> [[TMP0]])
241 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
243 svbool_t
test_svwhilege_b16_u64(uint64_t op1
, uint64_t op2
)
245 return SVE_ACLE_FUNC(svwhilege_b16
,_u64
,,)(op1
, op2
);
248 // CHECK-LABEL: @test_svwhilege_b32_u64(
249 // CHECK-NEXT: entry:
250 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilehs.nxv4i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
251 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
252 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
254 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b32_u64mm(
255 // CPP-CHECK-NEXT: entry:
256 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 4 x i1> @llvm.aarch64.sve.whilehs.nxv4i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
257 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1> [[TMP0]])
258 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
260 svbool_t
test_svwhilege_b32_u64(uint64_t op1
, uint64_t op2
)
262 return SVE_ACLE_FUNC(svwhilege_b32
,_u64
,,)(op1
, op2
);
265 // CHECK-LABEL: @test_svwhilege_b64_u64(
266 // CHECK-NEXT: entry:
267 // CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilehs.nxv2i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
268 // CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
269 // CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
271 // CPP-CHECK-LABEL: @_Z22test_svwhilege_b64_u64mm(
272 // CPP-CHECK-NEXT: entry:
273 // CPP-CHECK-NEXT: [[TMP0:%.*]] = tail call <vscale x 2 x i1> @llvm.aarch64.sve.whilehs.nxv2i1.i64(i64 [[OP1:%.*]], i64 [[OP2:%.*]])
274 // CPP-CHECK-NEXT: [[TMP1:%.*]] = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> [[TMP0]])
275 // CPP-CHECK-NEXT: ret <vscale x 16 x i1> [[TMP1]]
277 svbool_t
test_svwhilege_b64_u64(uint64_t op1
, uint64_t op2
)
279 return SVE_ACLE_FUNC(svwhilege_b64
,_u64
,,)(op1
, op2
);