Index: include/clang/Basic/BuiltinsX86.def =================================================================== --- include/clang/Basic/BuiltinsX86.def +++ include/clang/Basic/BuiltinsX86.def @@ -1418,4 +1418,37 @@ BUILTIN(__builtin_ia32_punpcklbw512_mask, "V64cV64cV64cV64cULLi", "") BUILTIN(__builtin_ia32_punpcklwd512_mask, "V32sV32sV32sV32sUi", "") +BUILTIN(__builtin_ia32_cvtpd2qq128_mask, "V2LLiV2dV2LLiUc", "") +BUILTIN(__builtin_ia32_cvtpd2qq256_mask, "V4LLiV4dV4LLiUc", "") +BUILTIN(__builtin_ia32_cvtpd2uqq128_mask, "V2LLiV2dV2LLiUc", "") +BUILTIN(__builtin_ia32_cvtpd2uqq256_mask, "V4LLiV4dV4LLiUc", "") +BUILTIN(__builtin_ia32_cvtps2qq128_mask, "V2LLiV4fV2LLiUc", "") +BUILTIN(__builtin_ia32_cvtps2qq256_mask, "V4LLiV4fV4LLiUc", "") +BUILTIN(__builtin_ia32_cvtps2uqq128_mask, "V2LLiV4fV2LLiUc", "") +BUILTIN(__builtin_ia32_cvtps2uqq256_mask, "V4LLiV4fV4LLiUc", "") +BUILTIN(__builtin_ia32_cvtqq2pd128_mask, "V2dV2LLiV2dUc", "") +BUILTIN(__builtin_ia32_cvtqq2pd256_mask, "V4dV4LLiV4dUc", "") +BUILTIN(__builtin_ia32_cvtqq2ps128_mask, "V4fV2LLiV4fUc", "") +BUILTIN(__builtin_ia32_cvtqq2ps256_mask, "V4fV4LLiV4fUc", "") +BUILTIN(__builtin_ia32_cvttpd2qq128_mask, "V2LLiV2dV2LLiUc", "") +BUILTIN(__builtin_ia32_cvttpd2qq256_mask, "V4LLiV4dV4LLiUc", "") +BUILTIN(__builtin_ia32_cvttpd2uqq128_mask, "V2LLiV2dV2LLiUc", "") +BUILTIN(__builtin_ia32_cvttpd2uqq256_mask, "V4LLiV4dV4LLiUc", "") +BUILTIN(__builtin_ia32_cvttps2qq128_mask, "V2LLiV4fV2LLiUc", "") +BUILTIN(__builtin_ia32_cvttps2qq256_mask, "V4LLiV4fV4LLiUc", "") +BUILTIN(__builtin_ia32_cvttps2uqq128_mask, "V2LLiV4fV2LLiUc", "") +BUILTIN(__builtin_ia32_cvttps2uqq256_mask, "V4LLiV4fV4LLiUc", "") +BUILTIN(__builtin_ia32_cvtuqq2pd128_mask, "V2dV2LLiV2dUc", "") +BUILTIN(__builtin_ia32_cvtuqq2pd256_mask, "V4dV4LLiV4dUc", "") +BUILTIN(__builtin_ia32_cvtuqq2ps128_mask, "V4fV2LLiV4fUc", "") +BUILTIN(__builtin_ia32_cvtuqq2ps256_mask, "V4fV4LLiV4fUc", "") +BUILTIN(__builtin_ia32_rangepd128_mask, "V2dV2dV2dIiV2dUc", "") +BUILTIN(__builtin_ia32_rangepd256_mask, "V4dV4dV4dIiV4dUc", "") +BUILTIN(__builtin_ia32_rangeps128_mask, "V4fV4fV4fIiV4fUc", "") +BUILTIN(__builtin_ia32_rangeps256_mask, "V8fV8fV8fIiV8fUc", "") +BUILTIN(__builtin_ia32_reducepd128_mask, "V2dV2dIiV2dUc", "") +BUILTIN(__builtin_ia32_reducepd256_mask, "V4dV4dIiV4dUc", "") +BUILTIN(__builtin_ia32_reduceps128_mask, "V4fV4fIiV4fUc", "") +BUILTIN(__builtin_ia32_reduceps256_mask, "V8fV8fIiV8fUc", "") + #undef BUILTIN Index: lib/Headers/avx512vldqintrin.h =================================================================== --- lib/Headers/avx512vldqintrin.h +++ lib/Headers/avx512vldqintrin.h @@ -348,6 +348,606 @@ (__mmask8) __U); } +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvtpd_epi64 (__m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2qq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvtpd_epi64 (__m128i __W, __mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2qq128_mask ((__v2df) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvtpd_epi64 (__mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2qq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvtpd_epi64 (__m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2qq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvtpd_epi64 (__m256i __W, __mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2qq256_mask ((__v4df) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvtpd_epi64 (__mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2qq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvtpd_epu64 (__m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2uqq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvtpd_epu64 (__m128i __W, __mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2uqq128_mask ((__v2df) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvtpd_epu64 (__mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvtpd2uqq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvtpd_epu64 (__m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2uqq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvtpd_epu64 (__m256i __W, __mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2uqq256_mask ((__v4df) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvtpd_epu64 (__mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvtpd2uqq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvtps_epi64 (__m128 __A) { + return (__m128i) __builtin_ia32_cvtps2qq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvtps_epi64 (__m128i __W, __mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvtps2qq128_mask ((__v4sf) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvtps_epi64 (__mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvtps2qq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvtps_epi64 (__m128 __A) { + return (__m256i) __builtin_ia32_cvtps2qq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvtps_epi64 (__m256i __W, __mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvtps2qq256_mask ((__v4sf) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvtps_epi64 (__mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvtps2qq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvtps_epu64 (__m128 __A) { + return (__m128i) __builtin_ia32_cvtps2uqq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvtps_epu64 (__m128i __W, __mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvtps2uqq128_mask ((__v4sf) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvtps_epu64 (__mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvtps2uqq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvtps_epu64 (__m128 __A) { + return (__m256i) __builtin_ia32_cvtps2uqq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvtps_epu64 (__m256i __W, __mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvtps2uqq256_mask ((__v4sf) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvtps_epu64 (__mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvtps2uqq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_cvtepi64_pd (__m128i __A) { + return (__m128d) __builtin_ia32_cvtqq2pd128_mask ((__v2di) __A, + (__v2df) _mm_setzero_pd(), + (__mmask8) -1); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_mask_cvtepi64_pd (__m128d __W, __mmask8 __U, __m128i __A) { + return (__m128d) __builtin_ia32_cvtqq2pd128_mask ((__v2di) __A, + (__v2df) __W, + (__mmask8) __U); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_maskz_cvtepi64_pd (__mmask8 __U, __m128i __A) { + return (__m128d) __builtin_ia32_cvtqq2pd128_mask ((__v2di) __A, + (__v2df) _mm_setzero_pd(), + (__mmask8) __U); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_cvtepi64_pd (__m256i __A) { + return (__m256d) __builtin_ia32_cvtqq2pd256_mask ((__v4di) __A, + (__v4df) _mm256_setzero_pd(), + (__mmask8) -1); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_mask_cvtepi64_pd (__m256d __W, __mmask8 __U, __m256i __A) { + return (__m256d) __builtin_ia32_cvtqq2pd256_mask ((__v4di) __A, + (__v4df) __W, + (__mmask8) __U); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_maskz_cvtepi64_pd (__mmask8 __U, __m256i __A) { + return (__m256d) __builtin_ia32_cvtqq2pd256_mask ((__v4di) __A, + (__v4df) _mm256_setzero_pd(), + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_cvtepi64_ps (__m128i __A) { + return (__m128) __builtin_ia32_cvtqq2ps128_mask ((__v2di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) -1); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_mask_cvtepi64_ps (__m128 __W, __mmask8 __U, __m128i __A) { + return (__m128) __builtin_ia32_cvtqq2ps128_mask ((__v2di) __A, + (__v4sf) __W, + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_maskz_cvtepi64_ps (__mmask8 __U, __m128i __A) { + return (__m128) __builtin_ia32_cvtqq2ps128_mask ((__v2di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_cvtepi64_ps (__m256i __A) { + return (__m128) __builtin_ia32_cvtqq2ps256_mask ((__v4di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) -1); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_mask_cvtepi64_ps (__m128 __W, __mmask8 __U, __m256i __A) { + return (__m128) __builtin_ia32_cvtqq2ps256_mask ((__v4di) __A, + (__v4sf) __W, + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_maskz_cvtepi64_ps (__mmask8 __U, __m256i __A) { + return (__m128) __builtin_ia32_cvtqq2ps256_mask ((__v4di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvttpd_epi64 (__m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2qq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvttpd_epi64 (__m128i __W, __mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2qq128_mask ((__v2df) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvttpd_epi64 (__mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2qq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvttpd_epi64 (__m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2qq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvttpd_epi64 (__m256i __W, __mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2qq256_mask ((__v4df) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvttpd_epi64 (__mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2qq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvttpd_epu64 (__m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2uqq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvttpd_epu64 (__m128i __W, __mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2uqq128_mask ((__v2df) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvttpd_epu64 (__mmask8 __U, __m128d __A) { + return (__m128i) __builtin_ia32_cvttpd2uqq128_mask ((__v2df) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvttpd_epu64 (__m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2uqq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvttpd_epu64 (__m256i __W, __mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2uqq256_mask ((__v4df) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvttpd_epu64 (__mmask8 __U, __m256d __A) { + return (__m256i) __builtin_ia32_cvttpd2uqq256_mask ((__v4df) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvttps_epi64 (__m128 __A) { + return (__m128i) __builtin_ia32_cvttps2qq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvttps_epi64 (__m128i __W, __mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvttps2qq128_mask ((__v4sf) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvttps_epi64 (__mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvttps2qq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvttps_epi64 (__m128 __A) { + return (__m256i) __builtin_ia32_cvttps2qq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvttps_epi64 (__m256i __W, __mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvttps2qq256_mask ((__v4sf) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvttps_epi64 (__mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvttps2qq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_cvttps_epu64 (__m128 __A) { + return (__m128i) __builtin_ia32_cvttps2uqq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) -1); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_mask_cvttps_epu64 (__m128i __W, __mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvttps2uqq128_mask ((__v4sf) __A, + (__v2di) __W, + (__mmask8) __U); +} + +static __inline__ __m128i __DEFAULT_FN_ATTRS +_mm_maskz_cvttps_epu64 (__mmask8 __U, __m128 __A) { + return (__m128i) __builtin_ia32_cvttps2uqq128_mask ((__v4sf) __A, + (__v2di) _mm_setzero_si128(), + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_cvttps_epu64 (__m128 __A) { + return (__m256i) __builtin_ia32_cvttps2uqq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) -1); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_mask_cvttps_epu64 (__m256i __W, __mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvttps2uqq256_mask ((__v4sf) __A, + (__v4di) __W, + (__mmask8) __U); +} + +static __inline__ __m256i __DEFAULT_FN_ATTRS +_mm256_maskz_cvttps_epu64 (__mmask8 __U, __m128 __A) { + return (__m256i) __builtin_ia32_cvttps2uqq256_mask ((__v4sf) __A, + (__v4di) _mm256_setzero_si256(), + (__mmask8) __U); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_cvtepu64_pd (__m128i __A) { + return (__m128d) __builtin_ia32_cvtuqq2pd128_mask ((__v2di) __A, + (__v2df) _mm_setzero_pd(), + (__mmask8) -1); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_mask_cvtepu64_pd (__m128d __W, __mmask8 __U, __m128i __A) { + return (__m128d) __builtin_ia32_cvtuqq2pd128_mask ((__v2di) __A, + (__v2df) __W, + (__mmask8) __U); +} + +static __inline__ __m128d __DEFAULT_FN_ATTRS +_mm_maskz_cvtepu64_pd (__mmask8 __U, __m128i __A) { + return (__m128d) __builtin_ia32_cvtuqq2pd128_mask ((__v2di) __A, + (__v2df) _mm_setzero_pd(), + (__mmask8) __U); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_cvtepu64_pd (__m256i __A) { + return (__m256d) __builtin_ia32_cvtuqq2pd256_mask ((__v4di) __A, + (__v4df) _mm256_setzero_pd(), + (__mmask8) -1); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_mask_cvtepu64_pd (__m256d __W, __mmask8 __U, __m256i __A) { + return (__m256d) __builtin_ia32_cvtuqq2pd256_mask ((__v4di) __A, + (__v4df) __W, + (__mmask8) __U); +} + +static __inline__ __m256d __DEFAULT_FN_ATTRS +_mm256_maskz_cvtepu64_pd (__mmask8 __U, __m256i __A) { + return (__m256d) __builtin_ia32_cvtuqq2pd256_mask ((__v4di) __A, + (__v4df) _mm256_setzero_pd(), + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_cvtepu64_ps (__m128i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps128_mask ((__v2di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) -1); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_mask_cvtepu64_ps (__m128 __W, __mmask8 __U, __m128i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps128_mask ((__v2di) __A, + (__v4sf) __W, + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm_maskz_cvtepu64_ps (__mmask8 __U, __m128i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps128_mask ((__v2di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_cvtepu64_ps (__m256i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps256_mask ((__v4di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) -1); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_mask_cvtepu64_ps (__m128 __W, __mmask8 __U, __m256i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps256_mask ((__v4di) __A, + (__v4sf) __W, + (__mmask8) __U); +} + +static __inline__ __m128 __DEFAULT_FN_ATTRS +_mm256_maskz_cvtepu64_ps (__mmask8 __U, __m256i __A) { + return (__m128) __builtin_ia32_cvtuqq2ps256_mask ((__v4di) __A, + (__v4sf) _mm_setzero_ps(), + (__mmask8) __U); +} + +#define _mm_range_pd(__A, __B, __C) __extension__ ({ \ + (__m128d) __builtin_ia32_rangepd128_mask ((__v2df) __A, (__v2df) __B, __C, \ + (__v2df) _mm_setzero_pd(), (__mmask8) -1); }) + +#define _mm_mask_range_pd(__W, __U, __A, __B, __C) __extension__ ({ \ + (__m128d) __builtin_ia32_rangepd128_mask ((__v2df) __A, (__v2df) __B, __C, \ + (__v2df) __W, (__mmask8) __U); }) + +#define _mm_maskz_range_pd(__U, __A, __B, __C) __extension__ ({ \ + (__m128d) __builtin_ia32_rangepd128_mask ((__v2df) __A, (__v2df) __B, __C, \ + (__v2df) _mm_setzero_pd(), (__mmask8) __U); }) + +#define _mm256_range_pd(__A, __B, __C) __extension__ ({ \ + (__m256d) __builtin_ia32_rangepd256_mask ((__v4df) __A, (__v4df) __B, __C, \ + (__v4df) _mm256_setzero_pd(), (__mmask8) -1); }) + +#define _mm256_mask_range_pd(__W, __U, __A, __B, __C) __extension__ ({ \ + (__m256d) __builtin_ia32_rangepd256_mask ((__v4df) __A, (__v4df) __B, __C, \ + (__v4df) __W, (__mmask8) __U); }) + +#define _mm256_maskz_range_pd(__U, __A, __B, __C) __extension__ ({ \ + (__m256d) __builtin_ia32_rangepd256_mask ((__v4df) __A, (__v4df) __B, __C, \ + (__v4df) _mm256_setzero_pd(), (__mmask8) __U); }) + +#define _mm_range_ps(__A, __B, __C) __extension__ ({ \ + (__m128) __builtin_ia32_rangeps128_mask ((__v4sf) __A, (__v4sf) __B, __C, \ + (__v4sf) _mm_setzero_ps(), (__mmask8) -1); }) + +#define _mm_mask_range_ps(__W, __U, __A, __B, __C) __extension__ ({ \ + (__m128) __builtin_ia32_rangeps128_mask ((__v4sf) __A, (__v4sf) __B, __C, \ + (__v4sf) __W, (__mmask8) __U); }) + +#define _mm_maskz_range_ps(__U, __A, __B, __C) __extension__ ({ \ + (__m128) __builtin_ia32_rangeps128_mask ((__v4sf) __A, (__v4sf) __B, __C, \ + (__v4sf) _mm_setzero_ps(), (__mmask8) __U); }) + +#define _mm256_range_ps(__A, __B, __C) __extension__ ({ \ + (__m256) __builtin_ia32_rangeps256_mask ((__v8sf) __A, (__v8sf) __B, __C, \ + (__v8sf) _mm256_setzero_ps(), (__mmask8) -1); }) + +#define _mm256_mask_range_ps(__W, __U, __A, __B, __C) __extension__ ({ \ + (__m256) __builtin_ia32_rangeps256_mask ((__v8sf) __A, (__v8sf) __B, __C, \ + (__v8sf) __W, (__mmask8) __U); }) + +#define _mm256_maskz_range_ps(__U, __A, __B, __C) __extension__ ({ \ + (__m256) __builtin_ia32_rangeps256_mask ((__v8sf) __A, (__v8sf) __B, __C, \ + (__v8sf) _mm256_setzero_ps(), (__mmask8) __U); }) + +#define _mm_reduce_pd(__A, __B) __extension__ ({ \ + (__m128d) __builtin_ia32_reducepd128_mask ((__v2df) __A, __B, \ + (__v2df) _mm_setzero_pd(), (__mmask8) -1); }) + +#define _mm_mask_reduce_pd(__W, __U, __A, __B) __extension__ ({ \ + (__m128d) __builtin_ia32_reducepd128_mask ((__v2df) __A, __B, \ + (__v2df) __W, (__mmask8) __U); }) + +#define _mm_maskz_reduce_pd(__U, __A, __B) __extension__ ({ \ + (__m128d) __builtin_ia32_reducepd128_mask ((__v2df) __A, __B, \ + (__v2df) _mm_setzero_pd(), (__mmask8) __U); }) + +#define _mm256_reduce_pd(__A, __B) __extension__ ({ \ + (__m256d) __builtin_ia32_reducepd256_mask ((__v4df) __A, __B, \ + (__v4df) _mm256_setzero_pd(), (__mmask8) -1); }) + +#define _mm256_mask_reduce_pd(__W, __U, __A, __B) __extension__ ({ \ + (__m256d) __builtin_ia32_reducepd256_mask ((__v4df) __A, __B, \ + (__v4df) __W, (__mmask8) __U); }) + +#define _mm256_maskz_reduce_pd(__U, __A, __B) __extension__ ({ \ + (__m256d) __builtin_ia32_reducepd256_mask ((__v4df) __A, __B, \ + (__v4df) _mm256_setzero_pd(), (__mmask8) __U); }) + +#define _mm_reduce_ps(__A, __B) __extension__ ({ \ + (__m128) __builtin_ia32_reduceps128_mask ((__v4sf) __A, __B, \ + (__v4sf) _mm_setzero_ps(), (__mmask8) -1); }) + +#define _mm_mask_reduce_ps(__W, __U, __A, __B) __extension__ ({ \ + (__m128) __builtin_ia32_reduceps128_mask ((__v4sf) __A, __B, \ + (__v4sf) __W, (__mmask8) __U); }) + +#define _mm_maskz_reduce_ps(__U, __A, __B) __extension__ ({ \ + (__m128) __builtin_ia32_reduceps128_mask ((__v4sf) __A, __B, \ + (__v4sf) _mm_setzero_ps(), (__mmask8) __U); }) + +#define _mm256_reduce_ps(__A, __B) __extension__ ({ \ + (__m256) __builtin_ia32_reduceps256_mask ((__v8sf) __A, __B, \ + (__v8sf) _mm256_setzero_ps(), (__mmask8) -1); }) + +#define _mm256_mask_reduce_ps(__W, __U, __A, __B) __extension__ ({ \ + (__m256) __builtin_ia32_reduceps256_mask ((__v8sf) __A, __B, \ + (__v8sf) __W, (__mmask8) __U); }) + +#define _mm256_maskz_reduce_ps(__U, __A, __B) __extension__ ({ \ + (__m256) __builtin_ia32_reduceps256_mask ((__v8sf) __A, __B, \ + (__v8sf) _mm256_setzero_ps(), (__mmask8) __U); }) + #undef __DEFAULT_FN_ATTRS #endif Index: test/CodeGen/avx512vldq-builtins.c =================================================================== --- test/CodeGen/avx512vldq-builtins.c +++ test/CodeGen/avx512vldq-builtins.c @@ -229,3 +229,579 @@ // CHECK: @llvm.x86.avx512.mask.or.ps.128 return (__m128) _mm_maskz_or_ps(__U, __A, __B); } + +__m128i test_mm_cvtpd_epi64(__m128d __A) { + // CHECK-LABEL: @test_mm_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.128 + return _mm_cvtpd_epi64(__A); +} + +__m128i test_mm_mask_cvtpd_epi64(__m128i __W, __mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_mask_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.128 + return _mm_mask_cvtpd_epi64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvtpd_epi64(__mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_maskz_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.128 + return _mm_maskz_cvtpd_epi64(__U, __A); +} + +__m256i test_mm256_cvtpd_epi64(__m256d __A) { + // CHECK-LABEL: @test_mm256_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.256 + return _mm256_cvtpd_epi64(__A); +} + +__m256i test_mm256_mask_cvtpd_epi64(__m256i __W, __mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_mask_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.256 + return _mm256_mask_cvtpd_epi64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvtpd_epi64(__mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2qq.256 + return _mm256_maskz_cvtpd_epi64(__U, __A); +} + +__m128i test_mm_cvtpd_epu64(__m128d __A) { + // CHECK-LABEL: @test_mm_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.128 + return _mm_cvtpd_epu64(__A); +} + +__m128i test_mm_mask_cvtpd_epu64(__m128i __W, __mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_mask_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.128 + return _mm_mask_cvtpd_epu64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvtpd_epu64(__mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_maskz_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.128 + return _mm_maskz_cvtpd_epu64(__U, __A); +} + +__m256i test_mm256_cvtpd_epu64(__m256d __A) { + // CHECK-LABEL: @test_mm256_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.256 + return _mm256_cvtpd_epu64(__A); +} + +__m256i test_mm256_mask_cvtpd_epu64(__m256i __W, __mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_mask_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.256 + return _mm256_mask_cvtpd_epu64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvtpd_epu64(__mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtpd2uqq.256 + return _mm256_maskz_cvtpd_epu64(__U, __A); +} + +__m128i test_mm_cvtps_epi64(__m128 __A) { + // CHECK-LABEL: @test_mm_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.128 + return _mm_cvtps_epi64(__A); +} + +__m128i test_mm_mask_cvtps_epi64(__m128i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_mask_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.128 + return _mm_mask_cvtps_epi64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvtps_epi64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_maskz_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.128 + return _mm_maskz_cvtps_epi64(__U, __A); +} + +__m256i test_mm256_cvtps_epi64(__m128 __A) { + // CHECK-LABEL: @test_mm256_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.256 + return _mm256_cvtps_epi64(__A); +} + +__m256i test_mm256_mask_cvtps_epi64(__m256i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_mask_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.256 + return _mm256_mask_cvtps_epi64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvtps_epi64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvtps2qq.256 + return _mm256_maskz_cvtps_epi64(__U, __A); +} + +__m128i test_mm_cvtps_epu64(__m128 __A) { + // CHECK-LABEL: @test_mm_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.128 + return _mm_cvtps_epu64(__A); +} + +__m128i test_mm_mask_cvtps_epu64(__m128i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_mask_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.128 + return _mm_mask_cvtps_epu64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvtps_epu64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_maskz_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.128 + return _mm_maskz_cvtps_epu64(__U, __A); +} + +__m256i test_mm256_cvtps_epu64(__m128 __A) { + // CHECK-LABEL: @test_mm256_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.256 + return _mm256_cvtps_epu64(__A); +} + +__m256i test_mm256_mask_cvtps_epu64(__m256i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_mask_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.256 + return _mm256_mask_cvtps_epu64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvtps_epu64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvtps2uqq.256 + return _mm256_maskz_cvtps_epu64(__U, __A); +} + +__m128d test_mm_cvtepi64_pd(__m128i __A) { + // CHECK-LABEL: @test_mm_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.128 + return _mm_cvtepi64_pd(__A); +} + +__m128d test_mm_mask_cvtepi64_pd(__m128d __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_mask_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.128 + return _mm_mask_cvtepi64_pd(__W, __U, __A); +} + +__m128d test_mm_maskz_cvtepi64_pd(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_maskz_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.128 + return _mm_maskz_cvtepi64_pd(__U, __A); +} + +__m256d test_mm256_cvtepi64_pd(__m256i __A) { + // CHECK-LABEL: @test_mm256_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.256 + return _mm256_cvtepi64_pd(__A); +} + +__m256d test_mm256_mask_cvtepi64_pd(__m256d __W, __mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_mask_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.256 + return _mm256_mask_cvtepi64_pd(__W, __U, __A); +} + +__m256d test_mm256_maskz_cvtepi64_pd(__mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtepi64_pd + // CHECK: @llvm.x86.avx512.mask.cvtqq2pd.256 + return _mm256_maskz_cvtepi64_pd(__U, __A); +} + +__m128 test_mm_cvtepi64_ps(__m128i __A) { + // CHECK-LABEL: @test_mm_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.128 + return _mm_cvtepi64_ps(__A); +} + +__m128 test_mm_mask_cvtepi64_ps(__m128 __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_mask_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.128 + return _mm_mask_cvtepi64_ps(__W, __U, __A); +} + +__m128 test_mm_maskz_cvtepi64_ps(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_maskz_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.128 + return _mm_maskz_cvtepi64_ps(__U, __A); +} + +__m128 test_mm256_cvtepi64_ps(__m256i __A) { + // CHECK-LABEL: @test_mm256_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.256 + return _mm256_cvtepi64_ps(__A); +} + +__m128 test_mm256_mask_cvtepi64_ps(__m128 __W, __mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_mask_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.256 + return _mm256_mask_cvtepi64_ps(__W, __U, __A); +} + +__m128 test_mm256_maskz_cvtepi64_ps(__mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtepi64_ps + // CHECK: @llvm.x86.avx512.mask.cvtqq2ps.256 + return _mm256_maskz_cvtepi64_ps(__U, __A); +} + +__m128i test_mm_cvttpd_epi64(__m128d __A) { + // CHECK-LABEL: @test_mm_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.128 + return _mm_cvttpd_epi64(__A); +} + +__m128i test_mm_mask_cvttpd_epi64(__m128i __W, __mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_mask_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.128 + return _mm_mask_cvttpd_epi64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvttpd_epi64(__mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_maskz_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.128 + return _mm_maskz_cvttpd_epi64(__U, __A); +} + +__m256i test_mm256_cvttpd_epi64(__m256d __A) { + // CHECK-LABEL: @test_mm256_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.256 + return _mm256_cvttpd_epi64(__A); +} + +__m256i test_mm256_mask_cvttpd_epi64(__m256i __W, __mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_mask_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.256 + return _mm256_mask_cvttpd_epi64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvttpd_epi64(__mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_maskz_cvttpd_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2qq.256 + return _mm256_maskz_cvttpd_epi64(__U, __A); +} + +__m128i test_mm_cvttpd_epu64(__m128d __A) { + // CHECK-LABEL: @test_mm_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.128 + return _mm_cvttpd_epu64(__A); +} + +__m128i test_mm_mask_cvttpd_epu64(__m128i __W, __mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_mask_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.128 + return _mm_mask_cvttpd_epu64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvttpd_epu64(__mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_maskz_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.128 + return _mm_maskz_cvttpd_epu64(__U, __A); +} + +__m256i test_mm256_cvttpd_epu64(__m256d __A) { + // CHECK-LABEL: @test_mm256_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.256 + return _mm256_cvttpd_epu64(__A); +} + +__m256i test_mm256_mask_cvttpd_epu64(__m256i __W, __mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_mask_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.256 + return _mm256_mask_cvttpd_epu64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvttpd_epu64(__mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_maskz_cvttpd_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttpd2uqq.256 + return _mm256_maskz_cvttpd_epu64(__U, __A); +} + +__m128i test_mm_cvttps_epi64(__m128 __A) { + // CHECK-LABEL: @test_mm_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.128 + return _mm_cvttps_epi64(__A); +} + +__m128i test_mm_mask_cvttps_epi64(__m128i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_mask_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.128 + return _mm_mask_cvttps_epi64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvttps_epi64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_maskz_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.128 + return _mm_maskz_cvttps_epi64(__U, __A); +} + +__m256i test_mm256_cvttps_epi64(__m128 __A) { + // CHECK-LABEL: @test_mm256_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.256 + return _mm256_cvttps_epi64(__A); +} + +__m256i test_mm256_mask_cvttps_epi64(__m256i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_mask_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.256 + return _mm256_mask_cvttps_epi64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvttps_epi64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_maskz_cvttps_epi64 + // CHECK: @llvm.x86.avx512.mask.cvttps2qq.256 + return _mm256_maskz_cvttps_epi64(__U, __A); +} + +__m128i test_mm_cvttps_epu64(__m128 __A) { + // CHECK-LABEL: @test_mm_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.128 + return _mm_cvttps_epu64(__A); +} + +__m128i test_mm_mask_cvttps_epu64(__m128i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_mask_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.128 + return _mm_mask_cvttps_epu64(__W, __U, __A); +} + +__m128i test_mm_maskz_cvttps_epu64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_maskz_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.128 + return _mm_maskz_cvttps_epu64(__U, __A); +} + +__m256i test_mm256_cvttps_epu64(__m128 __A) { + // CHECK-LABEL: @test_mm256_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.256 + return _mm256_cvttps_epu64(__A); +} + +__m256i test_mm256_mask_cvttps_epu64(__m256i __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_mask_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.256 + return _mm256_mask_cvttps_epu64(__W, __U, __A); +} + +__m256i test_mm256_maskz_cvttps_epu64(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm256_maskz_cvttps_epu64 + // CHECK: @llvm.x86.avx512.mask.cvttps2uqq.256 + return _mm256_maskz_cvttps_epu64(__U, __A); +} + +__m128d test_mm_cvtepu64_pd(__m128i __A) { + // CHECK-LABEL: @test_mm_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.128 + return _mm_cvtepu64_pd(__A); +} + +__m128d test_mm_mask_cvtepu64_pd(__m128d __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_mask_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.128 + return _mm_mask_cvtepu64_pd(__W, __U, __A); +} + +__m128d test_mm_maskz_cvtepu64_pd(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_maskz_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.128 + return _mm_maskz_cvtepu64_pd(__U, __A); +} + +__m256d test_mm256_cvtepu64_pd(__m256i __A) { + // CHECK-LABEL: @test_mm256_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.256 + return _mm256_cvtepu64_pd(__A); +} + +__m256d test_mm256_mask_cvtepu64_pd(__m256d __W, __mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_mask_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.256 + return _mm256_mask_cvtepu64_pd(__W, __U, __A); +} + +__m256d test_mm256_maskz_cvtepu64_pd(__mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtepu64_pd + // CHECK: @llvm.x86.avx512.mask.cvtuqq2pd.256 + return _mm256_maskz_cvtepu64_pd(__U, __A); +} + +__m128 test_mm_cvtepu64_ps(__m128i __A) { + // CHECK-LABEL: @test_mm_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.128 + return _mm_cvtepu64_ps(__A); +} + +__m128 test_mm_mask_cvtepu64_ps(__m128 __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_mask_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.128 + return _mm_mask_cvtepu64_ps(__W, __U, __A); +} + +__m128 test_mm_maskz_cvtepu64_ps(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm_maskz_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.128 + return _mm_maskz_cvtepu64_ps(__U, __A); +} + +__m128 test_mm256_cvtepu64_ps(__m256i __A) { + // CHECK-LABEL: @test_mm256_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.256 + return _mm256_cvtepu64_ps(__A); +} + +__m128 test_mm256_mask_cvtepu64_ps(__m128 __W, __mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_mask_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.256 + return _mm256_mask_cvtepu64_ps(__W, __U, __A); +} + +__m128 test_mm256_maskz_cvtepu64_ps(__mmask8 __U, __m256i __A) { + // CHECK-LABEL: @test_mm256_maskz_cvtepu64_ps + // CHECK: @llvm.x86.avx512.mask.cvtuqq2ps.256 + return _mm256_maskz_cvtepu64_ps(__U, __A); +} + +__m128d test_mm_range_pd(__m128d __A, __m128d __B) { + // CHECK-LABEL: @test_mm_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.128 + return _mm_range_pd(__A, __B, 4); +} + +__m128d test_mm_mask_range_pd(__m128d __W, __mmask8 __U, __m128d __A, __m128d __B) { + // CHECK-LABEL: @test_mm_mask_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.128 + return _mm_mask_range_pd(__W, __U, __A, __B, 4); +} + +__m128d test_mm_maskz_range_pd(__mmask8 __U, __m128d __A, __m128d __B) { + // CHECK-LABEL: @test_mm_maskz_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.128 + return _mm_maskz_range_pd(__U, __A, __B, 4); +} + +__m256d test_mm256_range_pd(__m256d __A, __m256d __B) { + // CHECK-LABEL: @test_mm256_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.256 + return _mm256_range_pd(__A, __B, 4); +} + +__m256d test_mm256_mask_range_pd(__m256d __W, __mmask8 __U, __m256d __A, __m256d __B) { + // CHECK-LABEL: @test_mm256_mask_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.256 + return _mm256_mask_range_pd(__W, __U, __A, __B, 4); +} + +__m256d test_mm256_maskz_range_pd(__mmask8 __U, __m256d __A, __m256d __B) { + // CHECK-LABEL: @test_mm256_maskz_range_pd + // CHECK: @llvm.x86.avx512.mask.range.pd.256 + return _mm256_maskz_range_pd(__U, __A, __B, 4); +} + +__m128 test_mm_range_ps(__m128 __A, __m128 __B) { + // CHECK-LABEL: @test_mm_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.128 + return _mm_range_ps(__A, __B, 4); +} + +__m128 test_mm_mask_range_ps(__m128 __W, __mmask8 __U, __m128 __A, __m128 __B) { + // CHECK-LABEL: @test_mm_mask_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.128 + return _mm_mask_range_ps(__W, __U, __A, __B, 4); +} + +__m128 test_mm_maskz_range_ps(__mmask8 __U, __m128 __A, __m128 __B) { + // CHECK-LABEL: @test_mm_maskz_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.128 + return _mm_maskz_range_ps(__U, __A, __B, 4); +} + +__m256 test_mm256_range_ps(__m256 __A, __m256 __B) { + // CHECK-LABEL: @test_mm256_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.256 + return _mm256_range_ps(__A, __B, 4); +} + +__m256 test_mm256_mask_range_ps(__m256 __W, __mmask8 __U, __m256 __A, __m256 __B) { + // CHECK-LABEL: @test_mm256_mask_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.256 + return _mm256_mask_range_ps(__W, __U, __A, __B, 4); +} + +__m256 test_mm256_maskz_range_ps(__mmask8 __U, __m256 __A, __m256 __B) { + // CHECK-LABEL: @test_mm256_maskz_range_ps + // CHECK: @llvm.x86.avx512.mask.range.ps.256 + return _mm256_maskz_range_ps(__U, __A, __B, 4); +} + +__m128d test_mm_reduce_pd(__m128d __A) { + // CHECK-LABEL: @test_mm_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.128 + return _mm_reduce_pd(__A, 4); +} + +__m128d test_mm_mask_reduce_pd(__m128d __W, __mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_mask_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.128 + return _mm_mask_reduce_pd(__W, __U, __A, 4); +} + +__m128d test_mm_maskz_reduce_pd(__mmask8 __U, __m128d __A) { + // CHECK-LABEL: @test_mm_maskz_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.128 + return _mm_maskz_reduce_pd(__U, __A, 4); +} + +__m256d test_mm256_reduce_pd(__m256d __A) { + // CHECK-LABEL: @test_mm256_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.256 + return _mm256_reduce_pd(__A, 4); +} + +__m256d test_mm256_mask_reduce_pd(__m256d __W, __mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_mask_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.256 + return _mm256_mask_reduce_pd(__W, __U, __A, 4); +} + +__m256d test_mm256_maskz_reduce_pd(__mmask8 __U, __m256d __A) { + // CHECK-LABEL: @test_mm256_maskz_reduce_pd + // CHECK: @llvm.x86.avx512.mask.reduce.pd.256 + return _mm256_maskz_reduce_pd(__U, __A, 4); +} + +__m128 test_mm_reduce_ps(__m128 __A) { + // CHECK-LABEL: @test_mm_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.128 + return _mm_reduce_ps(__A, 4); +} + +__m128 test_mm_mask_reduce_ps(__m128 __W, __mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_mask_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.128 + return _mm_mask_reduce_ps(__W, __U, __A, 4); +} + +__m128 test_mm_maskz_reduce_ps(__mmask8 __U, __m128 __A) { + // CHECK-LABEL: @test_mm_maskz_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.128 + return _mm_maskz_reduce_ps(__U, __A, 4); +} + +__m256 test_mm256_reduce_ps(__m256 __A) { + // CHECK-LABEL: @test_mm256_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.256 + return _mm256_reduce_ps(__A, 4); +} + +__m256 test_mm256_mask_reduce_ps(__m256 __W, __mmask8 __U, __m256 __A) { + // CHECK-LABEL: @test_mm256_mask_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.256 + return _mm256_mask_reduce_ps(__W, __U, __A, 4); +} + +__m256 test_mm256_maskz_reduce_ps(__mmask8 __U, __m256 __A) { + // CHECK-LABEL: @test_mm256_maskz_reduce_ps + // CHECK: @llvm.x86.avx512.mask.reduce.ps.256 + return _mm256_maskz_reduce_ps(__U, __A, 4); +} \ No newline at end of file