summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Christopher <echristo@apple.com>2010-03-07 06:17:19 +0000
committerEric Christopher <echristo@apple.com>2010-03-07 06:17:19 +0000
commitc82ac95dbd68cbfa13bf8a93f7230fbe252931f7 (patch)
tree54740abba5aeaf7e9ab81d87e2eb0ff6129119f0
parent31b2ac71e40c02cb587ebcc24361a6f94f87a7c7 (diff)
Add in support for dword multiply and fp dot product intrinsics.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@97902 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--lib/Headers/smmintrin.h17
1 files changed, 17 insertions, 0 deletions
diff --git a/lib/Headers/smmintrin.h b/lib/Headers/smmintrin.h
index 5f2e69ca8e..6fa33fcba1 100644
--- a/lib/Headers/smmintrin.h
+++ b/lib/Headers/smmintrin.h
@@ -105,6 +105,23 @@ _mm_blend_epi16 (__m128i __V1, __m128i __V2, const int __M)
return (__m128i) __builtin_ia32_pblendw128 ((__v8hi)__V1, (__v8hi)__V2, __M);
}
+/* SSE4 Dword Multiply Instructions. */
+static inline __m128i __attribute__((__always_inline__, __nodebug__))
+_mm_mullo_epi32 (__m128i __V1, __m128i __V2)
+{
+ return (__m128i) __builtin_ia32_pmulld128((__v4si)__V1, (__v4si)__V2);
+}
+
+static inline __m128i __attribute__((__always_inline__, __nodebug__))
+_mm_mul_epi32 (__m128i __V1, __m128i __V2)
+{
+ return (__m128i) __builtin_ia32_pmuldq128 ((__v4si)__V1, (__v4si)__V2);
+}
+
+/* SSE4 Floating Point Dot Product Instructions. */
+#define _mm_dp_ps(X, Y, M) __builtin_ia32_dpps ((X), (Y), (M))
+#define _mm_dp_pd(X, Y, M) __builtin_ia32_dppd ((X), (Y), (M))
+
#endif /* __SSE4_1__ */
#endif /* _SMMINTRIN_H */