diff options
| author | Eric Christopher <echristo@apple.com> | 2010-03-07 06:17:19 +0000 |
|---|---|---|
| committer | Eric Christopher <echristo@apple.com> | 2010-03-07 06:17:19 +0000 |
| commit | 87990fe5dfa73b54e4b20037aae75c18a59df323 (patch) | |
| tree | 95f72965cdfd26e323ac3d7a8ecdbf6df32fe602 /clang/lib | |
| parent | 1d99699bda9b10b0d02b95a81855c245bbe348ff (diff) | |
| download | bcm5719-llvm-87990fe5dfa73b54e4b20037aae75c18a59df323.tar.gz bcm5719-llvm-87990fe5dfa73b54e4b20037aae75c18a59df323.zip | |
Add in support for dword multiply and fp dot product intrinsics.
llvm-svn: 97902
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Headers/smmintrin.h | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/clang/lib/Headers/smmintrin.h b/clang/lib/Headers/smmintrin.h index 5f2e69ca8ea..6fa33fcba17 100644 --- a/clang/lib/Headers/smmintrin.h +++ b/clang/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 */ |

