Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / X86 / combine-pmadd.ll
blobe8a61eeac6a114eab9b59b6c20aeb0e0976d84aa
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+sse4.1 | FileCheck %s --check-prefix=SSE
3 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+avx | FileCheck %s --check-prefixes=AVX
4 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+avx2 | FileCheck %s --check-prefixes=AVX
6 declare <4 x i32> @llvm.x86.sse2.pmadd.wd(<8 x i16>, <8 x i16>) nounwind readnone
7 declare <8 x i16> @llvm.x86.ssse3.pmadd.ub.sw.128(<16 x i8>, <16 x i8>) nounwind readnone
9 define <4 x i32> @combine_pmaddwd_zero(<8 x i16> %a0, <8 x i16> %a1) {
10 ; SSE-LABEL: combine_pmaddwd_zero:
11 ; SSE:       # %bb.0:
12 ; SSE-NEXT:    xorps %xmm0, %xmm0
13 ; SSE-NEXT:    retq
15 ; AVX-LABEL: combine_pmaddwd_zero:
16 ; AVX:       # %bb.0:
17 ; AVX-NEXT:    vxorps %xmm0, %xmm0, %xmm0
18 ; AVX-NEXT:    retq
19   %1 = call <4 x i32> @llvm.x86.sse2.pmadd.wd(<8 x i16> %a0, <8 x i16> zeroinitializer)
20   ret <4 x i32> %1
23 define <4 x i32> @combine_pmaddwd_zero_commute(<8 x i16> %a0, <8 x i16> %a1) {
24 ; SSE-LABEL: combine_pmaddwd_zero_commute:
25 ; SSE:       # %bb.0:
26 ; SSE-NEXT:    xorps %xmm0, %xmm0
27 ; SSE-NEXT:    retq
29 ; AVX-LABEL: combine_pmaddwd_zero_commute:
30 ; AVX:       # %bb.0:
31 ; AVX-NEXT:    vxorps %xmm0, %xmm0, %xmm0
32 ; AVX-NEXT:    retq
33   %1 = call <4 x i32> @llvm.x86.sse2.pmadd.wd(<8 x i16> zeroinitializer, <8 x i16> %a0)
34   ret <4 x i32> %1
37 define <8 x i16> @combine_pmaddubsw_zero(<16 x i8> %a0, <16 x i8> %a1) {
38 ; SSE-LABEL: combine_pmaddubsw_zero:
39 ; SSE:       # %bb.0:
40 ; SSE-NEXT:    xorps %xmm0, %xmm0
41 ; SSE-NEXT:    retq
43 ; AVX-LABEL: combine_pmaddubsw_zero:
44 ; AVX:       # %bb.0:
45 ; AVX-NEXT:    vxorps %xmm0, %xmm0, %xmm0
46 ; AVX-NEXT:    retq
47   %1 = call <8 x i16> @llvm.x86.ssse3.pmadd.ub.sw.128(<16 x i8> %a0, <16 x i8> zeroinitializer)
48   ret <8 x i16> %1
51 define <8 x i16> @combine_pmaddubsw_zero_commute(<16 x i8> %a0, <16 x i8> %a1) {
52 ; SSE-LABEL: combine_pmaddubsw_zero_commute:
53 ; SSE:       # %bb.0:
54 ; SSE-NEXT:    xorps %xmm0, %xmm0
55 ; SSE-NEXT:    retq
57 ; AVX-LABEL: combine_pmaddubsw_zero_commute:
58 ; AVX:       # %bb.0:
59 ; AVX-NEXT:    vxorps %xmm0, %xmm0, %xmm0
60 ; AVX-NEXT:    retq
61   %1 = call <8 x i16> @llvm.x86.ssse3.pmadd.ub.sw.128(<16 x i8> zeroinitializer, <16 x i8> %a0)
62   ret <8 x i16> %1