summaryrefslogtreecommitdiffstats
path: root/lib/Headers/xopintrin.h
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@gmail.com>2012-06-15 06:33:42 +0000
committerCraig Topper <craig.topper@gmail.com>2012-06-15 06:33:42 +0000
commitcda8df0bb55203a07f824668220aba48ed4e5cdf (patch)
tree9914f907d0cf8ad33c34b086eb13c9c60c8a91a0 /lib/Headers/xopintrin.h
parent55bf69900afbd5dfb971c346b3712361e27e7b7f (diff)
Add XOP frcz instrinsics.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@158492 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Headers/xopintrin.h')
-rw-r--r--lib/Headers/xopintrin.h36
1 files changed, 36 insertions, 0 deletions
diff --git a/lib/Headers/xopintrin.h b/lib/Headers/xopintrin.h
index a58a3ed382..e5b8d92b65 100644
--- a/lib/Headers/xopintrin.h
+++ b/lib/Headers/xopintrin.h
@@ -370,6 +370,42 @@ _mm_sha_epi64(__m128i __A, __m128i __B)
(__m256)__builtin_ia32_vpermil2ps256((__v8sf)__X, (__v8sf)__Y, \
(__v8si)__C, (I)); })
+static __inline__ __m128 __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_ss(__m128 __A)
+{
+ return (__m128)__builtin_ia32_vfrczss((__v4sf)__A);
+}
+
+static __inline__ __m128d __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_sd(__m128d __A)
+{
+ return (__m128d)__builtin_ia32_vfrczsd((__v2df)__A);
+}
+
+static __inline__ __m128 __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_ps(__m128 __A)
+{
+ return (__m128)__builtin_ia32_vfrczps((__v4sf)__A);
+}
+
+static __inline__ __m128d __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_pd(__m128d __A)
+{
+ return (__m128d)__builtin_ia32_vfrczpd((__v2df)__A);
+}
+
+static __inline__ __m256 __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_ps(__m256 __A)
+{
+ return (__m256)__builtin_ia32_vfrczps((__v4sf)__A);
+}
+
+static __inline__ __m256d __attribute__((__always_inline__, __nodebug__))
+_mm_frcz_pd(__m256d __A)
+{
+ return (__m256d)__builtin_ia32_vfrczpd((__v2df)__A);
+}
+
#endif /* __XOP__ */
#endif /* __XOPINTRIN_H */