1/*===---- tmmintrin.h - SSSE3 intrinsics -----------------------------------=== 2 * 3 * Permission is hereby granted, free of charge, to any person obtaining a copy 4 * of this software and associated documentation files (the "Software"), to deal 5 * in the Software without restriction, including without limitation the rights 6 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7 * copies of the Software, and to permit persons to whom the Software is 8 * furnished to do so, subject to the following conditions: 9 * 10 * The above copyright notice and this permission notice shall be included in 11 * all copies or substantial portions of the Software. 12 * 13 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 19 * THE SOFTWARE. 20 * 21 *===-----------------------------------------------------------------------=== 22 */ 23 24#ifndef __TMMINTRIN_H 25#define __TMMINTRIN_H 26 27#include <pmmintrin.h> 28 29/* Define the default attributes for the functions in this file. */ 30#define __DEFAULT_FN_ATTRS __attribute__((__always_inline__, __nodebug__, __target__("ssse3"))) 31 32static __inline__ __m64 __DEFAULT_FN_ATTRS 33_mm_abs_pi8(__m64 __a) 34{ 35 return (__m64)__builtin_ia32_pabsb((__v8qi)__a); 36} 37 38static __inline__ __m128i __DEFAULT_FN_ATTRS 39_mm_abs_epi8(__m128i __a) 40{ 41 return (__m128i)__builtin_ia32_pabsb128((__v16qi)__a); 42} 43 44static __inline__ __m64 __DEFAULT_FN_ATTRS 45_mm_abs_pi16(__m64 __a) 46{ 47 return (__m64)__builtin_ia32_pabsw((__v4hi)__a); 48} 49 50static __inline__ __m128i __DEFAULT_FN_ATTRS 51_mm_abs_epi16(__m128i __a) 52{ 53 return (__m128i)__builtin_ia32_pabsw128((__v8hi)__a); 54} 55 56static __inline__ __m64 __DEFAULT_FN_ATTRS 57_mm_abs_pi32(__m64 __a) 58{ 59 return (__m64)__builtin_ia32_pabsd((__v2si)__a); 60} 61 62static __inline__ __m128i __DEFAULT_FN_ATTRS 63_mm_abs_epi32(__m128i __a) 64{ 65 return (__m128i)__builtin_ia32_pabsd128((__v4si)__a); 66} 67 68#define _mm_alignr_epi8(a, b, n) __extension__ ({ \ 69 (__m128i)__builtin_ia32_palignr128((__v16qi)(__m128i)(a), \ 70 (__v16qi)(__m128i)(b), (n)); }) 71 72#define _mm_alignr_pi8(a, b, n) __extension__ ({ \ 73 (__m64)__builtin_ia32_palignr((__v8qi)(__m64)(a), (__v8qi)(__m64)(b), (n)); }) 74 75static __inline__ __m128i __DEFAULT_FN_ATTRS 76_mm_hadd_epi16(__m128i __a, __m128i __b) 77{ 78 return (__m128i)__builtin_ia32_phaddw128((__v8hi)__a, (__v8hi)__b); 79} 80 81static __inline__ __m128i __DEFAULT_FN_ATTRS 82_mm_hadd_epi32(__m128i __a, __m128i __b) 83{ 84 return (__m128i)__builtin_ia32_phaddd128((__v4si)__a, (__v4si)__b); 85} 86 87static __inline__ __m64 __DEFAULT_FN_ATTRS 88_mm_hadd_pi16(__m64 __a, __m64 __b) 89{ 90 return (__m64)__builtin_ia32_phaddw((__v4hi)__a, (__v4hi)__b); 91} 92 93static __inline__ __m64 __DEFAULT_FN_ATTRS 94_mm_hadd_pi32(__m64 __a, __m64 __b) 95{ 96 return (__m64)__builtin_ia32_phaddd((__v2si)__a, (__v2si)__b); 97} 98 99static __inline__ __m128i __DEFAULT_FN_ATTRS 100_mm_hadds_epi16(__m128i __a, __m128i __b) 101{ 102 return (__m128i)__builtin_ia32_phaddsw128((__v8hi)__a, (__v8hi)__b); 103} 104 105static __inline__ __m64 __DEFAULT_FN_ATTRS 106_mm_hadds_pi16(__m64 __a, __m64 __b) 107{ 108 return (__m64)__builtin_ia32_phaddsw((__v4hi)__a, (__v4hi)__b); 109} 110 111static __inline__ __m128i __DEFAULT_FN_ATTRS 112_mm_hsub_epi16(__m128i __a, __m128i __b) 113{ 114 return (__m128i)__builtin_ia32_phsubw128((__v8hi)__a, (__v8hi)__b); 115} 116 117static __inline__ __m128i __DEFAULT_FN_ATTRS 118_mm_hsub_epi32(__m128i __a, __m128i __b) 119{ 120 return (__m128i)__builtin_ia32_phsubd128((__v4si)__a, (__v4si)__b); 121} 122 123static __inline__ __m64 __DEFAULT_FN_ATTRS 124_mm_hsub_pi16(__m64 __a, __m64 __b) 125{ 126 return (__m64)__builtin_ia32_phsubw((__v4hi)__a, (__v4hi)__b); 127} 128 129static __inline__ __m64 __DEFAULT_FN_ATTRS 130_mm_hsub_pi32(__m64 __a, __m64 __b) 131{ 132 return (__m64)__builtin_ia32_phsubd((__v2si)__a, (__v2si)__b); 133} 134 135static __inline__ __m128i __DEFAULT_FN_ATTRS 136_mm_hsubs_epi16(__m128i __a, __m128i __b) 137{ 138 return (__m128i)__builtin_ia32_phsubsw128((__v8hi)__a, (__v8hi)__b); 139} 140 141static __inline__ __m64 __DEFAULT_FN_ATTRS 142_mm_hsubs_pi16(__m64 __a, __m64 __b) 143{ 144 return (__m64)__builtin_ia32_phsubsw((__v4hi)__a, (__v4hi)__b); 145} 146 147static __inline__ __m128i __DEFAULT_FN_ATTRS 148_mm_maddubs_epi16(__m128i __a, __m128i __b) 149{ 150 return (__m128i)__builtin_ia32_pmaddubsw128((__v16qi)__a, (__v16qi)__b); 151} 152 153static __inline__ __m64 __DEFAULT_FN_ATTRS 154_mm_maddubs_pi16(__m64 __a, __m64 __b) 155{ 156 return (__m64)__builtin_ia32_pmaddubsw((__v8qi)__a, (__v8qi)__b); 157} 158 159static __inline__ __m128i __DEFAULT_FN_ATTRS 160_mm_mulhrs_epi16(__m128i __a, __m128i __b) 161{ 162 return (__m128i)__builtin_ia32_pmulhrsw128((__v8hi)__a, (__v8hi)__b); 163} 164 165static __inline__ __m64 __DEFAULT_FN_ATTRS 166_mm_mulhrs_pi16(__m64 __a, __m64 __b) 167{ 168 return (__m64)__builtin_ia32_pmulhrsw((__v4hi)__a, (__v4hi)__b); 169} 170 171static __inline__ __m128i __DEFAULT_FN_ATTRS 172_mm_shuffle_epi8(__m128i __a, __m128i __b) 173{ 174 return (__m128i)__builtin_ia32_pshufb128((__v16qi)__a, (__v16qi)__b); 175} 176 177static __inline__ __m64 __DEFAULT_FN_ATTRS 178_mm_shuffle_pi8(__m64 __a, __m64 __b) 179{ 180 return (__m64)__builtin_ia32_pshufb((__v8qi)__a, (__v8qi)__b); 181} 182 183static __inline__ __m128i __DEFAULT_FN_ATTRS 184_mm_sign_epi8(__m128i __a, __m128i __b) 185{ 186 return (__m128i)__builtin_ia32_psignb128((__v16qi)__a, (__v16qi)__b); 187} 188 189static __inline__ __m128i __DEFAULT_FN_ATTRS 190_mm_sign_epi16(__m128i __a, __m128i __b) 191{ 192 return (__m128i)__builtin_ia32_psignw128((__v8hi)__a, (__v8hi)__b); 193} 194 195static __inline__ __m128i __DEFAULT_FN_ATTRS 196_mm_sign_epi32(__m128i __a, __m128i __b) 197{ 198 return (__m128i)__builtin_ia32_psignd128((__v4si)__a, (__v4si)__b); 199} 200 201static __inline__ __m64 __DEFAULT_FN_ATTRS 202_mm_sign_pi8(__m64 __a, __m64 __b) 203{ 204 return (__m64)__builtin_ia32_psignb((__v8qi)__a, (__v8qi)__b); 205} 206 207static __inline__ __m64 __DEFAULT_FN_ATTRS 208_mm_sign_pi16(__m64 __a, __m64 __b) 209{ 210 return (__m64)__builtin_ia32_psignw((__v4hi)__a, (__v4hi)__b); 211} 212 213static __inline__ __m64 __DEFAULT_FN_ATTRS 214_mm_sign_pi32(__m64 __a, __m64 __b) 215{ 216 return (__m64)__builtin_ia32_psignd((__v2si)__a, (__v2si)__b); 217} 218 219#undef __DEFAULT_FN_ATTRS 220 221#endif /* __TMMINTRIN_H */ 222