aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Zuckerman <Michael.zuckerman@intel.com>2016-05-26 06:54:52 +0000
committerMichael Zuckerman <Michael.zuckerman@intel.com>2016-05-26 06:54:52 +0000
commit6f08cebf36b84d6dfb2a270e74bfd2594eaf24d7 (patch)
tree724c1b826740c6c752faafe8adaa7ad3ef4c7853
parent8cce333abd3ad46af5ce2db839de360c7628b762 (diff)
downloadllvm-6f08cebf36b84d6dfb2a270e74bfd2594eaf24d7.zip
llvm-6f08cebf36b84d6dfb2a270e74bfd2594eaf24d7.tar.gz
llvm-6f08cebf36b84d6dfb2a270e74bfd2594eaf24d7.tar.bz2
[Clang][AVX512][BUILTIN] Adding intrinsics for set1
Differential Revision: http://reviews.llvm.org/D20562 llvm-svn: 270825
-rw-r--r--clang/lib/Headers/avx512fintrin.h24
-rw-r--r--clang/test/CodeGen/avx512f-builtins.c30
2 files changed, 54 insertions, 0 deletions
diff --git a/clang/lib/Headers/avx512fintrin.h b/clang/lib/Headers/avx512fintrin.h
index 297c9b8..a9d2af3 100644
--- a/clang/lib/Headers/avx512fintrin.h
+++ b/clang/lib/Headers/avx512fintrin.h
@@ -27,6 +27,8 @@
#ifndef __AVX512FINTRIN_H
#define __AVX512FINTRIN_H
+typedef char __v64qi __attribute__((__vector_size__(64)));
+typedef short __v32hi __attribute__((__vector_size__(64)));
typedef double __v8df __attribute__((__vector_size__(64)));
typedef float __v16sf __attribute__((__vector_size__(64)));
typedef long long __v8di __attribute__((__vector_size__(64)));
@@ -286,6 +288,28 @@ _mm512_set1_pd(double __w)
}
static __inline __m512i __DEFAULT_FN_ATTRS
+_mm512_set1_epi8(char __w)
+{
+ return (__m512i)(__v64qi){ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w };
+}
+
+static __inline __m512i __DEFAULT_FN_ATTRS
+_mm512_set1_epi16(short __w)
+{
+ return (__m512i)(__v32hi){ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w,
+ __w, __w, __w, __w, __w, __w, __w, __w };
+}
+
+static __inline __m512i __DEFAULT_FN_ATTRS
_mm512_set1_epi32(int __s)
{
return (__m512i)(__v16si){ __s, __s, __s, __s, __s, __s, __s, __s,
diff --git a/clang/test/CodeGen/avx512f-builtins.c b/clang/test/CodeGen/avx512f-builtins.c
index 1c16ec8..553dc14 100644
--- a/clang/test/CodeGen/avx512f-builtins.c
+++ b/clang/test/CodeGen/avx512f-builtins.c
@@ -5951,6 +5951,36 @@ __m512d test_mm512_castpd128_pd512(__m128d __A) {
return _mm512_castpd128_pd512(__A);
}
+__m512d test_mm512_set1_epi8(char d)
+{
+ // CHECK-LABEL: @test_mm512_set1_epi8
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 0
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 1
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 2
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 3
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 4
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 5
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 6
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 7
+ // CHECK: insertelement <64 x i8> {{.*}}, i32 63
+ return _mm512_set1_epi8(d);
+}
+
+__m512d test_mm512_set1_epi16(short d)
+{
+ // CHECK-LABEL: @test_mm512_set1_epi16
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 0
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 1
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 2
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 3
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 4
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 5
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 6
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 7
+ // CHECK: insertelement <32 x i16> {{.*}}, i32 31
+ return _mm512_set1_epi16(d);
+}
+
__m512d test_mm512_castpd256_pd512(__m256d a)
{
// CHECK-LABEL: @test_mm512_castpd256_pd512