diff options
author | Fangrui Song <maskray@google.com> | 2019-05-06 09:24:36 +0000 |
---|---|---|
committer | Fangrui Song <maskray@google.com> | 2019-05-06 09:24:36 +0000 |
commit | 041c377a592ba542500aa24d7636a4be069a1587 (patch) | |
tree | 655dedcd42d265906f75ae4aed830c5d60850e7c /clang/test/CodeGen/avx512bf16-builtins.c | |
parent | 9e1f2a7fe7584494728177eb7c7c2b5e399c54e8 (diff) | |
download | bcm5719-llvm-041c377a592ba542500aa24d7636a4be069a1587.tar.gz bcm5719-llvm-041c377a592ba542500aa24d7636a4be069a1587.zip |
[X86] Move files to correct directories after D60552
llvm-svn: 360022
Diffstat (limited to 'clang/test/CodeGen/avx512bf16-builtins.c')
-rw-r--r-- | clang/test/CodeGen/avx512bf16-builtins.c | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/clang/test/CodeGen/avx512bf16-builtins.c b/clang/test/CodeGen/avx512bf16-builtins.c new file mode 100644 index 00000000000..f7b26e14bba --- /dev/null +++ b/clang/test/CodeGen/avx512bf16-builtins.c @@ -0,0 +1,74 @@ +// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-apple-darwin \ +// RUN: -target-feature +avx512bf16 -emit-llvm -o - -Wall -Werror \ +// RUN: | FileCheck %s + +#include <immintrin.h> + +__m512bh test_mm512_cvtne2ps2bf16(__m512 A, __m512 B) { + // CHECK-LABEL: @test_mm512_cvtne2ps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtne2ps2bf16.512 + // CHECK: ret <32 x i16> %{{.*}} + return _mm512_cvtne2ps_pbh(A, B); +} + +__m512bh test_mm512_maskz_cvtne2ps2bf16(__m512 A, __m512 B, __mmask32 U) { + // CHECK-LABEL: @test_mm512_maskz_cvtne2ps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtne2ps2bf16.512 + // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}} + // CHECK: ret <32 x i16> %{{.*}} + return _mm512_maskz_cvtne2ps_pbh(U, A, B); +} + +__m512bh test_mm512_mask_cvtne2ps2bf16(__m512bh C, __mmask32 U, __m512 A, __m512 B) { + // CHECK-LABEL: @test_mm512_mask_cvtne2ps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtne2ps2bf16.512 + // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}} + // CHECK: ret <32 x i16> %{{.*}} + return _mm512_mask_cvtne2ps_pbh(C, U, A, B); +} + +__m256bh test_mm512_cvtneps2bf16(__m512 A) { + // CHECK-LABEL: @test_mm512_cvtneps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtneps2bf16.512 + // CHECK: ret <16 x i16> %{{.*}} + return _mm512_cvtneps_pbh(A); +} + +__m256bh test_mm512_mask_cvtneps2bf16(__m256bh C, __mmask16 U, __m512 A) { + // CHECK-LABEL: @test_mm512_mask_cvtneps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtneps2bf16.512 + // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}} + // CHECK: ret <16 x i16> %{{.*}} + return _mm512_mask_cvtneps_pbh(C, U, A); +} + +__m256bh test_mm512_maskz_cvtneps2bf16(__m512 A, __mmask16 U) { + // CHECK-LABEL: @test_mm512_maskz_cvtneps2bf16 + // CHECK: @llvm.x86.avx512bf16.cvtneps2bf16.512 + // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}} + // CHECK: ret <16 x i16> %{{.*}} + return _mm512_maskz_cvtneps_pbh(U, A); +} + +__m512 test_mm512_dpbf16_ps(__m512 D, __m512bh A, __m512bh B) { + // CHECK-LABEL: @test_mm512_dpbf16_ps + // CHECK: @llvm.x86.avx512bf16.dpbf16ps.512 + // CHECK: ret <16 x float> %{{.*}} + return _mm512_dpbf16_ps(D, A, B); +} + +__m512 test_mm512_maskz_dpbf16_ps(__m512 D, __m512bh A, __m512bh B, __mmask16 U) { + // CHECK-LABEL: @test_mm512_maskz_dpbf16_ps + // CHECK: @llvm.x86.avx512bf16.dpbf16ps.512 + // CHECK: select <16 x i1> %{{.*}}, <16 x float> %{{.*}}, <16 x float> %{{.*}} + // CHECK: ret <16 x float> %{{.*}} + return _mm512_maskz_dpbf16_ps(U, D, A, B); +} + +__m512 test_mm512_mask_dpbf16_ps(__m512 D, __m512bh A, __m512bh B, __mmask16 U) { + // CHECK-LABEL: @test_mm512_mask_dpbf16_ps + // CHECK: @llvm.x86.avx512bf16.dpbf16ps.512 + // CHECK: select <16 x i1> %{{.*}}, <16 x float> %{{.*}}, <16 x float> %{{.*}} + // CHECK: ret <16 x float> %{{.*}} + return _mm512_mask_dpbf16_ps(D, U, A, B); +} |