zig/lib/include/avx512vnniintrin.h

116 lines
4.2 KiB
C
Raw Normal View History

2018-02-23 10:15:16 -08:00
/*===------------- avx512vnniintrin.h - VNNI intrinsics ------------------===
*
*
* Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
* See https://llvm.org/LICENSE.txt for license information.
* SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2018-02-23 10:15:16 -08:00
*
*===-----------------------------------------------------------------------===
*/
#ifndef __IMMINTRIN_H
#error "Never use <avx512vnniintrin.h> directly; include <immintrin.h> instead."
#endif
#ifndef __AVX512VNNIINTRIN_H
#define __AVX512VNNIINTRIN_H
/* Define the default attributes for the functions in this file. */
2018-08-04 23:20:05 -07:00
#define __DEFAULT_FN_ATTRS __attribute__((__always_inline__, __nodebug__, __target__("avx512vnni"), __min_vector_width__(512)))
2018-02-23 10:15:16 -08:00
2018-08-04 23:20:05 -07:00
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_dpbusd_epi32(__m512i __S, __m512i __A, __m512i __B)
{
return (__m512i)__builtin_ia32_vpdpbusd512((__v16si)__S, (__v16si)__A,
(__v16si)__B);
}
2018-02-23 10:15:16 -08:00
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_mask_dpbusd_epi32(__m512i __S, __mmask16 __U, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpbusd_epi32(__S, __A, __B),
(__v16si)__S);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_dpbusd_epi32(__mmask16 __U, __m512i __S, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpbusd_epi32(__S, __A, __B),
(__v16si)_mm512_setzero_si512());
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
2018-08-04 23:20:05 -07:00
_mm512_dpbusds_epi32(__m512i __S, __m512i __A, __m512i __B)
2018-02-23 10:15:16 -08:00
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_vpdpbusds512((__v16si)__S, (__v16si)__A,
(__v16si)__B);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_mask_dpbusds_epi32(__m512i __S, __mmask16 __U, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpbusds_epi32(__S, __A, __B),
(__v16si)__S);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_dpbusds_epi32(__mmask16 __U, __m512i __S, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpbusds_epi32(__S, __A, __B),
(__v16si)_mm512_setzero_si512());
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
2018-08-04 23:20:05 -07:00
_mm512_dpwssd_epi32(__m512i __S, __m512i __A, __m512i __B)
2018-02-23 10:15:16 -08:00
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_vpdpwssd512((__v16si)__S, (__v16si)__A,
(__v16si)__B);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_mask_dpwssd_epi32(__m512i __S, __mmask16 __U, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpwssd_epi32(__S, __A, __B),
(__v16si)__S);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_dpwssd_epi32(__mmask16 __U, __m512i __S, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpwssd_epi32(__S, __A, __B),
(__v16si)_mm512_setzero_si512());
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
2018-08-04 23:20:05 -07:00
_mm512_dpwssds_epi32(__m512i __S, __m512i __A, __m512i __B)
2018-02-23 10:15:16 -08:00
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_vpdpwssds512((__v16si)__S, (__v16si)__A,
(__v16si)__B);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_mask_dpwssds_epi32(__m512i __S, __mmask16 __U, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpwssds_epi32(__S, __A, __B),
(__v16si)__S);
2018-02-23 10:15:16 -08:00
}
static __inline__ __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_dpwssds_epi32(__mmask16 __U, __m512i __S, __m512i __A, __m512i __B)
{
2018-08-04 23:20:05 -07:00
return (__m512i)__builtin_ia32_selectd_512(__U,
(__v16si)_mm512_dpwssds_epi32(__S, __A, __B),
(__v16si)_mm512_setzero_si512());
2018-02-23 10:15:16 -08:00
}
#undef __DEFAULT_FN_ATTRS
#endif