summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@gmail.com>2016-12-27 04:03:25 +0000
committerCraig Topper <craig.topper@gmail.com>2016-12-27 04:03:25 +0000
commitc5ab78d4c3f3a2ce167f8aa3d8e5c557f92fb41e (patch)
tree74cbebc12e552a2140b2f83e60b348473d169015 /clang
parentddb49837aae8d36e6bd138bb356695deeb3b2e80 (diff)
downloadbcm5719-llvm-c5ab78d4c3f3a2ce167f8aa3d8e5c557f92fb41e.tar.gz
bcm5719-llvm-c5ab78d4c3f3a2ce167f8aa3d8e5c557f92fb41e.zip
Revert r290575 "[AVX-512] Replace masked 512-bit pmuldq and pmuludq builtins with the newly added unmasked versions and selects."
I failed to merge this with r290574. llvm-svn: 290578
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Headers/avx512fintrin.h8
-rw-r--r--clang/test/CodeGen/avx512f-builtins.c24
2 files changed, 8 insertions, 24 deletions
diff --git a/clang/lib/Headers/avx512fintrin.h b/clang/lib/Headers/avx512fintrin.h
index e6a7217c896..30ebfc0430f 100644
--- a/clang/lib/Headers/avx512fintrin.h
+++ b/clang/lib/Headers/avx512fintrin.h
@@ -1422,7 +1422,7 @@ _mm512_mul_epi32(__m512i __X, __m512i __Y)
static __inline __m512i __DEFAULT_FN_ATTRS
_mm512_mask_mul_epi32(__m512i __W, __mmask8 __M, __m512i __X, __m512i __Y)
{
- return (__m512i)__builtin_ia32_selectq_512((__mmask8)__M,
+ return (__m512i)__builtin_ia32_selectq_512((__mmask8)__U,
(__v8di)_mm512_mul_epi32(__X, __Y),
(__v8di)__W);
}
@@ -1430,7 +1430,7 @@ _mm512_mask_mul_epi32(__m512i __W, __mmask8 __M, __m512i __X, __m512i __Y)
static __inline __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_mul_epi32(__mmask8 __M, __m512i __X, __m512i __Y)
{
- return (__m512i)__builtin_ia32_selectq_512((__mmask8)__M,
+ return (__m512i)__builtin_ia32_selectq_512((__mmask8)__U,
(__v8di)_mm512_mul_epi32(__X, __Y),
(__v8di)_mm512_setzero_si512 ());
}
@@ -1444,7 +1444,7 @@ _mm512_mul_epu32(__m512i __X, __m512i __Y)
static __inline __m512i __DEFAULT_FN_ATTRS
_mm512_mask_mul_epu32(__m512i __W, __mmask8 __M, __m512i __X, __m512i __Y)
{
- return (__m512i)__builtin_ia32_selectq_512((__mmask8)__M,
+ return (__m512i)__builtin_ia32_selectq_512((__mmask8)__U,
(__v8di)_mm512_mul_epu32(__X, __Y),
(__v8di)__W);
}
@@ -1452,7 +1452,7 @@ _mm512_mask_mul_epu32(__m512i __W, __mmask8 __M, __m512i __X, __m512i __Y)
static __inline __m512i __DEFAULT_FN_ATTRS
_mm512_maskz_mul_epu32(__mmask8 __M, __m512i __X, __m512i __Y)
{
- return (__m512i)__builtin_ia32_selectq_512((__mmask8)__M,
+ return (__m512i)__builtin_ia32_selectq_512((__mmask8)__U,
(__v8di)_mm512_mul_epu32(__X, __Y),
(__v8di)_mm512_setzero_si512 ());
}
diff --git a/clang/test/CodeGen/avx512f-builtins.c b/clang/test/CodeGen/avx512f-builtins.c
index 760783af1ce..ebd162835fc 100644
--- a/clang/test/CodeGen/avx512f-builtins.c
+++ b/clang/test/CodeGen/avx512f-builtins.c
@@ -1867,45 +1867,29 @@ __m512i test_mm512_add_epi64(__m512i __A, __m512i __B) {
return _mm512_add_epi64(__A,__B);
}
-__m512i test_mm512_mul_epi32(__m512i __A, __m512i __B) {
- //CHECK-LABEL: @test_mm512_mul_epi32
- //CHECK: @llvm.x86.avx512.pmul.dq.512
- return _mm512_mul_epi32(__A,__B);
-}
-
__m512i test_mm512_maskz_mul_epi32 (__mmask16 __k,__m512i __A, __m512i __B) {
//CHECK-LABEL: @test_mm512_maskz_mul_epi32
- //CHECK: @llvm.x86.avx512.pmul.dq.512
- //CHECK: select <8 x i1> %{{.*}}, <8 x i64> %{{.*}}, <8 x i64> %{{.*}}
+ //CHECK: @llvm.x86.avx512.mask.pmul.dq.512
return _mm512_maskz_mul_epi32(__k,__A,__B);
}
__m512i test_mm512_mask_mul_epi32 (__mmask16 __k,__m512i __A, __m512i __B,
__m512i __src) {
//CHECK-LABEL: @test_mm512_mask_mul_epi32
- //CHECK: @llvm.x86.avx512.pmul.dq.512
- //CHECK: select <8 x i1> %{{.*}}, <8 x i64> %{{.*}}, <8 x i64> %{{.*}}
+ //CHECK: @llvm.x86.avx512.mask.pmul.dq.512
return _mm512_mask_mul_epi32(__src,__k,__A,__B);
}
-__m512i test_mm512_mul_epu32 (__m512i __A, __m512i __B) {
- //CHECK-LABEL: @test_mm512_mul_epu32
- //CHECK: @llvm.x86.avx512.pmulu.dq.512
- return _mm512_mul_epu32(__A,__B);
-}
-
__m512i test_mm512_maskz_mul_epu32 (__mmask16 __k,__m512i __A, __m512i __B) {
//CHECK-LABEL: @test_mm512_maskz_mul_epu32
- //CHECK: @llvm.x86.avx512.pmulu.dq.512
- //CHECK: select <8 x i1> %{{.*}}, <8 x i64> %{{.*}}, <8 x i64> %{{.*}}
+ //CHECK: @llvm.x86.avx512.mask.pmulu.dq.512
return _mm512_maskz_mul_epu32(__k,__A,__B);
}
__m512i test_mm512_mask_mul_epu32 (__mmask16 __k,__m512i __A, __m512i __B,
__m512i __src) {
//CHECK-LABEL: @test_mm512_mask_mul_epu32
- //CHECK: @llvm.x86.avx512.pmulu.dq.512
- //CHECK: select <8 x i1> %{{.*}}, <8 x i64> %{{.*}}, <8 x i64> %{{.*}}
+ //CHECK: @llvm.x86.avx512.mask.pmulu.dq.512
return _mm512_mask_mul_epu32(__src,__k,__A,__B);
}
OpenPOWER on IntegriCloud