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