xref: /dflybsd-src/contrib/gcc-8.0/gcc/config/i386/xmmintrin.h (revision 38fd149817dfbff97799f62fcb70be98c4e32523)
1*38fd1498Szrj /* Copyright (C) 2002-2018 Free Software Foundation, Inc.
2*38fd1498Szrj 
3*38fd1498Szrj    This file is part of GCC.
4*38fd1498Szrj 
5*38fd1498Szrj    GCC is free software; you can redistribute it and/or modify
6*38fd1498Szrj    it under the terms of the GNU General Public License as published by
7*38fd1498Szrj    the Free Software Foundation; either version 3, or (at your option)
8*38fd1498Szrj    any later version.
9*38fd1498Szrj 
10*38fd1498Szrj    GCC is distributed in the hope that it will be useful,
11*38fd1498Szrj    but WITHOUT ANY WARRANTY; without even the implied warranty of
12*38fd1498Szrj    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13*38fd1498Szrj    GNU General Public License for more details.
14*38fd1498Szrj 
15*38fd1498Szrj    Under Section 7 of GPL version 3, you are granted additional
16*38fd1498Szrj    permissions described in the GCC Runtime Library Exception, version
17*38fd1498Szrj    3.1, as published by the Free Software Foundation.
18*38fd1498Szrj 
19*38fd1498Szrj    You should have received a copy of the GNU General Public License and
20*38fd1498Szrj    a copy of the GCC Runtime Library Exception along with this program;
21*38fd1498Szrj    see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
22*38fd1498Szrj    <http://www.gnu.org/licenses/>.  */
23*38fd1498Szrj 
24*38fd1498Szrj /* Implemented from the specification included in the Intel C++ Compiler
25*38fd1498Szrj    User Guide and Reference, version 9.0.  */
26*38fd1498Szrj 
27*38fd1498Szrj #ifndef _XMMINTRIN_H_INCLUDED
28*38fd1498Szrj #define _XMMINTRIN_H_INCLUDED
29*38fd1498Szrj 
30*38fd1498Szrj /* We need type definitions from the MMX header file.  */
31*38fd1498Szrj #include <mmintrin.h>
32*38fd1498Szrj 
33*38fd1498Szrj /* Get _mm_malloc () and _mm_free ().  */
34*38fd1498Szrj #include <mm_malloc.h>
35*38fd1498Szrj 
36*38fd1498Szrj /* Constants for use with _mm_prefetch.  */
37*38fd1498Szrj enum _mm_hint
38*38fd1498Szrj {
39*38fd1498Szrj   /* _MM_HINT_ET is _MM_HINT_T with set 3rd bit.  */
40*38fd1498Szrj   _MM_HINT_ET0 = 7,
41*38fd1498Szrj   _MM_HINT_ET1 = 6,
42*38fd1498Szrj   _MM_HINT_T0 = 3,
43*38fd1498Szrj   _MM_HINT_T1 = 2,
44*38fd1498Szrj   _MM_HINT_T2 = 1,
45*38fd1498Szrj   _MM_HINT_NTA = 0
46*38fd1498Szrj };
47*38fd1498Szrj 
48*38fd1498Szrj /* Loads one cache line from address P to a location "closer" to the
49*38fd1498Szrj    processor.  The selector I specifies the type of prefetch operation.  */
50*38fd1498Szrj #ifdef __OPTIMIZE__
51*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_prefetch(const void * __P,enum _mm_hint __I)52*38fd1498Szrj _mm_prefetch (const void *__P, enum _mm_hint __I)
53*38fd1498Szrj {
54*38fd1498Szrj   __builtin_prefetch (__P, (__I & 0x4) >> 2, __I & 0x3);
55*38fd1498Szrj }
56*38fd1498Szrj #else
57*38fd1498Szrj #define _mm_prefetch(P, I) \
58*38fd1498Szrj   __builtin_prefetch ((P), ((I & 0x4) >> 2), (I & 0x3))
59*38fd1498Szrj #endif
60*38fd1498Szrj 
61*38fd1498Szrj #ifndef __SSE__
62*38fd1498Szrj #pragma GCC push_options
63*38fd1498Szrj #pragma GCC target("sse")
64*38fd1498Szrj #define __DISABLE_SSE__
65*38fd1498Szrj #endif /* __SSE__ */
66*38fd1498Szrj 
67*38fd1498Szrj /* The Intel API is flexible enough that we must allow aliasing with other
68*38fd1498Szrj    vector types, and their scalar components.  */
69*38fd1498Szrj typedef float __m128 __attribute__ ((__vector_size__ (16), __may_alias__));
70*38fd1498Szrj 
71*38fd1498Szrj /* Unaligned version of the same type.  */
72*38fd1498Szrj typedef float __m128_u __attribute__ ((__vector_size__ (16), __may_alias__, __aligned__ (1)));
73*38fd1498Szrj 
74*38fd1498Szrj /* Internal data types for implementing the intrinsics.  */
75*38fd1498Szrj typedef float __v4sf __attribute__ ((__vector_size__ (16)));
76*38fd1498Szrj 
77*38fd1498Szrj /* Create a selector for use with the SHUFPS instruction.  */
78*38fd1498Szrj #define _MM_SHUFFLE(fp3,fp2,fp1,fp0) \
79*38fd1498Szrj  (((fp3) << 6) | ((fp2) << 4) | ((fp1) << 2) | (fp0))
80*38fd1498Szrj 
81*38fd1498Szrj /* Bits in the MXCSR.  */
82*38fd1498Szrj #define _MM_EXCEPT_MASK       0x003f
83*38fd1498Szrj #define _MM_EXCEPT_INVALID    0x0001
84*38fd1498Szrj #define _MM_EXCEPT_DENORM     0x0002
85*38fd1498Szrj #define _MM_EXCEPT_DIV_ZERO   0x0004
86*38fd1498Szrj #define _MM_EXCEPT_OVERFLOW   0x0008
87*38fd1498Szrj #define _MM_EXCEPT_UNDERFLOW  0x0010
88*38fd1498Szrj #define _MM_EXCEPT_INEXACT    0x0020
89*38fd1498Szrj 
90*38fd1498Szrj #define _MM_MASK_MASK         0x1f80
91*38fd1498Szrj #define _MM_MASK_INVALID      0x0080
92*38fd1498Szrj #define _MM_MASK_DENORM       0x0100
93*38fd1498Szrj #define _MM_MASK_DIV_ZERO     0x0200
94*38fd1498Szrj #define _MM_MASK_OVERFLOW     0x0400
95*38fd1498Szrj #define _MM_MASK_UNDERFLOW    0x0800
96*38fd1498Szrj #define _MM_MASK_INEXACT      0x1000
97*38fd1498Szrj 
98*38fd1498Szrj #define _MM_ROUND_MASK        0x6000
99*38fd1498Szrj #define _MM_ROUND_NEAREST     0x0000
100*38fd1498Szrj #define _MM_ROUND_DOWN        0x2000
101*38fd1498Szrj #define _MM_ROUND_UP          0x4000
102*38fd1498Szrj #define _MM_ROUND_TOWARD_ZERO 0x6000
103*38fd1498Szrj 
104*38fd1498Szrj #define _MM_FLUSH_ZERO_MASK   0x8000
105*38fd1498Szrj #define _MM_FLUSH_ZERO_ON     0x8000
106*38fd1498Szrj #define _MM_FLUSH_ZERO_OFF    0x0000
107*38fd1498Szrj 
108*38fd1498Szrj /* Create an undefined vector.  */
109*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_undefined_ps(void)110*38fd1498Szrj _mm_undefined_ps (void)
111*38fd1498Szrj {
112*38fd1498Szrj   __m128 __Y = __Y;
113*38fd1498Szrj   return __Y;
114*38fd1498Szrj }
115*38fd1498Szrj 
116*38fd1498Szrj /* Create a vector of zeros.  */
117*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_setzero_ps(void)118*38fd1498Szrj _mm_setzero_ps (void)
119*38fd1498Szrj {
120*38fd1498Szrj   return __extension__ (__m128){ 0.0f, 0.0f, 0.0f, 0.0f };
121*38fd1498Szrj }
122*38fd1498Szrj 
123*38fd1498Szrj /* Perform the respective operation on the lower SPFP (single-precision
124*38fd1498Szrj    floating-point) values of A and B; the upper three SPFP values are
125*38fd1498Szrj    passed through from A.  */
126*38fd1498Szrj 
127*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_add_ss(__m128 __A,__m128 __B)128*38fd1498Szrj _mm_add_ss (__m128 __A, __m128 __B)
129*38fd1498Szrj {
130*38fd1498Szrj   return (__m128) __builtin_ia32_addss ((__v4sf)__A, (__v4sf)__B);
131*38fd1498Szrj }
132*38fd1498Szrj 
133*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sub_ss(__m128 __A,__m128 __B)134*38fd1498Szrj _mm_sub_ss (__m128 __A, __m128 __B)
135*38fd1498Szrj {
136*38fd1498Szrj   return (__m128) __builtin_ia32_subss ((__v4sf)__A, (__v4sf)__B);
137*38fd1498Szrj }
138*38fd1498Szrj 
139*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_mul_ss(__m128 __A,__m128 __B)140*38fd1498Szrj _mm_mul_ss (__m128 __A, __m128 __B)
141*38fd1498Szrj {
142*38fd1498Szrj   return (__m128) __builtin_ia32_mulss ((__v4sf)__A, (__v4sf)__B);
143*38fd1498Szrj }
144*38fd1498Szrj 
145*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_div_ss(__m128 __A,__m128 __B)146*38fd1498Szrj _mm_div_ss (__m128 __A, __m128 __B)
147*38fd1498Szrj {
148*38fd1498Szrj   return (__m128) __builtin_ia32_divss ((__v4sf)__A, (__v4sf)__B);
149*38fd1498Szrj }
150*38fd1498Szrj 
151*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sqrt_ss(__m128 __A)152*38fd1498Szrj _mm_sqrt_ss (__m128 __A)
153*38fd1498Szrj {
154*38fd1498Szrj   return (__m128) __builtin_ia32_sqrtss ((__v4sf)__A);
155*38fd1498Szrj }
156*38fd1498Szrj 
157*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_rcp_ss(__m128 __A)158*38fd1498Szrj _mm_rcp_ss (__m128 __A)
159*38fd1498Szrj {
160*38fd1498Szrj   return (__m128) __builtin_ia32_rcpss ((__v4sf)__A);
161*38fd1498Szrj }
162*38fd1498Szrj 
163*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_rsqrt_ss(__m128 __A)164*38fd1498Szrj _mm_rsqrt_ss (__m128 __A)
165*38fd1498Szrj {
166*38fd1498Szrj   return (__m128) __builtin_ia32_rsqrtss ((__v4sf)__A);
167*38fd1498Szrj }
168*38fd1498Szrj 
169*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_min_ss(__m128 __A,__m128 __B)170*38fd1498Szrj _mm_min_ss (__m128 __A, __m128 __B)
171*38fd1498Szrj {
172*38fd1498Szrj   return (__m128) __builtin_ia32_minss ((__v4sf)__A, (__v4sf)__B);
173*38fd1498Szrj }
174*38fd1498Szrj 
175*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_max_ss(__m128 __A,__m128 __B)176*38fd1498Szrj _mm_max_ss (__m128 __A, __m128 __B)
177*38fd1498Szrj {
178*38fd1498Szrj   return (__m128) __builtin_ia32_maxss ((__v4sf)__A, (__v4sf)__B);
179*38fd1498Szrj }
180*38fd1498Szrj 
181*38fd1498Szrj /* Perform the respective operation on the four SPFP values in A and B.  */
182*38fd1498Szrj 
183*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_add_ps(__m128 __A,__m128 __B)184*38fd1498Szrj _mm_add_ps (__m128 __A, __m128 __B)
185*38fd1498Szrj {
186*38fd1498Szrj   return (__m128) ((__v4sf)__A + (__v4sf)__B);
187*38fd1498Szrj }
188*38fd1498Szrj 
189*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sub_ps(__m128 __A,__m128 __B)190*38fd1498Szrj _mm_sub_ps (__m128 __A, __m128 __B)
191*38fd1498Szrj {
192*38fd1498Szrj   return (__m128) ((__v4sf)__A - (__v4sf)__B);
193*38fd1498Szrj }
194*38fd1498Szrj 
195*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_mul_ps(__m128 __A,__m128 __B)196*38fd1498Szrj _mm_mul_ps (__m128 __A, __m128 __B)
197*38fd1498Szrj {
198*38fd1498Szrj   return (__m128) ((__v4sf)__A * (__v4sf)__B);
199*38fd1498Szrj }
200*38fd1498Szrj 
201*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_div_ps(__m128 __A,__m128 __B)202*38fd1498Szrj _mm_div_ps (__m128 __A, __m128 __B)
203*38fd1498Szrj {
204*38fd1498Szrj   return (__m128) ((__v4sf)__A / (__v4sf)__B);
205*38fd1498Szrj }
206*38fd1498Szrj 
207*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sqrt_ps(__m128 __A)208*38fd1498Szrj _mm_sqrt_ps (__m128 __A)
209*38fd1498Szrj {
210*38fd1498Szrj   return (__m128) __builtin_ia32_sqrtps ((__v4sf)__A);
211*38fd1498Szrj }
212*38fd1498Szrj 
213*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_rcp_ps(__m128 __A)214*38fd1498Szrj _mm_rcp_ps (__m128 __A)
215*38fd1498Szrj {
216*38fd1498Szrj   return (__m128) __builtin_ia32_rcpps ((__v4sf)__A);
217*38fd1498Szrj }
218*38fd1498Szrj 
219*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_rsqrt_ps(__m128 __A)220*38fd1498Szrj _mm_rsqrt_ps (__m128 __A)
221*38fd1498Szrj {
222*38fd1498Szrj   return (__m128) __builtin_ia32_rsqrtps ((__v4sf)__A);
223*38fd1498Szrj }
224*38fd1498Szrj 
225*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_min_ps(__m128 __A,__m128 __B)226*38fd1498Szrj _mm_min_ps (__m128 __A, __m128 __B)
227*38fd1498Szrj {
228*38fd1498Szrj   return (__m128) __builtin_ia32_minps ((__v4sf)__A, (__v4sf)__B);
229*38fd1498Szrj }
230*38fd1498Szrj 
231*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_max_ps(__m128 __A,__m128 __B)232*38fd1498Szrj _mm_max_ps (__m128 __A, __m128 __B)
233*38fd1498Szrj {
234*38fd1498Szrj   return (__m128) __builtin_ia32_maxps ((__v4sf)__A, (__v4sf)__B);
235*38fd1498Szrj }
236*38fd1498Szrj 
237*38fd1498Szrj /* Perform logical bit-wise operations on 128-bit values.  */
238*38fd1498Szrj 
239*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_and_ps(__m128 __A,__m128 __B)240*38fd1498Szrj _mm_and_ps (__m128 __A, __m128 __B)
241*38fd1498Szrj {
242*38fd1498Szrj   return __builtin_ia32_andps (__A, __B);
243*38fd1498Szrj }
244*38fd1498Szrj 
245*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_andnot_ps(__m128 __A,__m128 __B)246*38fd1498Szrj _mm_andnot_ps (__m128 __A, __m128 __B)
247*38fd1498Szrj {
248*38fd1498Szrj   return __builtin_ia32_andnps (__A, __B);
249*38fd1498Szrj }
250*38fd1498Szrj 
251*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_or_ps(__m128 __A,__m128 __B)252*38fd1498Szrj _mm_or_ps (__m128 __A, __m128 __B)
253*38fd1498Szrj {
254*38fd1498Szrj   return __builtin_ia32_orps (__A, __B);
255*38fd1498Szrj }
256*38fd1498Szrj 
257*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_xor_ps(__m128 __A,__m128 __B)258*38fd1498Szrj _mm_xor_ps (__m128 __A, __m128 __B)
259*38fd1498Szrj {
260*38fd1498Szrj   return __builtin_ia32_xorps (__A, __B);
261*38fd1498Szrj }
262*38fd1498Szrj 
263*38fd1498Szrj /* Perform a comparison on the lower SPFP values of A and B.  If the
264*38fd1498Szrj    comparison is true, place a mask of all ones in the result, otherwise a
265*38fd1498Szrj    mask of zeros.  The upper three SPFP values are passed through from A.  */
266*38fd1498Szrj 
267*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpeq_ss(__m128 __A,__m128 __B)268*38fd1498Szrj _mm_cmpeq_ss (__m128 __A, __m128 __B)
269*38fd1498Szrj {
270*38fd1498Szrj   return (__m128) __builtin_ia32_cmpeqss ((__v4sf)__A, (__v4sf)__B);
271*38fd1498Szrj }
272*38fd1498Szrj 
273*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmplt_ss(__m128 __A,__m128 __B)274*38fd1498Szrj _mm_cmplt_ss (__m128 __A, __m128 __B)
275*38fd1498Szrj {
276*38fd1498Szrj   return (__m128) __builtin_ia32_cmpltss ((__v4sf)__A, (__v4sf)__B);
277*38fd1498Szrj }
278*38fd1498Szrj 
279*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmple_ss(__m128 __A,__m128 __B)280*38fd1498Szrj _mm_cmple_ss (__m128 __A, __m128 __B)
281*38fd1498Szrj {
282*38fd1498Szrj   return (__m128) __builtin_ia32_cmpless ((__v4sf)__A, (__v4sf)__B);
283*38fd1498Szrj }
284*38fd1498Szrj 
285*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpgt_ss(__m128 __A,__m128 __B)286*38fd1498Szrj _mm_cmpgt_ss (__m128 __A, __m128 __B)
287*38fd1498Szrj {
288*38fd1498Szrj   return (__m128) __builtin_ia32_movss ((__v4sf) __A,
289*38fd1498Szrj 					(__v4sf)
290*38fd1498Szrj 					__builtin_ia32_cmpltss ((__v4sf) __B,
291*38fd1498Szrj 								(__v4sf)
292*38fd1498Szrj 								__A));
293*38fd1498Szrj }
294*38fd1498Szrj 
295*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpge_ss(__m128 __A,__m128 __B)296*38fd1498Szrj _mm_cmpge_ss (__m128 __A, __m128 __B)
297*38fd1498Szrj {
298*38fd1498Szrj   return (__m128) __builtin_ia32_movss ((__v4sf) __A,
299*38fd1498Szrj 					(__v4sf)
300*38fd1498Szrj 					__builtin_ia32_cmpless ((__v4sf) __B,
301*38fd1498Szrj 								(__v4sf)
302*38fd1498Szrj 								__A));
303*38fd1498Szrj }
304*38fd1498Szrj 
305*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpneq_ss(__m128 __A,__m128 __B)306*38fd1498Szrj _mm_cmpneq_ss (__m128 __A, __m128 __B)
307*38fd1498Szrj {
308*38fd1498Szrj   return (__m128) __builtin_ia32_cmpneqss ((__v4sf)__A, (__v4sf)__B);
309*38fd1498Szrj }
310*38fd1498Szrj 
311*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnlt_ss(__m128 __A,__m128 __B)312*38fd1498Szrj _mm_cmpnlt_ss (__m128 __A, __m128 __B)
313*38fd1498Szrj {
314*38fd1498Szrj   return (__m128) __builtin_ia32_cmpnltss ((__v4sf)__A, (__v4sf)__B);
315*38fd1498Szrj }
316*38fd1498Szrj 
317*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnle_ss(__m128 __A,__m128 __B)318*38fd1498Szrj _mm_cmpnle_ss (__m128 __A, __m128 __B)
319*38fd1498Szrj {
320*38fd1498Szrj   return (__m128) __builtin_ia32_cmpnless ((__v4sf)__A, (__v4sf)__B);
321*38fd1498Szrj }
322*38fd1498Szrj 
323*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpngt_ss(__m128 __A,__m128 __B)324*38fd1498Szrj _mm_cmpngt_ss (__m128 __A, __m128 __B)
325*38fd1498Szrj {
326*38fd1498Szrj   return (__m128) __builtin_ia32_movss ((__v4sf) __A,
327*38fd1498Szrj 					(__v4sf)
328*38fd1498Szrj 					__builtin_ia32_cmpnltss ((__v4sf) __B,
329*38fd1498Szrj 								 (__v4sf)
330*38fd1498Szrj 								 __A));
331*38fd1498Szrj }
332*38fd1498Szrj 
333*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnge_ss(__m128 __A,__m128 __B)334*38fd1498Szrj _mm_cmpnge_ss (__m128 __A, __m128 __B)
335*38fd1498Szrj {
336*38fd1498Szrj   return (__m128) __builtin_ia32_movss ((__v4sf) __A,
337*38fd1498Szrj 					(__v4sf)
338*38fd1498Szrj 					__builtin_ia32_cmpnless ((__v4sf) __B,
339*38fd1498Szrj 								 (__v4sf)
340*38fd1498Szrj 								 __A));
341*38fd1498Szrj }
342*38fd1498Szrj 
343*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpord_ss(__m128 __A,__m128 __B)344*38fd1498Szrj _mm_cmpord_ss (__m128 __A, __m128 __B)
345*38fd1498Szrj {
346*38fd1498Szrj   return (__m128) __builtin_ia32_cmpordss ((__v4sf)__A, (__v4sf)__B);
347*38fd1498Szrj }
348*38fd1498Szrj 
349*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpunord_ss(__m128 __A,__m128 __B)350*38fd1498Szrj _mm_cmpunord_ss (__m128 __A, __m128 __B)
351*38fd1498Szrj {
352*38fd1498Szrj   return (__m128) __builtin_ia32_cmpunordss ((__v4sf)__A, (__v4sf)__B);
353*38fd1498Szrj }
354*38fd1498Szrj 
355*38fd1498Szrj /* Perform a comparison on the four SPFP values of A and B.  For each
356*38fd1498Szrj    element, if the comparison is true, place a mask of all ones in the
357*38fd1498Szrj    result, otherwise a mask of zeros.  */
358*38fd1498Szrj 
359*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpeq_ps(__m128 __A,__m128 __B)360*38fd1498Szrj _mm_cmpeq_ps (__m128 __A, __m128 __B)
361*38fd1498Szrj {
362*38fd1498Szrj   return (__m128) __builtin_ia32_cmpeqps ((__v4sf)__A, (__v4sf)__B);
363*38fd1498Szrj }
364*38fd1498Szrj 
365*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmplt_ps(__m128 __A,__m128 __B)366*38fd1498Szrj _mm_cmplt_ps (__m128 __A, __m128 __B)
367*38fd1498Szrj {
368*38fd1498Szrj   return (__m128) __builtin_ia32_cmpltps ((__v4sf)__A, (__v4sf)__B);
369*38fd1498Szrj }
370*38fd1498Szrj 
371*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmple_ps(__m128 __A,__m128 __B)372*38fd1498Szrj _mm_cmple_ps (__m128 __A, __m128 __B)
373*38fd1498Szrj {
374*38fd1498Szrj   return (__m128) __builtin_ia32_cmpleps ((__v4sf)__A, (__v4sf)__B);
375*38fd1498Szrj }
376*38fd1498Szrj 
377*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpgt_ps(__m128 __A,__m128 __B)378*38fd1498Szrj _mm_cmpgt_ps (__m128 __A, __m128 __B)
379*38fd1498Szrj {
380*38fd1498Szrj   return (__m128) __builtin_ia32_cmpgtps ((__v4sf)__A, (__v4sf)__B);
381*38fd1498Szrj }
382*38fd1498Szrj 
383*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpge_ps(__m128 __A,__m128 __B)384*38fd1498Szrj _mm_cmpge_ps (__m128 __A, __m128 __B)
385*38fd1498Szrj {
386*38fd1498Szrj   return (__m128) __builtin_ia32_cmpgeps ((__v4sf)__A, (__v4sf)__B);
387*38fd1498Szrj }
388*38fd1498Szrj 
389*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpneq_ps(__m128 __A,__m128 __B)390*38fd1498Szrj _mm_cmpneq_ps (__m128 __A, __m128 __B)
391*38fd1498Szrj {
392*38fd1498Szrj   return (__m128) __builtin_ia32_cmpneqps ((__v4sf)__A, (__v4sf)__B);
393*38fd1498Szrj }
394*38fd1498Szrj 
395*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnlt_ps(__m128 __A,__m128 __B)396*38fd1498Szrj _mm_cmpnlt_ps (__m128 __A, __m128 __B)
397*38fd1498Szrj {
398*38fd1498Szrj   return (__m128) __builtin_ia32_cmpnltps ((__v4sf)__A, (__v4sf)__B);
399*38fd1498Szrj }
400*38fd1498Szrj 
401*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnle_ps(__m128 __A,__m128 __B)402*38fd1498Szrj _mm_cmpnle_ps (__m128 __A, __m128 __B)
403*38fd1498Szrj {
404*38fd1498Szrj   return (__m128) __builtin_ia32_cmpnleps ((__v4sf)__A, (__v4sf)__B);
405*38fd1498Szrj }
406*38fd1498Szrj 
407*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpngt_ps(__m128 __A,__m128 __B)408*38fd1498Szrj _mm_cmpngt_ps (__m128 __A, __m128 __B)
409*38fd1498Szrj {
410*38fd1498Szrj   return (__m128) __builtin_ia32_cmpngtps ((__v4sf)__A, (__v4sf)__B);
411*38fd1498Szrj }
412*38fd1498Szrj 
413*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpnge_ps(__m128 __A,__m128 __B)414*38fd1498Szrj _mm_cmpnge_ps (__m128 __A, __m128 __B)
415*38fd1498Szrj {
416*38fd1498Szrj   return (__m128) __builtin_ia32_cmpngeps ((__v4sf)__A, (__v4sf)__B);
417*38fd1498Szrj }
418*38fd1498Szrj 
419*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpord_ps(__m128 __A,__m128 __B)420*38fd1498Szrj _mm_cmpord_ps (__m128 __A, __m128 __B)
421*38fd1498Szrj {
422*38fd1498Szrj   return (__m128) __builtin_ia32_cmpordps ((__v4sf)__A, (__v4sf)__B);
423*38fd1498Szrj }
424*38fd1498Szrj 
425*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cmpunord_ps(__m128 __A,__m128 __B)426*38fd1498Szrj _mm_cmpunord_ps (__m128 __A, __m128 __B)
427*38fd1498Szrj {
428*38fd1498Szrj   return (__m128) __builtin_ia32_cmpunordps ((__v4sf)__A, (__v4sf)__B);
429*38fd1498Szrj }
430*38fd1498Szrj 
431*38fd1498Szrj /* Compare the lower SPFP values of A and B and return 1 if true
432*38fd1498Szrj    and 0 if false.  */
433*38fd1498Szrj 
434*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comieq_ss(__m128 __A,__m128 __B)435*38fd1498Szrj _mm_comieq_ss (__m128 __A, __m128 __B)
436*38fd1498Szrj {
437*38fd1498Szrj   return __builtin_ia32_comieq ((__v4sf)__A, (__v4sf)__B);
438*38fd1498Szrj }
439*38fd1498Szrj 
440*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comilt_ss(__m128 __A,__m128 __B)441*38fd1498Szrj _mm_comilt_ss (__m128 __A, __m128 __B)
442*38fd1498Szrj {
443*38fd1498Szrj   return __builtin_ia32_comilt ((__v4sf)__A, (__v4sf)__B);
444*38fd1498Szrj }
445*38fd1498Szrj 
446*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comile_ss(__m128 __A,__m128 __B)447*38fd1498Szrj _mm_comile_ss (__m128 __A, __m128 __B)
448*38fd1498Szrj {
449*38fd1498Szrj   return __builtin_ia32_comile ((__v4sf)__A, (__v4sf)__B);
450*38fd1498Szrj }
451*38fd1498Szrj 
452*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comigt_ss(__m128 __A,__m128 __B)453*38fd1498Szrj _mm_comigt_ss (__m128 __A, __m128 __B)
454*38fd1498Szrj {
455*38fd1498Szrj   return __builtin_ia32_comigt ((__v4sf)__A, (__v4sf)__B);
456*38fd1498Szrj }
457*38fd1498Szrj 
458*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comige_ss(__m128 __A,__m128 __B)459*38fd1498Szrj _mm_comige_ss (__m128 __A, __m128 __B)
460*38fd1498Szrj {
461*38fd1498Szrj   return __builtin_ia32_comige ((__v4sf)__A, (__v4sf)__B);
462*38fd1498Szrj }
463*38fd1498Szrj 
464*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_comineq_ss(__m128 __A,__m128 __B)465*38fd1498Szrj _mm_comineq_ss (__m128 __A, __m128 __B)
466*38fd1498Szrj {
467*38fd1498Szrj   return __builtin_ia32_comineq ((__v4sf)__A, (__v4sf)__B);
468*38fd1498Szrj }
469*38fd1498Szrj 
470*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomieq_ss(__m128 __A,__m128 __B)471*38fd1498Szrj _mm_ucomieq_ss (__m128 __A, __m128 __B)
472*38fd1498Szrj {
473*38fd1498Szrj   return __builtin_ia32_ucomieq ((__v4sf)__A, (__v4sf)__B);
474*38fd1498Szrj }
475*38fd1498Szrj 
476*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomilt_ss(__m128 __A,__m128 __B)477*38fd1498Szrj _mm_ucomilt_ss (__m128 __A, __m128 __B)
478*38fd1498Szrj {
479*38fd1498Szrj   return __builtin_ia32_ucomilt ((__v4sf)__A, (__v4sf)__B);
480*38fd1498Szrj }
481*38fd1498Szrj 
482*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomile_ss(__m128 __A,__m128 __B)483*38fd1498Szrj _mm_ucomile_ss (__m128 __A, __m128 __B)
484*38fd1498Szrj {
485*38fd1498Szrj   return __builtin_ia32_ucomile ((__v4sf)__A, (__v4sf)__B);
486*38fd1498Szrj }
487*38fd1498Szrj 
488*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomigt_ss(__m128 __A,__m128 __B)489*38fd1498Szrj _mm_ucomigt_ss (__m128 __A, __m128 __B)
490*38fd1498Szrj {
491*38fd1498Szrj   return __builtin_ia32_ucomigt ((__v4sf)__A, (__v4sf)__B);
492*38fd1498Szrj }
493*38fd1498Szrj 
494*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomige_ss(__m128 __A,__m128 __B)495*38fd1498Szrj _mm_ucomige_ss (__m128 __A, __m128 __B)
496*38fd1498Szrj {
497*38fd1498Szrj   return __builtin_ia32_ucomige ((__v4sf)__A, (__v4sf)__B);
498*38fd1498Szrj }
499*38fd1498Szrj 
500*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_ucomineq_ss(__m128 __A,__m128 __B)501*38fd1498Szrj _mm_ucomineq_ss (__m128 __A, __m128 __B)
502*38fd1498Szrj {
503*38fd1498Szrj   return __builtin_ia32_ucomineq ((__v4sf)__A, (__v4sf)__B);
504*38fd1498Szrj }
505*38fd1498Szrj 
506*38fd1498Szrj /* Convert the lower SPFP value to a 32-bit integer according to the current
507*38fd1498Szrj    rounding mode.  */
508*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtss_si32(__m128 __A)509*38fd1498Szrj _mm_cvtss_si32 (__m128 __A)
510*38fd1498Szrj {
511*38fd1498Szrj   return __builtin_ia32_cvtss2si ((__v4sf) __A);
512*38fd1498Szrj }
513*38fd1498Szrj 
514*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvt_ss2si(__m128 __A)515*38fd1498Szrj _mm_cvt_ss2si (__m128 __A)
516*38fd1498Szrj {
517*38fd1498Szrj   return _mm_cvtss_si32 (__A);
518*38fd1498Szrj }
519*38fd1498Szrj 
520*38fd1498Szrj #ifdef __x86_64__
521*38fd1498Szrj /* Convert the lower SPFP value to a 32-bit integer according to the
522*38fd1498Szrj    current rounding mode.  */
523*38fd1498Szrj 
524*38fd1498Szrj /* Intel intrinsic.  */
525*38fd1498Szrj extern __inline long long __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtss_si64(__m128 __A)526*38fd1498Szrj _mm_cvtss_si64 (__m128 __A)
527*38fd1498Szrj {
528*38fd1498Szrj   return __builtin_ia32_cvtss2si64 ((__v4sf) __A);
529*38fd1498Szrj }
530*38fd1498Szrj 
531*38fd1498Szrj /* Microsoft intrinsic.  */
532*38fd1498Szrj extern __inline long long __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtss_si64x(__m128 __A)533*38fd1498Szrj _mm_cvtss_si64x (__m128 __A)
534*38fd1498Szrj {
535*38fd1498Szrj   return __builtin_ia32_cvtss2si64 ((__v4sf) __A);
536*38fd1498Szrj }
537*38fd1498Szrj #endif
538*38fd1498Szrj 
539*38fd1498Szrj /* Convert the two lower SPFP values to 32-bit integers according to the
540*38fd1498Szrj    current rounding mode.  Return the integers in packed form.  */
541*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtps_pi32(__m128 __A)542*38fd1498Szrj _mm_cvtps_pi32 (__m128 __A)
543*38fd1498Szrj {
544*38fd1498Szrj   return (__m64) __builtin_ia32_cvtps2pi ((__v4sf) __A);
545*38fd1498Szrj }
546*38fd1498Szrj 
547*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvt_ps2pi(__m128 __A)548*38fd1498Szrj _mm_cvt_ps2pi (__m128 __A)
549*38fd1498Szrj {
550*38fd1498Szrj   return _mm_cvtps_pi32 (__A);
551*38fd1498Szrj }
552*38fd1498Szrj 
553*38fd1498Szrj /* Truncate the lower SPFP value to a 32-bit integer.  */
554*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvttss_si32(__m128 __A)555*38fd1498Szrj _mm_cvttss_si32 (__m128 __A)
556*38fd1498Szrj {
557*38fd1498Szrj   return __builtin_ia32_cvttss2si ((__v4sf) __A);
558*38fd1498Szrj }
559*38fd1498Szrj 
560*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtt_ss2si(__m128 __A)561*38fd1498Szrj _mm_cvtt_ss2si (__m128 __A)
562*38fd1498Szrj {
563*38fd1498Szrj   return _mm_cvttss_si32 (__A);
564*38fd1498Szrj }
565*38fd1498Szrj 
566*38fd1498Szrj #ifdef __x86_64__
567*38fd1498Szrj /* Truncate the lower SPFP value to a 32-bit integer.  */
568*38fd1498Szrj 
569*38fd1498Szrj /* Intel intrinsic.  */
570*38fd1498Szrj extern __inline long long __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvttss_si64(__m128 __A)571*38fd1498Szrj _mm_cvttss_si64 (__m128 __A)
572*38fd1498Szrj {
573*38fd1498Szrj   return __builtin_ia32_cvttss2si64 ((__v4sf) __A);
574*38fd1498Szrj }
575*38fd1498Szrj 
576*38fd1498Szrj /* Microsoft intrinsic.  */
577*38fd1498Szrj extern __inline long long __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvttss_si64x(__m128 __A)578*38fd1498Szrj _mm_cvttss_si64x (__m128 __A)
579*38fd1498Szrj {
580*38fd1498Szrj   return __builtin_ia32_cvttss2si64 ((__v4sf) __A);
581*38fd1498Szrj }
582*38fd1498Szrj #endif
583*38fd1498Szrj 
584*38fd1498Szrj /* Truncate the two lower SPFP values to 32-bit integers.  Return the
585*38fd1498Szrj    integers in packed form.  */
586*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvttps_pi32(__m128 __A)587*38fd1498Szrj _mm_cvttps_pi32 (__m128 __A)
588*38fd1498Szrj {
589*38fd1498Szrj   return (__m64) __builtin_ia32_cvttps2pi ((__v4sf) __A);
590*38fd1498Szrj }
591*38fd1498Szrj 
592*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtt_ps2pi(__m128 __A)593*38fd1498Szrj _mm_cvtt_ps2pi (__m128 __A)
594*38fd1498Szrj {
595*38fd1498Szrj   return _mm_cvttps_pi32 (__A);
596*38fd1498Szrj }
597*38fd1498Szrj 
598*38fd1498Szrj /* Convert B to a SPFP value and insert it as element zero in A.  */
599*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtsi32_ss(__m128 __A,int __B)600*38fd1498Szrj _mm_cvtsi32_ss (__m128 __A, int __B)
601*38fd1498Szrj {
602*38fd1498Szrj   return (__m128) __builtin_ia32_cvtsi2ss ((__v4sf) __A, __B);
603*38fd1498Szrj }
604*38fd1498Szrj 
605*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvt_si2ss(__m128 __A,int __B)606*38fd1498Szrj _mm_cvt_si2ss (__m128 __A, int __B)
607*38fd1498Szrj {
608*38fd1498Szrj   return _mm_cvtsi32_ss (__A, __B);
609*38fd1498Szrj }
610*38fd1498Szrj 
611*38fd1498Szrj #ifdef __x86_64__
612*38fd1498Szrj /* Convert B to a SPFP value and insert it as element zero in A.  */
613*38fd1498Szrj 
614*38fd1498Szrj /* Intel intrinsic.  */
615*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtsi64_ss(__m128 __A,long long __B)616*38fd1498Szrj _mm_cvtsi64_ss (__m128 __A, long long __B)
617*38fd1498Szrj {
618*38fd1498Szrj   return (__m128) __builtin_ia32_cvtsi642ss ((__v4sf) __A, __B);
619*38fd1498Szrj }
620*38fd1498Szrj 
621*38fd1498Szrj /* Microsoft intrinsic.  */
622*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtsi64x_ss(__m128 __A,long long __B)623*38fd1498Szrj _mm_cvtsi64x_ss (__m128 __A, long long __B)
624*38fd1498Szrj {
625*38fd1498Szrj   return (__m128) __builtin_ia32_cvtsi642ss ((__v4sf) __A, __B);
626*38fd1498Szrj }
627*38fd1498Szrj #endif
628*38fd1498Szrj 
629*38fd1498Szrj /* Convert the two 32-bit values in B to SPFP form and insert them
630*38fd1498Szrj    as the two lower elements in A.  */
631*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpi32_ps(__m128 __A,__m64 __B)632*38fd1498Szrj _mm_cvtpi32_ps (__m128 __A, __m64 __B)
633*38fd1498Szrj {
634*38fd1498Szrj   return (__m128) __builtin_ia32_cvtpi2ps ((__v4sf) __A, (__v2si)__B);
635*38fd1498Szrj }
636*38fd1498Szrj 
637*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvt_pi2ps(__m128 __A,__m64 __B)638*38fd1498Szrj _mm_cvt_pi2ps (__m128 __A, __m64 __B)
639*38fd1498Szrj {
640*38fd1498Szrj   return _mm_cvtpi32_ps (__A, __B);
641*38fd1498Szrj }
642*38fd1498Szrj 
643*38fd1498Szrj /* Convert the four signed 16-bit values in A to SPFP form.  */
644*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpi16_ps(__m64 __A)645*38fd1498Szrj _mm_cvtpi16_ps (__m64 __A)
646*38fd1498Szrj {
647*38fd1498Szrj   __v4hi __sign;
648*38fd1498Szrj   __v2si __hisi, __losi;
649*38fd1498Szrj   __v4sf __zero, __ra, __rb;
650*38fd1498Szrj 
651*38fd1498Szrj   /* This comparison against zero gives us a mask that can be used to
652*38fd1498Szrj      fill in the missing sign bits in the unpack operations below, so
653*38fd1498Szrj      that we get signed values after unpacking.  */
654*38fd1498Szrj   __sign = __builtin_ia32_pcmpgtw ((__v4hi)0LL, (__v4hi)__A);
655*38fd1498Szrj 
656*38fd1498Szrj   /* Convert the four words to doublewords.  */
657*38fd1498Szrj   __losi = (__v2si) __builtin_ia32_punpcklwd ((__v4hi)__A, __sign);
658*38fd1498Szrj   __hisi = (__v2si) __builtin_ia32_punpckhwd ((__v4hi)__A, __sign);
659*38fd1498Szrj 
660*38fd1498Szrj   /* Convert the doublewords to floating point two at a time.  */
661*38fd1498Szrj   __zero = (__v4sf) _mm_setzero_ps ();
662*38fd1498Szrj   __ra = __builtin_ia32_cvtpi2ps (__zero, __losi);
663*38fd1498Szrj   __rb = __builtin_ia32_cvtpi2ps (__ra, __hisi);
664*38fd1498Szrj 
665*38fd1498Szrj   return (__m128) __builtin_ia32_movlhps (__ra, __rb);
666*38fd1498Szrj }
667*38fd1498Szrj 
668*38fd1498Szrj /* Convert the four unsigned 16-bit values in A to SPFP form.  */
669*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpu16_ps(__m64 __A)670*38fd1498Szrj _mm_cvtpu16_ps (__m64 __A)
671*38fd1498Szrj {
672*38fd1498Szrj   __v2si __hisi, __losi;
673*38fd1498Szrj   __v4sf __zero, __ra, __rb;
674*38fd1498Szrj 
675*38fd1498Szrj   /* Convert the four words to doublewords.  */
676*38fd1498Szrj   __losi = (__v2si) __builtin_ia32_punpcklwd ((__v4hi)__A, (__v4hi)0LL);
677*38fd1498Szrj   __hisi = (__v2si) __builtin_ia32_punpckhwd ((__v4hi)__A, (__v4hi)0LL);
678*38fd1498Szrj 
679*38fd1498Szrj   /* Convert the doublewords to floating point two at a time.  */
680*38fd1498Szrj   __zero = (__v4sf) _mm_setzero_ps ();
681*38fd1498Szrj   __ra = __builtin_ia32_cvtpi2ps (__zero, __losi);
682*38fd1498Szrj   __rb = __builtin_ia32_cvtpi2ps (__ra, __hisi);
683*38fd1498Szrj 
684*38fd1498Szrj   return (__m128) __builtin_ia32_movlhps (__ra, __rb);
685*38fd1498Szrj }
686*38fd1498Szrj 
687*38fd1498Szrj /* Convert the low four signed 8-bit values in A to SPFP form.  */
688*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpi8_ps(__m64 __A)689*38fd1498Szrj _mm_cvtpi8_ps (__m64 __A)
690*38fd1498Szrj {
691*38fd1498Szrj   __v8qi __sign;
692*38fd1498Szrj 
693*38fd1498Szrj   /* This comparison against zero gives us a mask that can be used to
694*38fd1498Szrj      fill in the missing sign bits in the unpack operations below, so
695*38fd1498Szrj      that we get signed values after unpacking.  */
696*38fd1498Szrj   __sign = __builtin_ia32_pcmpgtb ((__v8qi)0LL, (__v8qi)__A);
697*38fd1498Szrj 
698*38fd1498Szrj   /* Convert the four low bytes to words.  */
699*38fd1498Szrj   __A = (__m64) __builtin_ia32_punpcklbw ((__v8qi)__A, __sign);
700*38fd1498Szrj 
701*38fd1498Szrj   return _mm_cvtpi16_ps(__A);
702*38fd1498Szrj }
703*38fd1498Szrj 
704*38fd1498Szrj /* Convert the low four unsigned 8-bit values in A to SPFP form.  */
705*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpu8_ps(__m64 __A)706*38fd1498Szrj _mm_cvtpu8_ps(__m64 __A)
707*38fd1498Szrj {
708*38fd1498Szrj   __A = (__m64) __builtin_ia32_punpcklbw ((__v8qi)__A, (__v8qi)0LL);
709*38fd1498Szrj   return _mm_cvtpu16_ps(__A);
710*38fd1498Szrj }
711*38fd1498Szrj 
712*38fd1498Szrj /* Convert the four signed 32-bit values in A and B to SPFP form.  */
713*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtpi32x2_ps(__m64 __A,__m64 __B)714*38fd1498Szrj _mm_cvtpi32x2_ps(__m64 __A, __m64 __B)
715*38fd1498Szrj {
716*38fd1498Szrj   __v4sf __zero = (__v4sf) _mm_setzero_ps ();
717*38fd1498Szrj   __v4sf __sfa = __builtin_ia32_cvtpi2ps (__zero, (__v2si)__A);
718*38fd1498Szrj   __v4sf __sfb = __builtin_ia32_cvtpi2ps (__sfa, (__v2si)__B);
719*38fd1498Szrj   return (__m128) __builtin_ia32_movlhps (__sfa, __sfb);
720*38fd1498Szrj }
721*38fd1498Szrj 
722*38fd1498Szrj /* Convert the four SPFP values in A to four signed 16-bit integers.  */
723*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtps_pi16(__m128 __A)724*38fd1498Szrj _mm_cvtps_pi16(__m128 __A)
725*38fd1498Szrj {
726*38fd1498Szrj   __v4sf __hisf = (__v4sf)__A;
727*38fd1498Szrj   __v4sf __losf = __builtin_ia32_movhlps (__hisf, __hisf);
728*38fd1498Szrj   __v2si __hisi = __builtin_ia32_cvtps2pi (__hisf);
729*38fd1498Szrj   __v2si __losi = __builtin_ia32_cvtps2pi (__losf);
730*38fd1498Szrj   return (__m64) __builtin_ia32_packssdw (__hisi, __losi);
731*38fd1498Szrj }
732*38fd1498Szrj 
733*38fd1498Szrj /* Convert the four SPFP values in A to four signed 8-bit integers.  */
734*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtps_pi8(__m128 __A)735*38fd1498Szrj _mm_cvtps_pi8(__m128 __A)
736*38fd1498Szrj {
737*38fd1498Szrj   __v4hi __tmp = (__v4hi) _mm_cvtps_pi16 (__A);
738*38fd1498Szrj   return (__m64) __builtin_ia32_packsswb (__tmp, (__v4hi)0LL);
739*38fd1498Szrj }
740*38fd1498Szrj 
741*38fd1498Szrj /* Selects four specific SPFP values from A and B based on MASK.  */
742*38fd1498Szrj #ifdef __OPTIMIZE__
743*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_shuffle_ps(__m128 __A,__m128 __B,int const __mask)744*38fd1498Szrj _mm_shuffle_ps (__m128 __A, __m128 __B, int const __mask)
745*38fd1498Szrj {
746*38fd1498Szrj   return (__m128) __builtin_ia32_shufps ((__v4sf)__A, (__v4sf)__B, __mask);
747*38fd1498Szrj }
748*38fd1498Szrj #else
749*38fd1498Szrj #define _mm_shuffle_ps(A, B, MASK)					\
750*38fd1498Szrj   ((__m128) __builtin_ia32_shufps ((__v4sf)(__m128)(A),			\
751*38fd1498Szrj 				   (__v4sf)(__m128)(B), (int)(MASK)))
752*38fd1498Szrj #endif
753*38fd1498Szrj 
754*38fd1498Szrj /* Selects and interleaves the upper two SPFP values from A and B.  */
755*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_unpackhi_ps(__m128 __A,__m128 __B)756*38fd1498Szrj _mm_unpackhi_ps (__m128 __A, __m128 __B)
757*38fd1498Szrj {
758*38fd1498Szrj   return (__m128) __builtin_ia32_unpckhps ((__v4sf)__A, (__v4sf)__B);
759*38fd1498Szrj }
760*38fd1498Szrj 
761*38fd1498Szrj /* Selects and interleaves the lower two SPFP values from A and B.  */
762*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_unpacklo_ps(__m128 __A,__m128 __B)763*38fd1498Szrj _mm_unpacklo_ps (__m128 __A, __m128 __B)
764*38fd1498Szrj {
765*38fd1498Szrj   return (__m128) __builtin_ia32_unpcklps ((__v4sf)__A, (__v4sf)__B);
766*38fd1498Szrj }
767*38fd1498Szrj 
768*38fd1498Szrj /* Sets the upper two SPFP values with 64-bits of data loaded from P;
769*38fd1498Szrj    the lower two values are passed through from A.  */
770*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_loadh_pi(__m128 __A,__m64 const * __P)771*38fd1498Szrj _mm_loadh_pi (__m128 __A, __m64 const *__P)
772*38fd1498Szrj {
773*38fd1498Szrj   return (__m128) __builtin_ia32_loadhps ((__v4sf)__A, (const __v2sf *)__P);
774*38fd1498Szrj }
775*38fd1498Szrj 
776*38fd1498Szrj /* Stores the upper two SPFP values of A into P.  */
777*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_storeh_pi(__m64 * __P,__m128 __A)778*38fd1498Szrj _mm_storeh_pi (__m64 *__P, __m128 __A)
779*38fd1498Szrj {
780*38fd1498Szrj   __builtin_ia32_storehps ((__v2sf *)__P, (__v4sf)__A);
781*38fd1498Szrj }
782*38fd1498Szrj 
783*38fd1498Szrj /* Moves the upper two values of B into the lower two values of A.  */
784*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_movehl_ps(__m128 __A,__m128 __B)785*38fd1498Szrj _mm_movehl_ps (__m128 __A, __m128 __B)
786*38fd1498Szrj {
787*38fd1498Szrj   return (__m128) __builtin_ia32_movhlps ((__v4sf)__A, (__v4sf)__B);
788*38fd1498Szrj }
789*38fd1498Szrj 
790*38fd1498Szrj /* Moves the lower two values of B into the upper two values of A.  */
791*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_movelh_ps(__m128 __A,__m128 __B)792*38fd1498Szrj _mm_movelh_ps (__m128 __A, __m128 __B)
793*38fd1498Szrj {
794*38fd1498Szrj   return (__m128) __builtin_ia32_movlhps ((__v4sf)__A, (__v4sf)__B);
795*38fd1498Szrj }
796*38fd1498Szrj 
797*38fd1498Szrj /* Sets the lower two SPFP values with 64-bits of data loaded from P;
798*38fd1498Szrj    the upper two values are passed through from A.  */
799*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_loadl_pi(__m128 __A,__m64 const * __P)800*38fd1498Szrj _mm_loadl_pi (__m128 __A, __m64 const *__P)
801*38fd1498Szrj {
802*38fd1498Szrj   return (__m128) __builtin_ia32_loadlps ((__v4sf)__A, (const __v2sf *)__P);
803*38fd1498Szrj }
804*38fd1498Szrj 
805*38fd1498Szrj /* Stores the lower two SPFP values of A into P.  */
806*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_storel_pi(__m64 * __P,__m128 __A)807*38fd1498Szrj _mm_storel_pi (__m64 *__P, __m128 __A)
808*38fd1498Szrj {
809*38fd1498Szrj   __builtin_ia32_storelps ((__v2sf *)__P, (__v4sf)__A);
810*38fd1498Szrj }
811*38fd1498Szrj 
812*38fd1498Szrj /* Creates a 4-bit mask from the most significant bits of the SPFP values.  */
813*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_movemask_ps(__m128 __A)814*38fd1498Szrj _mm_movemask_ps (__m128 __A)
815*38fd1498Szrj {
816*38fd1498Szrj   return __builtin_ia32_movmskps ((__v4sf)__A);
817*38fd1498Szrj }
818*38fd1498Szrj 
819*38fd1498Szrj /* Return the contents of the control register.  */
820*38fd1498Szrj extern __inline unsigned int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_getcsr(void)821*38fd1498Szrj _mm_getcsr (void)
822*38fd1498Szrj {
823*38fd1498Szrj   return __builtin_ia32_stmxcsr ();
824*38fd1498Szrj }
825*38fd1498Szrj 
826*38fd1498Szrj /* Read exception bits from the control register.  */
827*38fd1498Szrj extern __inline unsigned int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_GET_EXCEPTION_STATE(void)828*38fd1498Szrj _MM_GET_EXCEPTION_STATE (void)
829*38fd1498Szrj {
830*38fd1498Szrj   return _mm_getcsr() & _MM_EXCEPT_MASK;
831*38fd1498Szrj }
832*38fd1498Szrj 
833*38fd1498Szrj extern __inline unsigned int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_GET_EXCEPTION_MASK(void)834*38fd1498Szrj _MM_GET_EXCEPTION_MASK (void)
835*38fd1498Szrj {
836*38fd1498Szrj   return _mm_getcsr() & _MM_MASK_MASK;
837*38fd1498Szrj }
838*38fd1498Szrj 
839*38fd1498Szrj extern __inline unsigned int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_GET_ROUNDING_MODE(void)840*38fd1498Szrj _MM_GET_ROUNDING_MODE (void)
841*38fd1498Szrj {
842*38fd1498Szrj   return _mm_getcsr() & _MM_ROUND_MASK;
843*38fd1498Szrj }
844*38fd1498Szrj 
845*38fd1498Szrj extern __inline unsigned int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_GET_FLUSH_ZERO_MODE(void)846*38fd1498Szrj _MM_GET_FLUSH_ZERO_MODE (void)
847*38fd1498Szrj {
848*38fd1498Szrj   return _mm_getcsr() & _MM_FLUSH_ZERO_MASK;
849*38fd1498Szrj }
850*38fd1498Szrj 
851*38fd1498Szrj /* Set the control register to I.  */
852*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_setcsr(unsigned int __I)853*38fd1498Szrj _mm_setcsr (unsigned int __I)
854*38fd1498Szrj {
855*38fd1498Szrj   __builtin_ia32_ldmxcsr (__I);
856*38fd1498Szrj }
857*38fd1498Szrj 
858*38fd1498Szrj /* Set exception bits in the control register.  */
859*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_SET_EXCEPTION_STATE(unsigned int __mask)860*38fd1498Szrj _MM_SET_EXCEPTION_STATE(unsigned int __mask)
861*38fd1498Szrj {
862*38fd1498Szrj   _mm_setcsr((_mm_getcsr() & ~_MM_EXCEPT_MASK) | __mask);
863*38fd1498Szrj }
864*38fd1498Szrj 
865*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_SET_EXCEPTION_MASK(unsigned int __mask)866*38fd1498Szrj _MM_SET_EXCEPTION_MASK (unsigned int __mask)
867*38fd1498Szrj {
868*38fd1498Szrj   _mm_setcsr((_mm_getcsr() & ~_MM_MASK_MASK) | __mask);
869*38fd1498Szrj }
870*38fd1498Szrj 
871*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_SET_ROUNDING_MODE(unsigned int __mode)872*38fd1498Szrj _MM_SET_ROUNDING_MODE (unsigned int __mode)
873*38fd1498Szrj {
874*38fd1498Szrj   _mm_setcsr((_mm_getcsr() & ~_MM_ROUND_MASK) | __mode);
875*38fd1498Szrj }
876*38fd1498Szrj 
877*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_MM_SET_FLUSH_ZERO_MODE(unsigned int __mode)878*38fd1498Szrj _MM_SET_FLUSH_ZERO_MODE (unsigned int __mode)
879*38fd1498Szrj {
880*38fd1498Szrj   _mm_setcsr((_mm_getcsr() & ~_MM_FLUSH_ZERO_MASK) | __mode);
881*38fd1498Szrj }
882*38fd1498Szrj 
883*38fd1498Szrj /* Create a vector with element 0 as F and the rest zero.  */
884*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_set_ss(float __F)885*38fd1498Szrj _mm_set_ss (float __F)
886*38fd1498Szrj {
887*38fd1498Szrj   return __extension__ (__m128)(__v4sf){ __F, 0.0f, 0.0f, 0.0f };
888*38fd1498Szrj }
889*38fd1498Szrj 
890*38fd1498Szrj /* Create a vector with all four elements equal to F.  */
891*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_set1_ps(float __F)892*38fd1498Szrj _mm_set1_ps (float __F)
893*38fd1498Szrj {
894*38fd1498Szrj   return __extension__ (__m128)(__v4sf){ __F, __F, __F, __F };
895*38fd1498Szrj }
896*38fd1498Szrj 
897*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_set_ps1(float __F)898*38fd1498Szrj _mm_set_ps1 (float __F)
899*38fd1498Szrj {
900*38fd1498Szrj   return _mm_set1_ps (__F);
901*38fd1498Szrj }
902*38fd1498Szrj 
903*38fd1498Szrj /* Create a vector with element 0 as *P and the rest zero.  */
904*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_load_ss(float const * __P)905*38fd1498Szrj _mm_load_ss (float const *__P)
906*38fd1498Szrj {
907*38fd1498Szrj   return _mm_set_ss (*__P);
908*38fd1498Szrj }
909*38fd1498Szrj 
910*38fd1498Szrj /* Create a vector with all four elements equal to *P.  */
911*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_load1_ps(float const * __P)912*38fd1498Szrj _mm_load1_ps (float const *__P)
913*38fd1498Szrj {
914*38fd1498Szrj   return _mm_set1_ps (*__P);
915*38fd1498Szrj }
916*38fd1498Szrj 
917*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_load_ps1(float const * __P)918*38fd1498Szrj _mm_load_ps1 (float const *__P)
919*38fd1498Szrj {
920*38fd1498Szrj   return _mm_load1_ps (__P);
921*38fd1498Szrj }
922*38fd1498Szrj 
923*38fd1498Szrj /* Load four SPFP values from P.  The address must be 16-byte aligned.  */
924*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_load_ps(float const * __P)925*38fd1498Szrj _mm_load_ps (float const *__P)
926*38fd1498Szrj {
927*38fd1498Szrj   return *(__m128 *)__P;
928*38fd1498Szrj }
929*38fd1498Szrj 
930*38fd1498Szrj /* Load four SPFP values from P.  The address need not be 16-byte aligned.  */
931*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_loadu_ps(float const * __P)932*38fd1498Szrj _mm_loadu_ps (float const *__P)
933*38fd1498Szrj {
934*38fd1498Szrj   return *(__m128_u *)__P;
935*38fd1498Szrj }
936*38fd1498Szrj 
937*38fd1498Szrj /* Load four SPFP values in reverse order.  The address must be aligned.  */
938*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_loadr_ps(float const * __P)939*38fd1498Szrj _mm_loadr_ps (float const *__P)
940*38fd1498Szrj {
941*38fd1498Szrj   __v4sf __tmp = *(__v4sf *)__P;
942*38fd1498Szrj   return (__m128) __builtin_ia32_shufps (__tmp, __tmp, _MM_SHUFFLE (0,1,2,3));
943*38fd1498Szrj }
944*38fd1498Szrj 
945*38fd1498Szrj /* Create the vector [Z Y X W].  */
946*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_set_ps(const float __Z,const float __Y,const float __X,const float __W)947*38fd1498Szrj _mm_set_ps (const float __Z, const float __Y, const float __X, const float __W)
948*38fd1498Szrj {
949*38fd1498Szrj   return __extension__ (__m128)(__v4sf){ __W, __X, __Y, __Z };
950*38fd1498Szrj }
951*38fd1498Szrj 
952*38fd1498Szrj /* Create the vector [W X Y Z].  */
953*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_setr_ps(float __Z,float __Y,float __X,float __W)954*38fd1498Szrj _mm_setr_ps (float __Z, float __Y, float __X, float __W)
955*38fd1498Szrj {
956*38fd1498Szrj   return __extension__ (__m128)(__v4sf){ __Z, __Y, __X, __W };
957*38fd1498Szrj }
958*38fd1498Szrj 
959*38fd1498Szrj /* Stores the lower SPFP value.  */
960*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_store_ss(float * __P,__m128 __A)961*38fd1498Szrj _mm_store_ss (float *__P, __m128 __A)
962*38fd1498Szrj {
963*38fd1498Szrj   *__P = ((__v4sf)__A)[0];
964*38fd1498Szrj }
965*38fd1498Szrj 
966*38fd1498Szrj extern __inline float __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_cvtss_f32(__m128 __A)967*38fd1498Szrj _mm_cvtss_f32 (__m128 __A)
968*38fd1498Szrj {
969*38fd1498Szrj   return ((__v4sf)__A)[0];
970*38fd1498Szrj }
971*38fd1498Szrj 
972*38fd1498Szrj /* Store four SPFP values.  The address must be 16-byte aligned.  */
973*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_store_ps(float * __P,__m128 __A)974*38fd1498Szrj _mm_store_ps (float *__P, __m128 __A)
975*38fd1498Szrj {
976*38fd1498Szrj   *(__m128 *)__P = __A;
977*38fd1498Szrj }
978*38fd1498Szrj 
979*38fd1498Szrj /* Store four SPFP values.  The address need not be 16-byte aligned.  */
980*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_storeu_ps(float * __P,__m128 __A)981*38fd1498Szrj _mm_storeu_ps (float *__P, __m128 __A)
982*38fd1498Szrj {
983*38fd1498Szrj   *(__m128_u *)__P = __A;
984*38fd1498Szrj }
985*38fd1498Szrj 
986*38fd1498Szrj /* Store the lower SPFP value across four words.  */
987*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_store1_ps(float * __P,__m128 __A)988*38fd1498Szrj _mm_store1_ps (float *__P, __m128 __A)
989*38fd1498Szrj {
990*38fd1498Szrj   __v4sf __va = (__v4sf)__A;
991*38fd1498Szrj   __v4sf __tmp = __builtin_ia32_shufps (__va, __va, _MM_SHUFFLE (0,0,0,0));
992*38fd1498Szrj   _mm_storeu_ps (__P, __tmp);
993*38fd1498Szrj }
994*38fd1498Szrj 
995*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_store_ps1(float * __P,__m128 __A)996*38fd1498Szrj _mm_store_ps1 (float *__P, __m128 __A)
997*38fd1498Szrj {
998*38fd1498Szrj   _mm_store1_ps (__P, __A);
999*38fd1498Szrj }
1000*38fd1498Szrj 
1001*38fd1498Szrj /* Store four SPFP values in reverse order.  The address must be aligned.  */
1002*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_storer_ps(float * __P,__m128 __A)1003*38fd1498Szrj _mm_storer_ps (float *__P, __m128 __A)
1004*38fd1498Szrj {
1005*38fd1498Szrj   __v4sf __va = (__v4sf)__A;
1006*38fd1498Szrj   __v4sf __tmp = __builtin_ia32_shufps (__va, __va, _MM_SHUFFLE (0,1,2,3));
1007*38fd1498Szrj   _mm_store_ps (__P, __tmp);
1008*38fd1498Szrj }
1009*38fd1498Szrj 
1010*38fd1498Szrj /* Sets the low SPFP value of A from the low value of B.  */
1011*38fd1498Szrj extern __inline __m128 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_move_ss(__m128 __A,__m128 __B)1012*38fd1498Szrj _mm_move_ss (__m128 __A, __m128 __B)
1013*38fd1498Szrj {
1014*38fd1498Szrj   return (__m128) __builtin_ia32_movss ((__v4sf)__A, (__v4sf)__B);
1015*38fd1498Szrj }
1016*38fd1498Szrj 
1017*38fd1498Szrj /* Extracts one of the four words of A.  The selector N must be immediate.  */
1018*38fd1498Szrj #ifdef __OPTIMIZE__
1019*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_extract_pi16(__m64 const __A,int const __N)1020*38fd1498Szrj _mm_extract_pi16 (__m64 const __A, int const __N)
1021*38fd1498Szrj {
1022*38fd1498Szrj   return __builtin_ia32_vec_ext_v4hi ((__v4hi)__A, __N);
1023*38fd1498Szrj }
1024*38fd1498Szrj 
1025*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pextrw(__m64 const __A,int const __N)1026*38fd1498Szrj _m_pextrw (__m64 const __A, int const __N)
1027*38fd1498Szrj {
1028*38fd1498Szrj   return _mm_extract_pi16 (__A, __N);
1029*38fd1498Szrj }
1030*38fd1498Szrj #else
1031*38fd1498Szrj #define _mm_extract_pi16(A, N)	\
1032*38fd1498Szrj   ((int) __builtin_ia32_vec_ext_v4hi ((__v4hi)(__m64)(A), (int)(N)))
1033*38fd1498Szrj 
1034*38fd1498Szrj #define _m_pextrw(A, N) _mm_extract_pi16(A, N)
1035*38fd1498Szrj #endif
1036*38fd1498Szrj 
1037*38fd1498Szrj /* Inserts word D into one of four words of A.  The selector N must be
1038*38fd1498Szrj    immediate.  */
1039*38fd1498Szrj #ifdef __OPTIMIZE__
1040*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_insert_pi16(__m64 const __A,int const __D,int const __N)1041*38fd1498Szrj _mm_insert_pi16 (__m64 const __A, int const __D, int const __N)
1042*38fd1498Szrj {
1043*38fd1498Szrj   return (__m64) __builtin_ia32_vec_set_v4hi ((__v4hi)__A, __D, __N);
1044*38fd1498Szrj }
1045*38fd1498Szrj 
1046*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pinsrw(__m64 const __A,int const __D,int const __N)1047*38fd1498Szrj _m_pinsrw (__m64 const __A, int const __D, int const __N)
1048*38fd1498Szrj {
1049*38fd1498Szrj   return _mm_insert_pi16 (__A, __D, __N);
1050*38fd1498Szrj }
1051*38fd1498Szrj #else
1052*38fd1498Szrj #define _mm_insert_pi16(A, D, N)				\
1053*38fd1498Szrj   ((__m64) __builtin_ia32_vec_set_v4hi ((__v4hi)(__m64)(A),	\
1054*38fd1498Szrj 					(int)(D), (int)(N)))
1055*38fd1498Szrj 
1056*38fd1498Szrj #define _m_pinsrw(A, D, N) _mm_insert_pi16(A, D, N)
1057*38fd1498Szrj #endif
1058*38fd1498Szrj 
1059*38fd1498Szrj /* Compute the element-wise maximum of signed 16-bit values.  */
1060*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_max_pi16(__m64 __A,__m64 __B)1061*38fd1498Szrj _mm_max_pi16 (__m64 __A, __m64 __B)
1062*38fd1498Szrj {
1063*38fd1498Szrj   return (__m64) __builtin_ia32_pmaxsw ((__v4hi)__A, (__v4hi)__B);
1064*38fd1498Szrj }
1065*38fd1498Szrj 
1066*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pmaxsw(__m64 __A,__m64 __B)1067*38fd1498Szrj _m_pmaxsw (__m64 __A, __m64 __B)
1068*38fd1498Szrj {
1069*38fd1498Szrj   return _mm_max_pi16 (__A, __B);
1070*38fd1498Szrj }
1071*38fd1498Szrj 
1072*38fd1498Szrj /* Compute the element-wise maximum of unsigned 8-bit values.  */
1073*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_max_pu8(__m64 __A,__m64 __B)1074*38fd1498Szrj _mm_max_pu8 (__m64 __A, __m64 __B)
1075*38fd1498Szrj {
1076*38fd1498Szrj   return (__m64) __builtin_ia32_pmaxub ((__v8qi)__A, (__v8qi)__B);
1077*38fd1498Szrj }
1078*38fd1498Szrj 
1079*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pmaxub(__m64 __A,__m64 __B)1080*38fd1498Szrj _m_pmaxub (__m64 __A, __m64 __B)
1081*38fd1498Szrj {
1082*38fd1498Szrj   return _mm_max_pu8 (__A, __B);
1083*38fd1498Szrj }
1084*38fd1498Szrj 
1085*38fd1498Szrj /* Compute the element-wise minimum of signed 16-bit values.  */
1086*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_min_pi16(__m64 __A,__m64 __B)1087*38fd1498Szrj _mm_min_pi16 (__m64 __A, __m64 __B)
1088*38fd1498Szrj {
1089*38fd1498Szrj   return (__m64) __builtin_ia32_pminsw ((__v4hi)__A, (__v4hi)__B);
1090*38fd1498Szrj }
1091*38fd1498Szrj 
1092*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pminsw(__m64 __A,__m64 __B)1093*38fd1498Szrj _m_pminsw (__m64 __A, __m64 __B)
1094*38fd1498Szrj {
1095*38fd1498Szrj   return _mm_min_pi16 (__A, __B);
1096*38fd1498Szrj }
1097*38fd1498Szrj 
1098*38fd1498Szrj /* Compute the element-wise minimum of unsigned 8-bit values.  */
1099*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_min_pu8(__m64 __A,__m64 __B)1100*38fd1498Szrj _mm_min_pu8 (__m64 __A, __m64 __B)
1101*38fd1498Szrj {
1102*38fd1498Szrj   return (__m64) __builtin_ia32_pminub ((__v8qi)__A, (__v8qi)__B);
1103*38fd1498Szrj }
1104*38fd1498Szrj 
1105*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pminub(__m64 __A,__m64 __B)1106*38fd1498Szrj _m_pminub (__m64 __A, __m64 __B)
1107*38fd1498Szrj {
1108*38fd1498Szrj   return _mm_min_pu8 (__A, __B);
1109*38fd1498Szrj }
1110*38fd1498Szrj 
1111*38fd1498Szrj /* Create an 8-bit mask of the signs of 8-bit values.  */
1112*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_movemask_pi8(__m64 __A)1113*38fd1498Szrj _mm_movemask_pi8 (__m64 __A)
1114*38fd1498Szrj {
1115*38fd1498Szrj   return __builtin_ia32_pmovmskb ((__v8qi)__A);
1116*38fd1498Szrj }
1117*38fd1498Szrj 
1118*38fd1498Szrj extern __inline int __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pmovmskb(__m64 __A)1119*38fd1498Szrj _m_pmovmskb (__m64 __A)
1120*38fd1498Szrj {
1121*38fd1498Szrj   return _mm_movemask_pi8 (__A);
1122*38fd1498Szrj }
1123*38fd1498Szrj 
1124*38fd1498Szrj /* Multiply four unsigned 16-bit values in A by four unsigned 16-bit values
1125*38fd1498Szrj    in B and produce the high 16 bits of the 32-bit results.  */
1126*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_mulhi_pu16(__m64 __A,__m64 __B)1127*38fd1498Szrj _mm_mulhi_pu16 (__m64 __A, __m64 __B)
1128*38fd1498Szrj {
1129*38fd1498Szrj   return (__m64) __builtin_ia32_pmulhuw ((__v4hi)__A, (__v4hi)__B);
1130*38fd1498Szrj }
1131*38fd1498Szrj 
1132*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pmulhuw(__m64 __A,__m64 __B)1133*38fd1498Szrj _m_pmulhuw (__m64 __A, __m64 __B)
1134*38fd1498Szrj {
1135*38fd1498Szrj   return _mm_mulhi_pu16 (__A, __B);
1136*38fd1498Szrj }
1137*38fd1498Szrj 
1138*38fd1498Szrj /* Return a combination of the four 16-bit values in A.  The selector
1139*38fd1498Szrj    must be an immediate.  */
1140*38fd1498Szrj #ifdef __OPTIMIZE__
1141*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_shuffle_pi16(__m64 __A,int const __N)1142*38fd1498Szrj _mm_shuffle_pi16 (__m64 __A, int const __N)
1143*38fd1498Szrj {
1144*38fd1498Szrj   return (__m64) __builtin_ia32_pshufw ((__v4hi)__A, __N);
1145*38fd1498Szrj }
1146*38fd1498Szrj 
1147*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pshufw(__m64 __A,int const __N)1148*38fd1498Szrj _m_pshufw (__m64 __A, int const __N)
1149*38fd1498Szrj {
1150*38fd1498Szrj   return _mm_shuffle_pi16 (__A, __N);
1151*38fd1498Szrj }
1152*38fd1498Szrj #else
1153*38fd1498Szrj #define _mm_shuffle_pi16(A, N) \
1154*38fd1498Szrj   ((__m64) __builtin_ia32_pshufw ((__v4hi)(__m64)(A), (int)(N)))
1155*38fd1498Szrj 
1156*38fd1498Szrj #define _m_pshufw(A, N) _mm_shuffle_pi16 (A, N)
1157*38fd1498Szrj #endif
1158*38fd1498Szrj 
1159*38fd1498Szrj /* Conditionally store byte elements of A into P.  The high bit of each
1160*38fd1498Szrj    byte in the selector N determines whether the corresponding byte from
1161*38fd1498Szrj    A is stored.  */
1162*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_maskmove_si64(__m64 __A,__m64 __N,char * __P)1163*38fd1498Szrj _mm_maskmove_si64 (__m64 __A, __m64 __N, char *__P)
1164*38fd1498Szrj {
1165*38fd1498Szrj   __builtin_ia32_maskmovq ((__v8qi)__A, (__v8qi)__N, __P);
1166*38fd1498Szrj }
1167*38fd1498Szrj 
1168*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_maskmovq(__m64 __A,__m64 __N,char * __P)1169*38fd1498Szrj _m_maskmovq (__m64 __A, __m64 __N, char *__P)
1170*38fd1498Szrj {
1171*38fd1498Szrj   _mm_maskmove_si64 (__A, __N, __P);
1172*38fd1498Szrj }
1173*38fd1498Szrj 
1174*38fd1498Szrj /* Compute the rounded averages of the unsigned 8-bit values in A and B.  */
1175*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_avg_pu8(__m64 __A,__m64 __B)1176*38fd1498Szrj _mm_avg_pu8 (__m64 __A, __m64 __B)
1177*38fd1498Szrj {
1178*38fd1498Szrj   return (__m64) __builtin_ia32_pavgb ((__v8qi)__A, (__v8qi)__B);
1179*38fd1498Szrj }
1180*38fd1498Szrj 
1181*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pavgb(__m64 __A,__m64 __B)1182*38fd1498Szrj _m_pavgb (__m64 __A, __m64 __B)
1183*38fd1498Szrj {
1184*38fd1498Szrj   return _mm_avg_pu8 (__A, __B);
1185*38fd1498Szrj }
1186*38fd1498Szrj 
1187*38fd1498Szrj /* Compute the rounded averages of the unsigned 16-bit values in A and B.  */
1188*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_avg_pu16(__m64 __A,__m64 __B)1189*38fd1498Szrj _mm_avg_pu16 (__m64 __A, __m64 __B)
1190*38fd1498Szrj {
1191*38fd1498Szrj   return (__m64) __builtin_ia32_pavgw ((__v4hi)__A, (__v4hi)__B);
1192*38fd1498Szrj }
1193*38fd1498Szrj 
1194*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_pavgw(__m64 __A,__m64 __B)1195*38fd1498Szrj _m_pavgw (__m64 __A, __m64 __B)
1196*38fd1498Szrj {
1197*38fd1498Szrj   return _mm_avg_pu16 (__A, __B);
1198*38fd1498Szrj }
1199*38fd1498Szrj 
1200*38fd1498Szrj /* Compute the sum of the absolute differences of the unsigned 8-bit
1201*38fd1498Szrj    values in A and B.  Return the value in the lower 16-bit word; the
1202*38fd1498Szrj    upper words are cleared.  */
1203*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sad_pu8(__m64 __A,__m64 __B)1204*38fd1498Szrj _mm_sad_pu8 (__m64 __A, __m64 __B)
1205*38fd1498Szrj {
1206*38fd1498Szrj   return (__m64) __builtin_ia32_psadbw ((__v8qi)__A, (__v8qi)__B);
1207*38fd1498Szrj }
1208*38fd1498Szrj 
1209*38fd1498Szrj extern __inline __m64 __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_m_psadbw(__m64 __A,__m64 __B)1210*38fd1498Szrj _m_psadbw (__m64 __A, __m64 __B)
1211*38fd1498Szrj {
1212*38fd1498Szrj   return _mm_sad_pu8 (__A, __B);
1213*38fd1498Szrj }
1214*38fd1498Szrj 
1215*38fd1498Szrj /* Stores the data in A to the address P without polluting the caches.  */
1216*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_stream_pi(__m64 * __P,__m64 __A)1217*38fd1498Szrj _mm_stream_pi (__m64 *__P, __m64 __A)
1218*38fd1498Szrj {
1219*38fd1498Szrj   __builtin_ia32_movntq ((unsigned long long *)__P, (unsigned long long)__A);
1220*38fd1498Szrj }
1221*38fd1498Szrj 
1222*38fd1498Szrj /* Likewise.  The address must be 16-byte aligned.  */
1223*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_stream_ps(float * __P,__m128 __A)1224*38fd1498Szrj _mm_stream_ps (float *__P, __m128 __A)
1225*38fd1498Szrj {
1226*38fd1498Szrj   __builtin_ia32_movntps (__P, (__v4sf)__A);
1227*38fd1498Szrj }
1228*38fd1498Szrj 
1229*38fd1498Szrj /* Guarantees that every preceding store is globally visible before
1230*38fd1498Szrj    any subsequent store.  */
1231*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_sfence(void)1232*38fd1498Szrj _mm_sfence (void)
1233*38fd1498Szrj {
1234*38fd1498Szrj   __builtin_ia32_sfence ();
1235*38fd1498Szrj }
1236*38fd1498Szrj 
1237*38fd1498Szrj /* Transpose the 4x4 matrix composed of row[0-3].  */
1238*38fd1498Szrj #define _MM_TRANSPOSE4_PS(row0, row1, row2, row3)			\
1239*38fd1498Szrj do {									\
1240*38fd1498Szrj   __v4sf __r0 = (row0), __r1 = (row1), __r2 = (row2), __r3 = (row3);	\
1241*38fd1498Szrj   __v4sf __t0 = __builtin_ia32_unpcklps (__r0, __r1);			\
1242*38fd1498Szrj   __v4sf __t1 = __builtin_ia32_unpcklps (__r2, __r3);			\
1243*38fd1498Szrj   __v4sf __t2 = __builtin_ia32_unpckhps (__r0, __r1);			\
1244*38fd1498Szrj   __v4sf __t3 = __builtin_ia32_unpckhps (__r2, __r3);			\
1245*38fd1498Szrj   (row0) = __builtin_ia32_movlhps (__t0, __t1);				\
1246*38fd1498Szrj   (row1) = __builtin_ia32_movhlps (__t1, __t0);				\
1247*38fd1498Szrj   (row2) = __builtin_ia32_movlhps (__t2, __t3);				\
1248*38fd1498Szrj   (row3) = __builtin_ia32_movhlps (__t3, __t2);				\
1249*38fd1498Szrj } while (0)
1250*38fd1498Szrj 
1251*38fd1498Szrj /* For backward source compatibility.  */
1252*38fd1498Szrj # include <emmintrin.h>
1253*38fd1498Szrj 
1254*38fd1498Szrj #ifdef __DISABLE_SSE__
1255*38fd1498Szrj #undef __DISABLE_SSE__
1256*38fd1498Szrj #pragma GCC pop_options
1257*38fd1498Szrj #endif /* __DISABLE_SSE__ */
1258*38fd1498Szrj 
1259*38fd1498Szrj /* The execution of the next instruction is delayed by an implementation
1260*38fd1498Szrj    specific amount of time.  The instruction does not modify the
1261*38fd1498Szrj    architectural state.  This is after the pop_options pragma because
1262*38fd1498Szrj    it does not require SSE support in the processor--the encoding is a
1263*38fd1498Szrj    nop on processors that do not support it.  */
1264*38fd1498Szrj extern __inline void __attribute__((__gnu_inline__, __always_inline__, __artificial__))
_mm_pause(void)1265*38fd1498Szrj _mm_pause (void)
1266*38fd1498Szrj {
1267*38fd1498Szrj   __builtin_ia32_pause ();
1268*38fd1498Szrj }
1269*38fd1498Szrj 
1270*38fd1498Szrj #endif /* _XMMINTRIN_H_INCLUDED */
1271