1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-apple-darwin -mcpu=knl -mattr=+avx512bw -mattr=+avx512fp16 -mattr=+avx512vl | FileCheck %s
4 declare <4 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.128(<4 x float>, <4 x float>, <4 x float>, i8)
5 declare <4 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.128(<4 x float>, <4 x float>, <4 x float>, i8)
7 define <4 x float> @test_int_x86_avx512fp8_mask_cfmadd_ph_bst(<4 x float> %x0, <4 x float> %x1, i8 %x3){
8 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfmadd_ph_bst:
10 ; CHECK-NEXT: kmovd %edi, %k1
11 ; CHECK-NEXT: vfmaddcph {{\.?LCPI[0-9]+_[0-9]+}}(%rip){1to4}, %xmm0, %xmm1 {%k1}
12 ; CHECK-NEXT: vmovaps %xmm1, %xmm0
14 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.128(<4 x float> %x0, <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, <4 x float> %x1, i8 %x3)
18 define <4 x float> @test_int_x86_avx512fp8_mask_cfmadd_ph_bst2(<4 x float> %x0, <4 x float> %x1, i8 %x3){
19 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfmadd_ph_bst2:
21 ; CHECK-NEXT: kmovd %edi, %k1
22 ; CHECK-NEXT: vfmaddcph {{\.?LCPI[0-9]+_[0-9]+}}(%rip){1to4}, %xmm0, %xmm1 {%k1}
23 ; CHECK-NEXT: vmovaps %xmm1, %xmm0
25 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.128(<4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, <4 x float> %x0, <4 x float> %x1, i8 %x3)
29 define <4 x float> @test_int_x86_avx512fp8_mask_cfmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3){
30 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfmadd_ph_128:
32 ; CHECK-NEXT: kmovd %edi, %k1
33 ; CHECK-NEXT: vfmaddcph %xmm1, %xmm0, %xmm2 {%k1}
34 ; CHECK-NEXT: vmovaps %xmm2, %xmm0
36 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3)
40 define <4 x float> @test_int_x86_avx512fp8_maskz_cfmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3){
41 ; CHECK-LABEL: test_int_x86_avx512fp8_maskz_cfmadd_ph_128:
43 ; CHECK-NEXT: kmovd %edi, %k1
44 ; CHECK-NEXT: vfmaddcph %xmm1, %xmm0, %xmm2 {%k1} {z}
45 ; CHECK-NEXT: vmovaps %xmm2, %xmm0
47 %res = call <4 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3)
51 define <4 x float> @test_int_x86_avx512fp8_cfmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2){
52 ; CHECK-LABEL: test_int_x86_avx512fp8_cfmadd_ph_128:
54 ; CHECK-NEXT: vfmaddcph %xmm1, %xmm2, %xmm0
56 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.128(<4 x float> %x2, <4 x float> %x1, <4 x float> %x0, i8 -1)
61 declare <8 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.256(<8 x float>, <8 x float>, <8 x float>, i8)
62 declare <8 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.256(<8 x float>, <8 x float>, <8 x float>, i8)
64 define <8 x float> @test_int_x86_avx512fp16_mask_cfmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3){
65 ; CHECK-LABEL: test_int_x86_avx512fp16_mask_cfmadd_ph_256:
67 ; CHECK-NEXT: kmovd %edi, %k1
68 ; CHECK-NEXT: vfmaddcph %ymm1, %ymm0, %ymm2 {%k1}
69 ; CHECK-NEXT: vmovaps %ymm2, %ymm0
71 %res = call <8 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3)
75 define <8 x float> @test_int_x86_avx512fp16_maskz_cfmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3){
76 ; CHECK-LABEL: test_int_x86_avx512fp16_maskz_cfmadd_ph_256:
78 ; CHECK-NEXT: kmovd %edi, %k1
79 ; CHECK-NEXT: vfmaddcph %ymm1, %ymm0, %ymm2 {%k1} {z}
80 ; CHECK-NEXT: vmovaps %ymm2, %ymm0
82 %res = call <8 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3)
86 define <8 x float> @test_int_x86_avx512fp16_cfmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2){
87 ; CHECK-LABEL: test_int_x86_avx512fp16_cfmadd_ph_256:
89 ; CHECK-NEXT: vfmaddcph %ymm1, %ymm2, %ymm0
91 %res = call <8 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.256(<8 x float> %x2, <8 x float> %x1, <8 x float> %x0, i8 -1)
96 declare <16 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.512(<16 x float>, <16 x float>, <16 x float>, i16, i32)
97 declare <16 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.512(<16 x float>, <16 x float>, <16 x float>, i16, i32)
99 define <16 x float> @test_int_x86_avx512fp16_mask_cfmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
100 ; CHECK-LABEL: test_int_x86_avx512fp16_mask_cfmadd_ph_512:
102 ; CHECK-NEXT: kmovd %edi, %k1
103 ; CHECK-NEXT: vfmaddcph %zmm1, %zmm0, %zmm2 {%k1}
104 ; CHECK-NEXT: vmovaps %zmm2, %zmm0
106 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3, i32 4)
107 ret <16 x float> %res
110 define <16 x float> @test_int_x86_avx512fp16_maskz_cfmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
111 ; CHECK-LABEL: test_int_x86_avx512fp16_maskz_cfmadd_ph_512:
113 ; CHECK-NEXT: kmovd %edi, %k1
114 ; CHECK-NEXT: vfmaddcph %zmm1, %zmm0, %zmm2 {%k1} {z}
115 ; CHECK-NEXT: vmovaps %zmm2, %zmm0
117 %res = call <16 x float> @llvm.x86.avx512fp16.maskz.vfmadd.cph.512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3, i32 4)
118 ret <16 x float> %res
121 define <16 x float> @test_int_x86_avx512fp16_cfmadd_ph_512_rn(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
122 ; CHECK-LABEL: test_int_x86_avx512fp16_cfmadd_ph_512_rn:
124 ; CHECK-NEXT: vfmaddcph {rz-sae}, %zmm1, %zmm2, %zmm0
126 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.512(<16 x float> %x2, <16 x float> %x1, <16 x float> %x0, i16 -1, i32 11)
127 ret <16 x float> %res
130 define <16 x float> @test_int_x86_avx512fp16_cfmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
131 ; CHECK-LABEL: test_int_x86_avx512fp16_cfmadd_ph_512:
133 ; CHECK-NEXT: vfmaddcph %zmm1, %zmm2, %zmm0
135 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfmadd.cph.512(<16 x float> %x2, <16 x float> %x1, <16 x float> %x0, i16 -1, i32 4)
136 ret <16 x float> %res
139 declare <4 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.128(<4 x float>, <4 x float>, <4 x float>, i8)
140 declare <4 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.128(<4 x float>, <4 x float>, <4 x float>, i8)
142 define <4 x float> @test_int_x86_avx512fp8_mask_cfcmadd_ph_bst(<4 x float> %x0, <4 x float> %x1, i8 %x3){
143 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfcmadd_ph_bst:
145 ; CHECK-NEXT: kmovd %edi, %k1
146 ; CHECK-NEXT: vfcmaddcph {{\.?LCPI[0-9]+_[0-9]+}}(%rip){1to4}, %xmm0, %xmm1 {%k1}
147 ; CHECK-NEXT: vmovaps %xmm1, %xmm0
149 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.128(<4 x float> %x0, <4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, <4 x float> %x1, i8 %x3)
153 ; Check conjugate complex FMA is not commutable.
154 define <4 x float> @test_int_x86_avx512fp8_mask_cfcmadd_ph_bst2(<4 x float> %x0, <4 x float> %x1, i8 %x3){
155 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfcmadd_ph_bst2:
157 ; CHECK-NEXT: kmovd %edi, %k1
158 ; CHECK-NEXT: vbroadcastss {{.*#+}} xmm2 = [1.0E+0,1.0E+0,1.0E+0,1.0E+0]
159 ; CHECK-NEXT: vfcmaddcph %xmm0, %xmm2, %xmm1 {%k1}
160 ; CHECK-NEXT: vmovaps %xmm1, %xmm0
162 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.128(<4 x float> <float 1.000000e+00, float 1.000000e+00, float 1.000000e+00, float 1.000000e+00>, <4 x float> %x0, <4 x float> %x1, i8 %x3)
166 define <4 x float> @test_int_x86_avx512fp8_mask_cfcmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3){
167 ; CHECK-LABEL: test_int_x86_avx512fp8_mask_cfcmadd_ph_128:
169 ; CHECK-NEXT: kmovd %edi, %k1
170 ; CHECK-NEXT: vfcmaddcph %xmm1, %xmm0, %xmm2 {%k1}
171 ; CHECK-NEXT: vmovaps %xmm2, %xmm0
173 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3)
177 define <4 x float> @test_int_x86_avx512fp8_maskz_cfcmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3){
178 ; CHECK-LABEL: test_int_x86_avx512fp8_maskz_cfcmadd_ph_128:
180 ; CHECK-NEXT: kmovd %edi, %k1
181 ; CHECK-NEXT: vfcmaddcph %xmm1, %xmm0, %xmm2 {%k1} {z}
182 ; CHECK-NEXT: vmovaps %xmm2, %xmm0
184 %res = call <4 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2, i8 %x3)
188 define <4 x float> @test_int_x86_avx512fp8_cfcmadd_ph_128(<4 x float> %x0, <4 x float> %x1, <4 x float> %x2){
189 ; CHECK-LABEL: test_int_x86_avx512fp8_cfcmadd_ph_128:
191 ; CHECK-NEXT: vfcmaddcph %xmm1, %xmm2, %xmm0
193 %res = call <4 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.128(<4 x float> %x2, <4 x float> %x1, <4 x float> %x0, i8 -1)
198 declare <8 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.256(<8 x float>, <8 x float>, <8 x float>, i8)
199 declare <8 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.256(<8 x float>, <8 x float>, <8 x float>, i8)
201 define <8 x float> @test_int_x86_avx512fp16_mask_cfcmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3){
202 ; CHECK-LABEL: test_int_x86_avx512fp16_mask_cfcmadd_ph_256:
204 ; CHECK-NEXT: kmovd %edi, %k1
205 ; CHECK-NEXT: vfcmaddcph %ymm1, %ymm0, %ymm2 {%k1}
206 ; CHECK-NEXT: vmovaps %ymm2, %ymm0
208 %res = call <8 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3)
212 define <8 x float> @test_int_x86_avx512fp16_maskz_cfcmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3){
213 ; CHECK-LABEL: test_int_x86_avx512fp16_maskz_cfcmadd_ph_256:
215 ; CHECK-NEXT: kmovd %edi, %k1
216 ; CHECK-NEXT: vfcmaddcph %ymm1, %ymm0, %ymm2 {%k1} {z}
217 ; CHECK-NEXT: vmovaps %ymm2, %ymm0
219 %res = call <8 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2, i8 %x3)
223 define <8 x float> @test_int_x86_avx512fp16_cfcmadd_ph_256(<8 x float> %x0, <8 x float> %x1, <8 x float> %x2){
224 ; CHECK-LABEL: test_int_x86_avx512fp16_cfcmadd_ph_256:
226 ; CHECK-NEXT: vfcmaddcph %ymm1, %ymm2, %ymm0
228 %res = call <8 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.256(<8 x float> %x2, <8 x float> %x1, <8 x float> %x0, i8 -1)
233 declare <16 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.512(<16 x float>, <16 x float>, <16 x float>, i16, i32)
234 declare <16 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.512(<16 x float>, <16 x float>, <16 x float>, i16, i32)
236 define <16 x float> @test_int_x86_avx512fp16_mask_cfcmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
237 ; CHECK-LABEL: test_int_x86_avx512fp16_mask_cfcmadd_ph_512:
239 ; CHECK-NEXT: kmovd %edi, %k1
240 ; CHECK-NEXT: vfcmaddcph %zmm1, %zmm0, %zmm2 {%k1}
241 ; CHECK-NEXT: vmovaps %zmm2, %zmm0
243 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3, i32 4)
244 ret <16 x float> %res
247 define <16 x float> @test_int_x86_avx512fp16_maskz_cfcmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
248 ; CHECK-LABEL: test_int_x86_avx512fp16_maskz_cfcmadd_ph_512:
250 ; CHECK-NEXT: kmovd %edi, %k1
251 ; CHECK-NEXT: vfcmaddcph %zmm1, %zmm0, %zmm2 {%k1} {z}
252 ; CHECK-NEXT: vmovaps %zmm2, %zmm0
254 %res = call <16 x float> @llvm.x86.avx512fp16.maskz.vfcmadd.cph.512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3, i32 4)
255 ret <16 x float> %res
258 define <16 x float> @test_int_x86_avx512fp16_cfcmadd_ph_512_rn(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
259 ; CHECK-LABEL: test_int_x86_avx512fp16_cfcmadd_ph_512_rn:
261 ; CHECK-NEXT: vfcmaddcph {rz-sae}, %zmm1, %zmm2, %zmm0
263 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.512(<16 x float> %x2, <16 x float> %x1, <16 x float> %x0, i16 -1, i32 11)
264 ret <16 x float> %res
267 define <16 x float> @test_int_x86_avx512fp16_cfcmadd_ph_512(<16 x float> %x0, <16 x float> %x1, <16 x float> %x2, i16 %x3){
268 ; CHECK-LABEL: test_int_x86_avx512fp16_cfcmadd_ph_512:
270 ; CHECK-NEXT: vfcmaddcph %zmm1, %zmm2, %zmm0
272 %res = call <16 x float> @llvm.x86.avx512fp16.mask.vfcmadd.cph.512(<16 x float> %x2, <16 x float> %x1, <16 x float> %x0, i16 -1, i32 4)
273 ret <16 x float> %res