1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=x86_64-unknown-unknown -mattr=+avx512bw | FileCheck %s
4 define <64 x i8> @vpaddb512_test(<64 x i8> %i, <64 x i8> %j) nounwind readnone {
5 ; CHECK-LABEL: vpaddb512_test:
7 ; CHECK-NEXT: vpaddb %zmm1, %zmm0, %zmm0
9 %x = add <64 x i8> %i, %j
13 define <64 x i8> @vpaddb512_fold_test(<64 x i8> %i, ptr %j) nounwind {
14 ; CHECK-LABEL: vpaddb512_fold_test:
16 ; CHECK-NEXT: vpaddb (%rdi), %zmm0, %zmm0
18 %tmp = load <64 x i8>, ptr %j, align 4
19 %x = add <64 x i8> %i, %tmp
23 define <32 x i16> @vpaddw512_test(<32 x i16> %i, <32 x i16> %j) nounwind readnone {
24 ; CHECK-LABEL: vpaddw512_test:
26 ; CHECK-NEXT: vpaddw %zmm1, %zmm0, %zmm0
28 %x = add <32 x i16> %i, %j
32 define <32 x i16> @vpaddw512_fold_test(<32 x i16> %i, ptr %j) nounwind {
33 ; CHECK-LABEL: vpaddw512_fold_test:
35 ; CHECK-NEXT: vpaddw (%rdi), %zmm0, %zmm0
37 %tmp = load <32 x i16>, ptr %j, align 4
38 %x = add <32 x i16> %i, %tmp
42 define <32 x i16> @vpaddw512_mask_test(<32 x i16> %i, <32 x i16> %j, <32 x i16> %mask1) nounwind readnone {
43 ; CHECK-LABEL: vpaddw512_mask_test:
45 ; CHECK-NEXT: vptestmw %zmm2, %zmm2, %k1
46 ; CHECK-NEXT: vpaddw %zmm1, %zmm0, %zmm0 {%k1}
48 %mask = icmp ne <32 x i16> %mask1, zeroinitializer
49 %x = add <32 x i16> %i, %j
50 %r = select <32 x i1> %mask, <32 x i16> %x, <32 x i16> %i
54 define <32 x i16> @vpaddw512_maskz_test(<32 x i16> %i, <32 x i16> %j, <32 x i16> %mask1) nounwind readnone {
55 ; CHECK-LABEL: vpaddw512_maskz_test:
57 ; CHECK-NEXT: vptestmw %zmm2, %zmm2, %k1
58 ; CHECK-NEXT: vpaddw %zmm1, %zmm0, %zmm0 {%k1} {z}
60 %mask = icmp ne <32 x i16> %mask1, zeroinitializer
61 %x = add <32 x i16> %i, %j
62 %r = select <32 x i1> %mask, <32 x i16> %x, <32 x i16> zeroinitializer
66 define <32 x i16> @vpaddw512_mask_fold_test(<32 x i16> %i, ptr %j.ptr, <32 x i16> %mask1) nounwind readnone {
67 ; CHECK-LABEL: vpaddw512_mask_fold_test:
69 ; CHECK-NEXT: vptestmw %zmm1, %zmm1, %k1
70 ; CHECK-NEXT: vpaddw (%rdi), %zmm0, %zmm0 {%k1}
72 %mask = icmp ne <32 x i16> %mask1, zeroinitializer
73 %j = load <32 x i16>, ptr %j.ptr
74 %x = add <32 x i16> %i, %j
75 %r = select <32 x i1> %mask, <32 x i16> %x, <32 x i16> %i
79 define <32 x i16> @vpaddw512_maskz_fold_test(<32 x i16> %i, ptr %j.ptr, <32 x i16> %mask1) nounwind readnone {
80 ; CHECK-LABEL: vpaddw512_maskz_fold_test:
82 ; CHECK-NEXT: vptestmw %zmm1, %zmm1, %k1
83 ; CHECK-NEXT: vpaddw (%rdi), %zmm0, %zmm0 {%k1} {z}
85 %mask = icmp ne <32 x i16> %mask1, zeroinitializer
86 %j = load <32 x i16>, ptr %j.ptr
87 %x = add <32 x i16> %i, %j
88 %r = select <32 x i1> %mask, <32 x i16> %x, <32 x i16> zeroinitializer
92 define <64 x i8> @vpsubb512_test(<64 x i8> %i, <64 x i8> %j) nounwind readnone {
93 ; CHECK-LABEL: vpsubb512_test:
95 ; CHECK-NEXT: vpsubb %zmm1, %zmm0, %zmm0
97 %x = sub <64 x i8> %i, %j
101 define <32 x i16> @vpsubw512_test(<32 x i16> %i, <32 x i16> %j) nounwind readnone {
102 ; CHECK-LABEL: vpsubw512_test:
104 ; CHECK-NEXT: vpsubw %zmm1, %zmm0, %zmm0
106 %x = sub <32 x i16> %i, %j
110 define <32 x i16> @vpmullw512_test(<32 x i16> %i, <32 x i16> %j) {
111 ; CHECK-LABEL: vpmullw512_test:
113 ; CHECK-NEXT: vpmullw %zmm1, %zmm0, %zmm0
115 %x = mul <32 x i16> %i, %j