diff options
author | Michael Zuckerman <Michael.zuckerman@intel.com> | 2016-02-21 14:00:11 +0000 |
---|---|---|
committer | Michael Zuckerman <Michael.zuckerman@intel.com> | 2016-02-21 14:00:11 +0000 |
commit | 7a33dce4ef8eafd320936350f90f4482c5c6e63a (patch) | |
tree | 4508ed24ddd5b5d4ee5104944d0800c73eeef003 /clang/test/CodeGen/avx512f-builtins.c | |
parent | e2ada8d3a72146f8665626f1f5e9d77708a630a1 (diff) | |
download | bcm5719-llvm-7a33dce4ef8eafd320936350f90f4482c5c6e63a.tar.gz bcm5719-llvm-7a33dce4ef8eafd320936350f90f4482c5c6e63a.zip |
[CLANG] [AVX512] [BUILTIN] Adding pmovzx{b|d|w}{w|d|q}{128|256|512} builtin to clang
Differential Revision: http://reviews.llvm.org/D16961
llvm-svn: 261471
Diffstat (limited to 'clang/test/CodeGen/avx512f-builtins.c')
-rw-r--r-- | clang/test/CodeGen/avx512f-builtins.c | 89 |
1 files changed, 89 insertions, 0 deletions
diff --git a/clang/test/CodeGen/avx512f-builtins.c b/clang/test/CodeGen/avx512f-builtins.c index 0b161773ea0..457f5968a6d 100644 --- a/clang/test/CodeGen/avx512f-builtins.c +++ b/clang/test/CodeGen/avx512f-builtins.c @@ -1990,3 +1990,92 @@ __m512i test_mm512_maskz_cvtepi16_epi64(__mmask8 __U, __m128i __A) { return _mm512_maskz_cvtepi16_epi64(__U, __A); } +__m512i test_mm512_cvtepu8_epi32(__m128i __A) { + // CHECK-LABEL: @test_mm512_cvtepu8_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.d.512 + return _mm512_cvtepu8_epi32(__A); +} + +__m512i test_mm512_mask_cvtepu8_epi32(__m512i __W, __mmask16 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_mask_cvtepu8_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.d.512 + return _mm512_mask_cvtepu8_epi32(__W, __U, __A); +} + +__m512i test_mm512_maskz_cvtepu8_epi32(__mmask16 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_maskz_cvtepu8_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.d.512 + return _mm512_maskz_cvtepu8_epi32(__U, __A); +} + +__m512i test_mm512_cvtepu8_epi64(__m128i __A) { + // CHECK-LABEL: @test_mm512_cvtepu8_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.q.512 + return _mm512_cvtepu8_epi64(__A); +} + +__m512i test_mm512_mask_cvtepu8_epi64(__m512i __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_mask_cvtepu8_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.q.512 + return _mm512_mask_cvtepu8_epi64(__W, __U, __A); +} + +__m512i test_mm512_maskz_cvtepu8_epi64(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_maskz_cvtepu8_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxb.q.512 + return _mm512_maskz_cvtepu8_epi64(__U, __A); +} + +__m512i test_mm512_cvtepu32_epi64(__m256i __X) { + // CHECK-LABEL: @test_mm512_cvtepu32_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxd.q.512 + return _mm512_cvtepu32_epi64(__X); +} + +__m512i test_mm512_mask_cvtepu32_epi64(__m512i __W, __mmask8 __U, __m256i __X) { + // CHECK-LABEL: @test_mm512_mask_cvtepu32_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxd.q.512 + return _mm512_mask_cvtepu32_epi64(__W, __U, __X); +} + +__m512i test_mm512_maskz_cvtepu32_epi64(__mmask8 __U, __m256i __X) { + // CHECK-LABEL: @test_mm512_maskz_cvtepu32_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxd.q.512 + return _mm512_maskz_cvtepu32_epi64(__U, __X); +} + +__m512i test_mm512_cvtepu16_epi32(__m256i __A) { + // CHECK-LABEL: @test_mm512_cvtepu16_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.d.512 + return _mm512_cvtepu16_epi32(__A); +} + +__m512i test_mm512_mask_cvtepu16_epi32(__m512i __W, __mmask16 __U, __m256i __A) { + // CHECK-LABEL: @test_mm512_mask_cvtepu16_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.d.512 + return _mm512_mask_cvtepu16_epi32(__W, __U, __A); +} + +__m512i test_mm512_maskz_cvtepu16_epi32(__mmask16 __U, __m256i __A) { + // CHECK-LABEL: @test_mm512_maskz_cvtepu16_epi32 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.d.512 + return _mm512_maskz_cvtepu16_epi32(__U, __A); +} + +__m512i test_mm512_cvtepu16_epi64(__m128i __A) { + // CHECK-LABEL: @test_mm512_cvtepu16_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.q.512 + return _mm512_cvtepu16_epi64(__A); +} + +__m512i test_mm512_mask_cvtepu16_epi64(__m512i __W, __mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_mask_cvtepu16_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.q.512 + return _mm512_mask_cvtepu16_epi64(__W, __U, __A); +} + +__m512i test_mm512_maskz_cvtepu16_epi64(__mmask8 __U, __m128i __A) { + // CHECK-LABEL: @test_mm512_maskz_cvtepu16_epi64 + // CHECK: @llvm.x86.avx512.mask.pmovzxw.q.512 + return _mm512_maskz_cvtepu16_epi64(__U, __A); +}
\ No newline at end of file |