1117395Skan/* PowerPC E500 user include file.
2169689Skan   Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc.
3117395Skan   Contributed by Aldy Hernandez (aldyh@redhat.com).
4117395Skan
5132718Skan   This file is part of GCC.
6117395Skan
7132718Skan   GCC is free software; you can redistribute it and/or modify it
8132718Skan   under the terms of the GNU General Public License as published
9132718Skan   by the Free Software Foundation; either version 2, or (at your
10132718Skan   option) any later version.
11117395Skan
12132718Skan   GCC is distributed in the hope that it will be useful, but WITHOUT
13132718Skan   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14132718Skan   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
15132718Skan   License for more details.
16117395Skan
17132718Skan   You should have received a copy of the GNU General Public License
18132718Skan   along with GCC; see the file COPYING.  If not, write to the
19169689Skan   Free Software Foundation, 51 Franklin Street, Fifth Floor, Boston,
20169689Skan   MA 02110-1301, USA.  */
21117395Skan
22117395Skan/* As a special exception, if you include this header file into source
23117395Skan   files compiled by GCC, this header file does not by itself cause
24117395Skan   the resulting executable to be covered by the GNU General Public
25117395Skan   License.  This exception does not however invalidate any other
26117395Skan   reasons why the executable file might be covered by the GNU General
27117395Skan   Public License.  */
28117395Skan
29117395Skan#ifndef _SPE_H
30117395Skan#define _SPE_H
31117395Skan
32117395Skan#define __vector __attribute__((vector_size(8)))
33117395Skan
34117395Skantypedef int 	 		int32_t;
35117395Skantypedef unsigned 		uint32_t;
36117395Skantypedef short    		int16_t;
37117395Skantypedef unsigned short  	uint16_t;
38117395Skantypedef long long 		int64_t;
39117395Skantypedef unsigned long long	uint64_t;
40117395Skan
41117395Skantypedef short 			__vector __ev64_s16__;
42117395Skantypedef unsigned short  	__vector __ev64_u16__;
43117395Skantypedef int 			__vector __ev64_s32__;
44117395Skantypedef unsigned 		__vector __ev64_u32__;
45117395Skantypedef long long 		__vector __ev64_s64__;
46117395Skantypedef unsigned long long 	__vector __ev64_u64__;
47117395Skantypedef float 			__vector __ev64_fs__;
48117395Skan
49117395Skan#define __v2si __ev64_opaque__
50117395Skan#define __v2sf __ev64_fs__
51117395Skan
52132718Skan#define __ev_addw __builtin_spe_evaddw
53132718Skan#define __ev_addiw __builtin_spe_evaddiw
54132718Skan#define __ev_subfw(a,b) __builtin_spe_evsubfw ((b), (a))
55132718Skan#define __ev_subw __builtin_spe_evsubfw
56132718Skan#define __ev_subifw(a,b) __builtin_spe_evsubifw ((b), (a))
57132718Skan#define __ev_subiw __builtin_spe_evsubifw
58132718Skan#define __ev_abs __builtin_spe_evabs
59132718Skan#define __ev_neg __builtin_spe_evneg
60132718Skan#define __ev_extsb __builtin_spe_evextsb
61132718Skan#define __ev_extsh __builtin_spe_evextsh
62132718Skan#define __ev_and __builtin_spe_evand
63132718Skan#define __ev_or __builtin_spe_evor
64132718Skan#define __ev_xor __builtin_spe_evxor
65132718Skan#define __ev_nand __builtin_spe_evnand
66132718Skan#define __ev_nor __builtin_spe_evnor
67132718Skan#define __ev_eqv __builtin_spe_eveqv
68132718Skan#define __ev_andc __builtin_spe_evandc
69132718Skan#define __ev_orc __builtin_spe_evorc
70132718Skan#define __ev_rlw __builtin_spe_evrlw
71132718Skan#define __ev_rlwi __builtin_spe_evrlwi
72132718Skan#define __ev_slw __builtin_spe_evslw
73132718Skan#define __ev_slwi __builtin_spe_evslwi
74132718Skan#define __ev_srws __builtin_spe_evsrws
75132718Skan#define __ev_srwu __builtin_spe_evsrwu
76132718Skan#define __ev_srwis __builtin_spe_evsrwis
77132718Skan#define __ev_srwiu __builtin_spe_evsrwiu
78132718Skan#define __ev_cntlzw __builtin_spe_evcntlzw
79132718Skan#define __ev_cntlsw __builtin_spe_evcntlsw
80132718Skan#define __ev_rndw __builtin_spe_evrndw
81132718Skan#define __ev_mergehi __builtin_spe_evmergehi
82132718Skan#define __ev_mergelo __builtin_spe_evmergelo
83132718Skan#define __ev_mergelohi __builtin_spe_evmergelohi
84132718Skan#define __ev_mergehilo __builtin_spe_evmergehilo
85132718Skan#define __ev_splati __builtin_spe_evsplati
86132718Skan#define __ev_splatfi __builtin_spe_evsplatfi
87132718Skan#define __ev_divws __builtin_spe_evdivws
88132718Skan#define __ev_divwu __builtin_spe_evdivwu
89132718Skan#define __ev_mra __builtin_spe_evmra
90117395Skan
91117395Skan#define __brinc __builtin_spe_brinc
92117395Skan
93117395Skan/* Loads.  */
94117395Skan
95132718Skan#define __ev_lddx __builtin_spe_evlddx
96132718Skan#define __ev_ldwx __builtin_spe_evldwx
97132718Skan#define __ev_ldhx __builtin_spe_evldhx
98132718Skan#define __ev_lwhex __builtin_spe_evlwhex
99132718Skan#define __ev_lwhoux __builtin_spe_evlwhoux
100132718Skan#define __ev_lwhosx __builtin_spe_evlwhosx
101132718Skan#define __ev_lwwsplatx __builtin_spe_evlwwsplatx
102132718Skan#define __ev_lwhsplatx __builtin_spe_evlwhsplatx
103132718Skan#define __ev_lhhesplatx __builtin_spe_evlhhesplatx
104132718Skan#define __ev_lhhousplatx __builtin_spe_evlhhousplatx
105132718Skan#define __ev_lhhossplatx __builtin_spe_evlhhossplatx
106132718Skan#define __ev_ldd __builtin_spe_evldd
107132718Skan#define __ev_ldw __builtin_spe_evldw
108132718Skan#define __ev_ldh __builtin_spe_evldh
109132718Skan#define __ev_lwhe __builtin_spe_evlwhe
110132718Skan#define __ev_lwhou __builtin_spe_evlwhou
111132718Skan#define __ev_lwhos __builtin_spe_evlwhos
112132718Skan#define __ev_lwwsplat __builtin_spe_evlwwsplat
113132718Skan#define __ev_lwhsplat __builtin_spe_evlwhsplat
114132718Skan#define __ev_lhhesplat __builtin_spe_evlhhesplat
115132718Skan#define __ev_lhhousplat __builtin_spe_evlhhousplat
116132718Skan#define __ev_lhhossplat __builtin_spe_evlhhossplat
117117395Skan
118117395Skan/* Stores.  */
119117395Skan
120132718Skan#define __ev_stddx __builtin_spe_evstddx
121132718Skan#define __ev_stdwx __builtin_spe_evstdwx
122132718Skan#define __ev_stdhx __builtin_spe_evstdhx
123132718Skan#define __ev_stwwex __builtin_spe_evstwwex
124132718Skan#define __ev_stwwox __builtin_spe_evstwwox
125132718Skan#define __ev_stwhex __builtin_spe_evstwhex
126132718Skan#define __ev_stwhox __builtin_spe_evstwhox
127132718Skan#define __ev_stdd __builtin_spe_evstdd
128132718Skan#define __ev_stdw __builtin_spe_evstdw
129132718Skan#define __ev_stdh __builtin_spe_evstdh
130132718Skan#define __ev_stwwe __builtin_spe_evstwwe
131132718Skan#define __ev_stwwo __builtin_spe_evstwwo
132132718Skan#define __ev_stwhe __builtin_spe_evstwhe
133132718Skan#define __ev_stwho __builtin_spe_evstwho
134117395Skan
135117395Skan/* Fixed point complex.  */
136117395Skan
137132718Skan#define __ev_mhossf __builtin_spe_evmhossf
138132718Skan#define __ev_mhosmf __builtin_spe_evmhosmf
139132718Skan#define __ev_mhosmi __builtin_spe_evmhosmi
140132718Skan#define __ev_mhoumi __builtin_spe_evmhoumi
141132718Skan#define __ev_mhessf __builtin_spe_evmhessf
142132718Skan#define __ev_mhesmf __builtin_spe_evmhesmf
143132718Skan#define __ev_mhesmi __builtin_spe_evmhesmi
144132718Skan#define __ev_mheumi __builtin_spe_evmheumi
145132718Skan#define __ev_mhossfa __builtin_spe_evmhossfa
146132718Skan#define __ev_mhosmfa __builtin_spe_evmhosmfa
147132718Skan#define __ev_mhosmia __builtin_spe_evmhosmia
148132718Skan#define __ev_mhoumia __builtin_spe_evmhoumia
149132718Skan#define __ev_mhessfa __builtin_spe_evmhessfa
150132718Skan#define __ev_mhesmfa __builtin_spe_evmhesmfa
151132718Skan#define __ev_mhesmia __builtin_spe_evmhesmia
152132718Skan#define __ev_mheumia __builtin_spe_evmheumia
153117395Skan
154117395Skan#define __ev_mhoumf __ev_mhoumi
155117395Skan#define __ev_mheumf __ev_mheumi
156117395Skan#define __ev_mhoumfa __ev_mhoumia
157117395Skan#define __ev_mheumfa __ev_mheumia
158117395Skan
159132718Skan#define __ev_mhossfaaw __builtin_spe_evmhossfaaw
160132718Skan#define __ev_mhossiaaw __builtin_spe_evmhossiaaw
161132718Skan#define __ev_mhosmfaaw __builtin_spe_evmhosmfaaw
162132718Skan#define __ev_mhosmiaaw __builtin_spe_evmhosmiaaw
163132718Skan#define __ev_mhousiaaw __builtin_spe_evmhousiaaw
164132718Skan#define __ev_mhoumiaaw __builtin_spe_evmhoumiaaw
165132718Skan#define __ev_mhessfaaw __builtin_spe_evmhessfaaw
166132718Skan#define __ev_mhessiaaw __builtin_spe_evmhessiaaw
167132718Skan#define __ev_mhesmfaaw __builtin_spe_evmhesmfaaw
168132718Skan#define __ev_mhesmiaaw __builtin_spe_evmhesmiaaw
169132718Skan#define __ev_mheusiaaw __builtin_spe_evmheusiaaw
170132718Skan#define __ev_mheumiaaw __builtin_spe_evmheumiaaw
171117395Skan
172117395Skan#define __ev_mhousfaaw __ev_mhousiaaw
173117395Skan#define __ev_mhoumfaaw __ev_mhoumiaaw
174117395Skan#define __ev_mheusfaaw __ev_mheusiaaw
175117395Skan#define __ev_mheumfaaw __ev_mheumiaaw
176117395Skan
177132718Skan#define __ev_mhossfanw __builtin_spe_evmhossfanw
178132718Skan#define __ev_mhossianw __builtin_spe_evmhossianw
179132718Skan#define __ev_mhosmfanw __builtin_spe_evmhosmfanw
180132718Skan#define __ev_mhosmianw __builtin_spe_evmhosmianw
181132718Skan#define __ev_mhousianw __builtin_spe_evmhousianw
182132718Skan#define __ev_mhoumianw __builtin_spe_evmhoumianw
183132718Skan#define __ev_mhessfanw __builtin_spe_evmhessfanw
184132718Skan#define __ev_mhessianw __builtin_spe_evmhessianw
185132718Skan#define __ev_mhesmfanw __builtin_spe_evmhesmfanw
186132718Skan#define __ev_mhesmianw __builtin_spe_evmhesmianw
187132718Skan#define __ev_mheusianw __builtin_spe_evmheusianw
188132718Skan#define __ev_mheumianw __builtin_spe_evmheumianw
189117395Skan
190117395Skan#define __ev_mhousfanw __ev_mhousianw
191117395Skan#define __ev_mhoumfanw __ev_mhoumianw
192117395Skan#define __ev_mheusfanw __ev_mheusianw
193117395Skan#define __ev_mheumfanw __ev_mheumianw
194117395Skan
195132718Skan#define __ev_mhogsmfaa __builtin_spe_evmhogsmfaa
196132718Skan#define __ev_mhogsmiaa __builtin_spe_evmhogsmiaa
197132718Skan#define __ev_mhogumiaa __builtin_spe_evmhogumiaa
198132718Skan#define __ev_mhegsmfaa __builtin_spe_evmhegsmfaa
199132718Skan#define __ev_mhegsmiaa __builtin_spe_evmhegsmiaa
200132718Skan#define __ev_mhegumiaa __builtin_spe_evmhegumiaa
201117395Skan
202117395Skan#define __ev_mhogumfaa __ev_mhogumiaa
203117395Skan#define __ev_mhegumfaa __ev_mhegumiaa
204117395Skan
205132718Skan#define __ev_mhogsmfan __builtin_spe_evmhogsmfan
206132718Skan#define __ev_mhogsmian __builtin_spe_evmhogsmian
207132718Skan#define __ev_mhogumian __builtin_spe_evmhogumian
208132718Skan#define __ev_mhegsmfan __builtin_spe_evmhegsmfan
209132718Skan#define __ev_mhegsmian __builtin_spe_evmhegsmian
210132718Skan#define __ev_mhegumian __builtin_spe_evmhegumian
211117395Skan
212117395Skan#define __ev_mhogumfan __ev_mhogumian
213117395Skan#define __ev_mhegumfan __ev_mhegumian
214117395Skan
215132718Skan#define __ev_mwhssf __builtin_spe_evmwhssf
216132718Skan#define __ev_mwhsmf __builtin_spe_evmwhsmf
217132718Skan#define __ev_mwhsmi __builtin_spe_evmwhsmi
218132718Skan#define __ev_mwhumi __builtin_spe_evmwhumi
219132718Skan#define __ev_mwhssfa __builtin_spe_evmwhssfa
220132718Skan#define __ev_mwhsmfa __builtin_spe_evmwhsmfa
221132718Skan#define __ev_mwhsmia __builtin_spe_evmwhsmia
222132718Skan#define __ev_mwhumia __builtin_spe_evmwhumia
223117395Skan
224117395Skan#define __ev_mwhumf __ev_mwhumi
225117395Skan#define __ev_mwhumfa __ev_mwhumia
226117395Skan
227132718Skan#define __ev_mwlumi __builtin_spe_evmwlumi
228132718Skan#define __ev_mwlumia __builtin_spe_evmwlumia
229132718Skan#define __ev_mwlumiaaw __builtin_spe_evmwlumiaaw
230117395Skan
231132718Skan#define __ev_mwlssiaaw __builtin_spe_evmwlssiaaw
232132718Skan#define __ev_mwlsmiaaw __builtin_spe_evmwlsmiaaw
233132718Skan#define __ev_mwlusiaaw __builtin_spe_evmwlusiaaw
234132718Skan#define __ev_mwlusiaaw __builtin_spe_evmwlusiaaw
235117395Skan
236132718Skan#define __ev_mwlssianw __builtin_spe_evmwlssianw
237132718Skan#define __ev_mwlsmianw __builtin_spe_evmwlsmianw
238132718Skan#define __ev_mwlusianw __builtin_spe_evmwlusianw
239132718Skan#define __ev_mwlumianw __builtin_spe_evmwlumianw
240117395Skan
241132718Skan#define __ev_mwssf __builtin_spe_evmwssf
242132718Skan#define __ev_mwsmf __builtin_spe_evmwsmf
243132718Skan#define __ev_mwsmi __builtin_spe_evmwsmi
244132718Skan#define __ev_mwumi __builtin_spe_evmwumi
245132718Skan#define __ev_mwssfa __builtin_spe_evmwssfa
246132718Skan#define __ev_mwsmfa __builtin_spe_evmwsmfa
247132718Skan#define __ev_mwsmia __builtin_spe_evmwsmia
248132718Skan#define __ev_mwumia __builtin_spe_evmwumia
249117395Skan
250117395Skan#define __ev_mwumf __ev_mwumi
251117395Skan#define __ev_mwumfa __ev_mwumia
252117395Skan
253132718Skan#define __ev_mwssfaa __builtin_spe_evmwssfaa
254132718Skan#define __ev_mwsmfaa __builtin_spe_evmwsmfaa
255132718Skan#define __ev_mwsmiaa __builtin_spe_evmwsmiaa
256132718Skan#define __ev_mwumiaa __builtin_spe_evmwumiaa
257117395Skan
258117395Skan#define __ev_mwumfaa __ev_mwumiaa
259117395Skan
260132718Skan#define __ev_mwssfan __builtin_spe_evmwssfan
261132718Skan#define __ev_mwsmfan __builtin_spe_evmwsmfan
262132718Skan#define __ev_mwsmian __builtin_spe_evmwsmian
263132718Skan#define __ev_mwumian __builtin_spe_evmwumian
264117395Skan
265117395Skan#define __ev_mwumfan __ev_mwumian
266117395Skan
267132718Skan#define __ev_addssiaaw __builtin_spe_evaddssiaaw
268132718Skan#define __ev_addsmiaaw __builtin_spe_evaddsmiaaw
269132718Skan#define __ev_addusiaaw __builtin_spe_evaddusiaaw
270132718Skan#define __ev_addumiaaw __builtin_spe_evaddumiaaw
271117395Skan
272117395Skan#define __ev_addusfaaw __ev_addusiaaw
273117395Skan#define __ev_addumfaaw __ev_addumiaaw
274117395Skan#define __ev_addsmfaaw __ev_addsmiaaw
275117395Skan#define __ev_addssfaaw __ev_addssiaaw
276117395Skan
277132718Skan#define __ev_subfssiaaw __builtin_spe_evsubfssiaaw
278132718Skan#define __ev_subfsmiaaw __builtin_spe_evsubfsmiaaw
279132718Skan#define __ev_subfusiaaw __builtin_spe_evsubfusiaaw
280132718Skan#define __ev_subfumiaaw __builtin_spe_evsubfumiaaw
281117395Skan
282117395Skan#define __ev_subfusfaaw __ev_subfusiaaw
283117395Skan#define __ev_subfumfaaw __ev_subfumiaaw
284117395Skan#define __ev_subfsmfaaw __ev_subfsmiaaw
285117395Skan#define __ev_subfssfaaw __ev_subfssiaaw
286117395Skan
287117395Skan/* Floating Point SIMD Instructions  */
288117395Skan
289132718Skan#define __ev_fsabs __builtin_spe_evfsabs
290132718Skan#define __ev_fsnabs __builtin_spe_evfsnabs
291132718Skan#define __ev_fsneg __builtin_spe_evfsneg
292132718Skan#define __ev_fsadd __builtin_spe_evfsadd
293132718Skan#define __ev_fssub __builtin_spe_evfssub
294132718Skan#define __ev_fsmul __builtin_spe_evfsmul
295132718Skan#define __ev_fsdiv __builtin_spe_evfsdiv
296132718Skan#define __ev_fscfui __builtin_spe_evfscfui
297132718Skan#define __ev_fscfsi __builtin_spe_evfscfsi
298132718Skan#define __ev_fscfuf __builtin_spe_evfscfuf
299132718Skan#define __ev_fscfsf __builtin_spe_evfscfsf
300132718Skan#define __ev_fsctui __builtin_spe_evfsctui
301132718Skan#define __ev_fsctsi __builtin_spe_evfsctsi
302132718Skan#define __ev_fsctuf __builtin_spe_evfsctuf
303132718Skan#define __ev_fsctsf __builtin_spe_evfsctsf
304132718Skan#define __ev_fsctuiz __builtin_spe_evfsctuiz
305132718Skan#define __ev_fsctsiz __builtin_spe_evfsctsiz
306117395Skan
307117395Skan/* NOT SUPPORTED IN FIRST e500, support via two instructions:  */
308117395Skan
309117395Skan#define __ev_mwhusfaaw  __ev_mwhusiaaw
310117395Skan#define __ev_mwhumfaaw  __ev_mwhumiaaw
311117395Skan#define __ev_mwhusfanw  __ev_mwhusianw
312117395Skan#define __ev_mwhumfanw  __ev_mwhumianw
313117395Skan#define __ev_mwhgumfaa  __ev_mwhgumiaa
314117395Skan#define __ev_mwhgumfan  __ev_mwhgumian
315117395Skan
316132718Skan#define __ev_mwhgssfaa __internal_ev_mwhgssfaa
317132718Skan#define __ev_mwhgsmfaa __internal_ev_mwhgsmfaa
318132718Skan#define __ev_mwhgsmiaa __internal_ev_mwhgsmiaa
319132718Skan#define __ev_mwhgumiaa __internal_ev_mwhgumiaa
320132718Skan#define __ev_mwhgssfan __internal_ev_mwhgssfan
321132718Skan#define __ev_mwhgsmfan __internal_ev_mwhgsmfan
322132718Skan#define __ev_mwhgsmian __internal_ev_mwhgsmian
323132718Skan#define __ev_mwhgumian __internal_ev_mwhgumian
324132718Skan#define __ev_mwhssiaaw __internal_ev_mwhssiaaw
325132718Skan#define __ev_mwhssfaaw __internal_ev_mwhssfaaw
326132718Skan#define __ev_mwhsmfaaw __internal_ev_mwhsmfaaw
327132718Skan#define __ev_mwhsmiaaw __internal_ev_mwhsmiaaw
328132718Skan#define __ev_mwhusiaaw __internal_ev_mwhusiaaw
329132718Skan#define __ev_mwhumiaaw __internal_ev_mwhumiaaw
330132718Skan#define __ev_mwhssfanw __internal_ev_mwhssfanw
331132718Skan#define __ev_mwhssianw __internal_ev_mwhssianw
332132718Skan#define __ev_mwhsmfanw __internal_ev_mwhsmfanw
333132718Skan#define __ev_mwhsmianw __internal_ev_mwhsmianw
334132718Skan#define __ev_mwhusianw __internal_ev_mwhusianw
335132718Skan#define __ev_mwhumianw __internal_ev_mwhumianw
336117395Skan
337117395Skanstatic inline __ev64_opaque__
338117395Skan__internal_ev_mwhssfaaw (__ev64_opaque__ a, __ev64_opaque__ b)
339117395Skan{
340117395Skan  __ev64_opaque__ t;
341117395Skan
342117395Skan  t = __ev_mwhssf (a, b);
343117395Skan  return __ev_addssiaaw (t);
344117395Skan}
345117395Skan
346117395Skanstatic inline __ev64_opaque__
347117395Skan__internal_ev_mwhssiaaw (__ev64_opaque__ a, __ev64_opaque__ b)
348117395Skan{
349117395Skan  __ev64_opaque__ t;
350117395Skan
351117395Skan  t = __ev_mwhsmi (a, b);
352117395Skan  return __ev_addssiaaw (t);
353117395Skan}
354117395Skan
355117395Skanstatic inline __ev64_opaque__
356117395Skan__internal_ev_mwhsmfaaw (__ev64_opaque__ a, __ev64_opaque__ b)
357117395Skan{
358117395Skan  __ev64_opaque__ t;
359117395Skan
360117395Skan  t = __ev_mwhsmf (a, b);
361117395Skan  return __ev_addsmiaaw (t);
362117395Skan}
363117395Skan
364117395Skanstatic inline __ev64_opaque__
365117395Skan__internal_ev_mwhsmiaaw (__ev64_opaque__ a, __ev64_opaque__ b)
366117395Skan{
367117395Skan  __ev64_opaque__ t;
368117395Skan
369117395Skan  t = __ev_mwhsmi (a, b);
370117395Skan  return __ev_addsmiaaw (t);
371117395Skan}
372117395Skan
373117395Skanstatic inline __ev64_opaque__
374117395Skan__internal_ev_mwhusiaaw (__ev64_opaque__ a, __ev64_opaque__ b)
375117395Skan{
376117395Skan  __ev64_opaque__ t;
377117395Skan
378117395Skan  t = __ev_mwhumi (a, b);
379117395Skan  return __ev_addusiaaw (t);
380117395Skan}
381117395Skan
382117395Skanstatic inline __ev64_opaque__
383117395Skan__internal_ev_mwhumiaaw (__ev64_opaque__ a, __ev64_opaque__ b)
384117395Skan{
385117395Skan  __ev64_opaque__ t;
386117395Skan
387117395Skan  t = __ev_mwhumi (a, b);
388117395Skan  return __ev_addumiaaw (t);
389117395Skan}
390117395Skan
391117395Skanstatic inline __ev64_opaque__
392117395Skan__internal_ev_mwhssfanw (__ev64_opaque__ a, __ev64_opaque__ b)
393117395Skan{
394117395Skan  __ev64_opaque__ t;
395117395Skan
396117395Skan  t = __ev_mwhssf (a, b);
397117395Skan  return __ev_subfssiaaw (t);
398117395Skan}
399117395Skan
400117395Skanstatic inline __ev64_opaque__
401117395Skan__internal_ev_mwhssianw (__ev64_opaque__ a, __ev64_opaque__ b)
402117395Skan{
403117395Skan  __ev64_opaque__ t;
404117395Skan
405117395Skan  t = __ev_mwhsmi (a, b);
406117395Skan  return __ev_subfssiaaw (t);
407117395Skan}
408117395Skan
409117395Skanstatic inline __ev64_opaque__
410117395Skan__internal_ev_mwhsmfanw (__ev64_opaque__ a, __ev64_opaque__ b)
411117395Skan{
412117395Skan  __ev64_opaque__ t;
413117395Skan
414117395Skan  t = __ev_mwhsmf (a, b);
415117395Skan  return __ev_subfsmiaaw (t);
416117395Skan}
417117395Skan
418117395Skanstatic inline __ev64_opaque__
419117395Skan__internal_ev_mwhsmianw (__ev64_opaque__ a, __ev64_opaque__ b)
420117395Skan{
421117395Skan  __ev64_opaque__ t;
422117395Skan
423117395Skan  t = __ev_mwhsmi (a, b);
424117395Skan  return __ev_subfsmiaaw (t);
425117395Skan}
426117395Skan
427117395Skanstatic inline __ev64_opaque__
428117395Skan__internal_ev_mwhusianw (__ev64_opaque__ a, __ev64_opaque__ b)
429117395Skan{
430117395Skan  __ev64_opaque__ t;
431117395Skan
432117395Skan  t = __ev_mwhumi (a, b);
433117395Skan  return __ev_subfusiaaw (t);
434117395Skan}
435117395Skan
436117395Skanstatic inline __ev64_opaque__
437117395Skan__internal_ev_mwhumianw (__ev64_opaque__ a, __ev64_opaque__ b)
438117395Skan{
439117395Skan  __ev64_opaque__ t;
440117395Skan
441117395Skan  t = __ev_mwhumi (a, b);
442117395Skan  return __ev_subfumiaaw (t);
443117395Skan}
444117395Skan
445117395Skanstatic inline __ev64_opaque__
446117395Skan__internal_ev_mwhgssfaa (__ev64_opaque__ a, __ev64_opaque__ b)
447117395Skan{
448117395Skan  __ev64_opaque__ t;
449117395Skan
450117395Skan  t = __ev_mwhssf (a, b);
451117395Skan  return __ev_mwsmiaa (t, ((__ev64_s32__){1, 1}));
452117395Skan}
453117395Skan
454117395Skanstatic inline __ev64_opaque__
455117395Skan__internal_ev_mwhgsmfaa (__ev64_opaque__ a, __ev64_opaque__ b)
456117395Skan{
457117395Skan  __ev64_opaque__ t;
458117395Skan
459117395Skan  t = __ev_mwhsmf (a, b);
460117395Skan  return __ev_mwsmiaa (t, ((__ev64_s32__){1, 1}));
461117395Skan}
462117395Skan
463117395Skanstatic inline __ev64_opaque__
464117395Skan__internal_ev_mwhgsmiaa (__ev64_opaque__ a, __ev64_opaque__ b)
465117395Skan{
466117395Skan  __ev64_opaque__ t;
467117395Skan
468117395Skan  t = __ev_mwhsmi (a, b);
469117395Skan  return __ev_mwsmiaa (t, ((__ev64_s32__){1, 1}));
470117395Skan}
471117395Skan
472117395Skanstatic inline __ev64_opaque__
473117395Skan__internal_ev_mwhgumiaa (__ev64_opaque__ a, __ev64_opaque__ b)
474117395Skan{
475117395Skan  __ev64_opaque__ t;
476117395Skan
477117395Skan  t = __ev_mwhumi (a, b);
478117395Skan  return __ev_mwumiaa (t, ((__ev64_s32__){1, 1}));
479117395Skan}
480117395Skan
481117395Skanstatic inline __ev64_opaque__
482117395Skan__internal_ev_mwhgssfan (__ev64_opaque__ a, __ev64_opaque__ b)
483117395Skan{
484117395Skan  __ev64_opaque__ t;
485117395Skan
486117395Skan  t = __ev_mwhssf (a, b);
487117395Skan  return __ev_mwsmian (t, ((__ev64_s32__){1, 1}));
488117395Skan}
489117395Skan
490117395Skanstatic inline __ev64_opaque__
491117395Skan__internal_ev_mwhgsmfan (__ev64_opaque__ a, __ev64_opaque__ b)
492117395Skan{
493117395Skan  __ev64_opaque__ t;
494117395Skan
495117395Skan  t = __ev_mwhsmf (a, b);
496117395Skan  return __ev_mwsmian (t, ((__ev64_s32__){1, 1}));
497117395Skan}
498117395Skan
499117395Skanstatic inline __ev64_opaque__
500117395Skan__internal_ev_mwhgsmian (__ev64_opaque__ a, __ev64_opaque__ b)
501117395Skan{
502117395Skan  __ev64_opaque__ t;
503117395Skan
504117395Skan  t = __ev_mwhsmi (a, b);
505117395Skan  return __ev_mwsmian (t, ((__ev64_s32__){1, 1}));
506117395Skan}
507117395Skan
508117395Skanstatic inline __ev64_opaque__
509117395Skan__internal_ev_mwhgumian (__ev64_opaque__ a, __ev64_opaque__ b)
510117395Skan{
511117395Skan  __ev64_opaque__ t;
512117395Skan
513117395Skan  t = __ev_mwhumi (a, b);
514117395Skan  return __ev_mwumian (t, ((__ev64_s32__){1, 1}));
515117395Skan}
516117395Skan
517117395Skan/* END OF NOT SUPPORTED */
518117395Skan
519117395Skan/* __ev_create* functions.  */
520117395Skan
521117395Skan#define __ev_create_ufix32_u32 __ev_create_u32
522117395Skan#define __ev_create_sfix32_s32 __ev_create_s32
523117395Skan
524117395Skanstatic inline __ev64_opaque__
525117395Skan__ev_create_s16 (int16_t a, int16_t b, int16_t c, int16_t d)
526117395Skan{
527117395Skan  union
528117395Skan  {
529117395Skan    __ev64_opaque__ v;
530117395Skan    int16_t i[4];
531117395Skan  } u;
532117395Skan
533117395Skan  u.i[0] = a;
534117395Skan  u.i[1] = b;
535117395Skan  u.i[2] = c;
536117395Skan  u.i[3] = d;
537117395Skan
538117395Skan  return u.v;
539117395Skan}
540117395Skan
541117395Skanstatic inline __ev64_opaque__
542117395Skan__ev_create_u16 (uint16_t a, uint16_t b, uint16_t c, uint16_t d)
543117395Skan
544117395Skan{
545117395Skan  union
546117395Skan  {
547117395Skan    __ev64_opaque__ v;
548117395Skan    uint16_t i[4];
549117395Skan  } u;
550117395Skan
551117395Skan  u.i[0] = a;
552117395Skan  u.i[1] = b;
553117395Skan  u.i[2] = c;
554117395Skan  u.i[3] = d;
555117395Skan
556117395Skan  return u.v;
557117395Skan}
558117395Skan
559117395Skanstatic inline __ev64_opaque__
560117395Skan__ev_create_s32 (int32_t a, int32_t b)
561117395Skan{
562117395Skan  union
563117395Skan  {
564117395Skan    __ev64_opaque__ v;
565117395Skan   int32_t i[2];
566117395Skan  } u;
567117395Skan
568117395Skan  u.i[0] = a;
569117395Skan  u.i[1] = b;
570117395Skan
571117395Skan  return u.v;
572117395Skan}
573117395Skan
574117395Skanstatic inline __ev64_opaque__
575117395Skan__ev_create_u32 (uint32_t a, uint32_t b)
576117395Skan{
577117395Skan  union
578117395Skan  {
579117395Skan    __ev64_opaque__ v;
580117395Skan    uint32_t i[2];
581117395Skan  } u;
582117395Skan
583117395Skan  u.i[0] = a;
584117395Skan  u.i[1] = b;
585117395Skan
586117395Skan  return u.v;
587117395Skan}
588117395Skan
589117395Skanstatic inline __ev64_opaque__
590117395Skan__ev_create_fs (float a, float b)
591117395Skan{
592117395Skan  union
593117395Skan  {
594117395Skan    __ev64_opaque__ v;
595117395Skan    float f[2];
596117395Skan  } u;
597117395Skan
598117395Skan  u.f[0] = a;
599117395Skan  u.f[1] = b;
600117395Skan
601117395Skan  return u.v;
602117395Skan}
603117395Skan
604117395Skanstatic inline __ev64_opaque__
605117395Skan__ev_create_sfix32_fs (float a, float b)
606117395Skan{
607117395Skan  __ev64_opaque__ ev;
608117395Skan
609117395Skan  ev = (__ev64_opaque__) __ev_create_fs (a, b);
610117395Skan  return (__ev64_opaque__) __builtin_spe_evfsctsf ((__v2sf) ev);
611117395Skan}
612117395Skan
613117395Skanstatic inline __ev64_opaque__
614117395Skan__ev_create_ufix32_fs (float a, float b)
615117395Skan{
616117395Skan  __ev64_opaque__ ev;
617117395Skan
618117395Skan  ev = (__ev64_opaque__) __ev_create_fs (a, b);
619117395Skan  return (__ev64_opaque__) __builtin_spe_evfsctuf ((__v2sf) ev);
620117395Skan}
621117395Skan
622117395Skanstatic inline __ev64_opaque__
623117395Skan__ev_create_s64 (int64_t a)
624117395Skan{
625117395Skan  union
626117395Skan  {
627117395Skan    __ev64_opaque__ v;
628117395Skan    int64_t i;
629117395Skan  } u;
630117395Skan
631117395Skan  u.i = a;
632117395Skan  return u.v;
633117395Skan}
634117395Skan
635117395Skanstatic inline __ev64_opaque__
636117395Skan__ev_create_u64 (uint64_t a)
637117395Skan{
638117395Skan  union
639117395Skan  {
640117395Skan    __ev64_opaque__ v;
641117395Skan    uint64_t i;
642117395Skan  } u;
643117395Skan
644117395Skan  u.i = a;
645117395Skan  return u.v;
646117395Skan}
647117395Skan
648117395Skanstatic inline uint64_t
649117395Skan__ev_convert_u64 (__ev64_opaque__ a)
650117395Skan{
651117395Skan  return (uint64_t) a;
652117395Skan}
653117395Skan
654117395Skanstatic inline int64_t
655117395Skan__ev_convert_s64 (__ev64_opaque__ a)
656117395Skan{
657117395Skan  return (int64_t) a;
658117395Skan}
659117395Skan
660117395Skan/* __ev_get_* functions.  */
661117395Skan
662132718Skan#define __ev_get_upper_u32(a) __ev_get_u32_internal ((a), 0)
663132718Skan#define __ev_get_lower_u32(a) __ev_get_u32_internal ((a), 1)
664132718Skan#define __ev_get_upper_s32(a) __ev_get_s32_internal ((a), 0)
665132718Skan#define __ev_get_lower_s32(a) __ev_get_s32_internal ((a), 1)
666132718Skan#define __ev_get_upper_fs(a) __ev_get_fs_internal ((a), 0)
667132718Skan#define __ev_get_lower_fs(a) __ev_get_fs_internal ((a), 1)
668132718Skan#define __ev_get_upper_ufix32_u32 __ev_get_upper_u32
669132718Skan#define __ev_get_lower_ufix32_u32 __ev_get_lower_u32
670132718Skan#define __ev_get_upper_sfix32_s32 __ev_get_upper_s32
671132718Skan#define __ev_get_lower_sfix32_s32 __ev_get_lower_s32
672132718Skan#define __ev_get_upper_sfix32_fs(a)  __ev_get_sfix32_fs ((a), 0)
673132718Skan#define __ev_get_lower_sfix32_fs(a)  __ev_get_sfix32_fs ((a), 1)
674132718Skan#define __ev_get_upper_ufix32_fs(a)  __ev_get_ufix32_fs ((a), 0)
675132718Skan#define __ev_get_lower_ufix32_fs(a)  __ev_get_ufix32_fs ((a), 1)
676117395Skan
677132718Skan#define __ev_get_u32 __ev_get_u32_internal
678132718Skan#define __ev_get_s32 __ev_get_s32_internal
679132718Skan#define __ev_get_fs __ev_get_fs_internal
680132718Skan#define __ev_get_u16 __ev_get_u16_internal
681132718Skan#define __ev_get_s16 __ev_get_s16_internal
682117395Skan
683132718Skan#define __ev_get_ufix32_u32 __ev_get_u32
684132718Skan#define __ev_get_sfix32_s32 __ev_get_s32
685132718Skan#define __ev_get_ufix32_fs     __ev_get_ufix32_fs_internal
686132718Skan#define __ev_get_sfix32_fs     __ev_get_sfix32_fs_internal
687117395Skan
688117395Skanstatic inline uint32_t
689117395Skan__ev_get_u32_internal (__ev64_opaque__ a, uint32_t pos)
690117395Skan{
691117395Skan  union
692117395Skan  {
693117395Skan    __ev64_opaque__ v;
694117395Skan    uint32_t i[2];
695117395Skan  } u;
696117395Skan
697117395Skan  u.v = a;
698117395Skan  return u.i[pos];
699117395Skan}
700117395Skan
701117395Skanstatic inline int32_t
702117395Skan__ev_get_s32_internal (__ev64_opaque__ a, uint32_t pos)
703117395Skan{
704117395Skan  union
705117395Skan  {
706117395Skan    __ev64_opaque__ v;
707117395Skan    int32_t i[2];
708117395Skan  } u;
709117395Skan
710117395Skan  u.v = a;
711117395Skan  return u.i[pos];
712117395Skan}
713117395Skan
714117395Skanstatic inline float
715117395Skan__ev_get_fs_internal (__ev64_opaque__ a, uint32_t pos)
716117395Skan{
717117395Skan  union
718117395Skan  {
719117395Skan    __ev64_opaque__ v;
720117395Skan    float f[2];
721117395Skan  } u;
722117395Skan
723117395Skan  u.v = a;
724117395Skan  return u.f[pos];
725117395Skan}
726117395Skan
727117395Skanstatic inline float
728117395Skan__ev_get_sfix32_fs_internal (__ev64_opaque__ a, uint32_t pos)
729117395Skan{
730117395Skan  __ev64_fs__ v;
731117395Skan
732117395Skan  v = __builtin_spe_evfscfsf ((__v2sf) a);
733117395Skan  return __ev_get_fs_internal ((__ev64_opaque__) v, pos);
734117395Skan}
735117395Skan
736117395Skanstatic inline float
737117395Skan__ev_get_ufix32_fs_internal (__ev64_opaque__ a, uint32_t pos)
738117395Skan{
739117395Skan  __ev64_fs__ v;
740117395Skan
741117395Skan  v = __builtin_spe_evfscfuf ((__v2sf) a);
742117395Skan  return __ev_get_fs_internal ((__ev64_opaque__) v, pos);
743117395Skan}
744117395Skan
745117395Skanstatic inline uint16_t
746117395Skan__ev_get_u16_internal (__ev64_opaque__ a, uint32_t pos)
747117395Skan{
748117395Skan  union
749117395Skan  {
750117395Skan    __ev64_opaque__ v;
751117395Skan    uint16_t i[4];
752117395Skan  } u;
753117395Skan
754117395Skan  u.v = a;
755117395Skan  return u.i[pos];
756117395Skan}
757117395Skan
758117395Skanstatic inline int16_t
759117395Skan__ev_get_s16_internal (__ev64_opaque__ a, uint32_t pos)
760117395Skan{
761117395Skan  union
762117395Skan  {
763117395Skan    __ev64_opaque__ v;
764117395Skan    int16_t i[4];
765117395Skan  } u;
766117395Skan
767117395Skan  u.v = a;
768117395Skan  return u.i[pos];
769117395Skan}
770117395Skan
771117395Skan/* __ev_set_* functions.  */
772117395Skan
773132718Skan#define __ev_set_u32 __ev_set_u32_internal
774132718Skan#define __ev_set_s32 __ev_set_s32_internal
775132718Skan#define __ev_set_fs __ev_set_fs_internal
776132718Skan#define __ev_set_u16 __ev_set_u16_internal
777132718Skan#define __ev_set_s16 __ev_set_s16_internal
778117395Skan
779117395Skan#define __ev_set_ufix32_u32 __ev_set_u32
780117395Skan#define __ev_set_sfix32_s32 __ev_set_s32
781117395Skan
782132718Skan#define __ev_set_sfix32_fs  __ev_set_sfix32_fs_internal
783132718Skan#define __ev_set_ufix32_fs  __ev_set_ufix32_fs_internal
784117395Skan
785117395Skan#define __ev_set_upper_u32(a, b) __ev_set_u32 (a, b, 0)
786117395Skan#define __ev_set_lower_u32(a, b) __ev_set_u32 (a, b, 1)
787117395Skan#define __ev_set_upper_s32(a, b) __ev_set_s32 (a, b, 0)
788117395Skan#define __ev_set_lower_s32(a, b) __ev_set_s32 (a, b, 1)
789117395Skan#define __ev_set_upper_fs(a, b) __ev_set_fs (a, b, 0)
790117395Skan#define __ev_set_lower_fs(a, b) __ev_set_fs (a, b, 1)
791117395Skan#define __ev_set_upper_ufix32_u32 __ev_set_upper_u32
792117395Skan#define __ev_set_lower_ufix32_u32 __ev_set_lower_u32
793117395Skan#define __ev_set_upper_sfix32_s32 __ev_set_upper_s32
794117395Skan#define __ev_set_lower_sfix32_s32 __ev_set_lower_s32
795117395Skan#define __ev_set_upper_sfix32_fs(a, b)  __ev_set_sfix32_fs (a, b, 0)
796117395Skan#define __ev_set_lower_sfix32_fs(a, b)  __ev_set_sfix32_fs (a, b, 1)
797117395Skan#define __ev_set_upper_ufix32_fs(a, b)  __ev_set_ufix32_fs (a, b, 0)
798117395Skan#define __ev_set_lower_ufix32_fs(a, b)  __ev_set_ufix32_fs (a, b, 1)
799117395Skan
800132718Skan#define __ev_set_acc_vec64 __builtin_spe_evmra
801117395Skan
802117395Skanstatic inline __ev64_opaque__
803117395Skan__ev_set_acc_u64 (uint64_t a)
804117395Skan{
805117395Skan  __ev64_opaque__ ev32;
806117395Skan  ev32 = __ev_create_u64 (a);
807117395Skan  __ev_mra (ev32);
808117395Skan  return ev32;
809117395Skan}
810117395Skan
811117395Skanstatic inline __ev64_opaque__
812117395Skan__ev_set_acc_s64 (int64_t a)
813117395Skan{
814117395Skan  __ev64_opaque__ ev32;
815117395Skan  ev32 = __ev_create_s64 (a);
816117395Skan  __ev_mra (ev32);
817117395Skan  return ev32;
818117395Skan}
819117395Skan
820117395Skanstatic inline __ev64_opaque__
821117395Skan__ev_set_u32_internal (__ev64_opaque__ a, uint32_t b, uint32_t pos)
822117395Skan{
823117395Skan  union
824117395Skan  {
825117395Skan    __ev64_opaque__ v;
826117395Skan    uint32_t i[2];
827117395Skan  } u;
828117395Skan
829117395Skan  u.v = a;
830117395Skan  u.i[pos] = b;
831117395Skan  return u.v;
832117395Skan}
833117395Skan
834117395Skanstatic inline __ev64_opaque__
835117395Skan__ev_set_s32_internal (__ev64_opaque__ a, int32_t b, uint32_t pos)
836117395Skan{
837117395Skan  union
838117395Skan  {
839117395Skan    __ev64_opaque__ v;
840117395Skan    int32_t i[2];
841117395Skan  } u;
842117395Skan
843117395Skan  u.v = a;
844117395Skan  u.i[pos] = b;
845117395Skan  return u.v;
846117395Skan}
847117395Skan
848117395Skanstatic inline __ev64_opaque__
849117395Skan__ev_set_fs_internal (__ev64_opaque__ a, float b, uint32_t pos)
850117395Skan{
851117395Skan  union
852117395Skan  {
853117395Skan    __ev64_opaque__ v;
854117395Skan    float f[2];
855117395Skan  } u;
856117395Skan
857117395Skan  u.v = a;
858117395Skan  u.f[pos] = b;
859117395Skan  return u.v;
860117395Skan}
861117395Skan
862117395Skanstatic inline __ev64_opaque__
863117395Skan__ev_set_sfix32_fs_internal (__ev64_opaque__ a, float b, uint32_t pos)
864117395Skan{
865117395Skan  __ev64_opaque__ v;
866117395Skan  float other;
867117395Skan
868117395Skan  /* Get other half.  */
869117395Skan  other = __ev_get_fs_internal (a, pos ^ 1);
870117395Skan
871117395Skan  /* Make an sfix32 with 'b'.  */
872117395Skan  v = __ev_create_sfix32_fs (b, b);
873117395Skan
874117395Skan  /* Set other half to what it used to be.  */
875117395Skan  return __ev_set_fs_internal (v, other, pos ^ 1);
876117395Skan}
877117395Skan
878117395Skanstatic inline __ev64_opaque__
879117395Skan__ev_set_ufix32_fs_internal (__ev64_opaque__ a, float b, uint32_t pos)
880117395Skan{
881117395Skan  __ev64_opaque__ v;
882117395Skan  float other;
883117395Skan
884117395Skan  /* Get other half.  */
885117395Skan  other = __ev_get_fs_internal (a, pos ^ 1);
886117395Skan
887117395Skan  /* Make an ufix32 with 'b'.  */
888117395Skan  v = __ev_create_ufix32_fs (b, b);
889117395Skan
890117395Skan  /* Set other half to what it used to be.  */
891117395Skan  return __ev_set_fs_internal (v, other, pos ^ 1);
892117395Skan}
893117395Skan
894117395Skanstatic inline __ev64_opaque__
895117395Skan__ev_set_u16_internal (__ev64_opaque__ a, uint16_t b, uint32_t pos)
896117395Skan{
897117395Skan  union
898117395Skan  {
899117395Skan    __ev64_opaque__ v;
900117395Skan    uint16_t i[4];
901117395Skan  } u;
902117395Skan
903117395Skan  u.v = a;
904117395Skan  u.i[pos] = b;
905117395Skan  return u.v;
906117395Skan}
907117395Skan
908117395Skanstatic inline __ev64_opaque__
909117395Skan__ev_set_s16_internal (__ev64_opaque__ a, int16_t b, uint32_t pos)
910117395Skan{
911117395Skan  union
912117395Skan  {
913117395Skan    __ev64_opaque__ v;
914117395Skan    int16_t i[4];
915117395Skan  } u;
916117395Skan
917117395Skan  u.v = a;
918117395Skan  u.i[pos] = b;
919117395Skan  return u.v;
920117395Skan}
921117395Skan
922117395Skan/* Predicates.  */
923117395Skan
924117395Skan#define __pred_all	0
925117395Skan#define __pred_any	1
926117395Skan#define __pred_upper	2
927117395Skan#define __pred_lower	3
928117395Skan
929132718Skan#define __ev_any_gts(a, b)		__builtin_spe_evcmpgts (__pred_any, (a), (b))
930132718Skan#define __ev_all_gts(a, b)		__builtin_spe_evcmpgts (__pred_all, (a), (b))
931132718Skan#define __ev_upper_gts(a, b)		__builtin_spe_evcmpgts (__pred_upper, (a), (b))
932132718Skan#define __ev_lower_gts(a, b)		__builtin_spe_evcmpgts (__pred_lower, (a), (b))
933132718Skan#define __ev_select_gts			__builtin_spe_evsel_gts
934117395Skan
935132718Skan#define __ev_any_gtu(a, b)		__builtin_spe_evcmpgtu (__pred_any, (a), (b))
936132718Skan#define __ev_all_gtu(a, b)		__builtin_spe_evcmpgtu (__pred_all, (a), (b))
937132718Skan#define __ev_upper_gtu(a, b)		__builtin_spe_evcmpgtu (__pred_upper, (a), (b))
938132718Skan#define __ev_lower_gtu(a, b)		__builtin_spe_evcmpgtu (__pred_lower, (a), (b))
939132718Skan#define __ev_select_gtu			__builtin_spe_evsel_gtu
940117395Skan
941132718Skan#define __ev_any_lts(a, b)		__builtin_spe_evcmplts (__pred_any, (a), (b))
942132718Skan#define __ev_all_lts(a, b)		__builtin_spe_evcmplts (__pred_all, (a), (b))
943132718Skan#define __ev_upper_lts(a, b)		__builtin_spe_evcmplts (__pred_upper, (a), (b))
944132718Skan#define __ev_lower_lts(a, b)		__builtin_spe_evcmplts (__pred_lower, (a), (b))
945132718Skan#define __ev_select_lts(a, b, c, d) 	((__v2si) __builtin_spe_evsel_lts ((a), (b), (c), (d)))
946117395Skan
947132718Skan#define __ev_any_ltu(a, b)		__builtin_spe_evcmpltu (__pred_any, (a), (b))
948132718Skan#define __ev_all_ltu(a, b)		__builtin_spe_evcmpltu (__pred_all, (a), (b))
949132718Skan#define __ev_upper_ltu(a, b)		__builtin_spe_evcmpltu (__pred_upper, (a), (b))
950132718Skan#define __ev_lower_ltu(a, b)		__builtin_spe_evcmpltu (__pred_lower, (a), (b))
951132718Skan#define __ev_select_ltu 		__builtin_spe_evsel_ltu
952132718Skan#define __ev_any_eq(a, b)		__builtin_spe_evcmpeq (__pred_any, (a), (b))
953132718Skan#define __ev_all_eq(a, b)		__builtin_spe_evcmpeq (__pred_all, (a), (b))
954132718Skan#define __ev_upper_eq(a, b)		__builtin_spe_evcmpeq (__pred_upper, (a), (b))
955132718Skan#define __ev_lower_eq(a, b)		__builtin_spe_evcmpeq (__pred_lower, (a), (b))
956132718Skan#define __ev_select_eq			__builtin_spe_evsel_eq
957117395Skan
958132718Skan#define __ev_any_fs_gt(a, b)		__builtin_spe_evfscmpgt (__pred_any, (a), (b))
959132718Skan#define __ev_all_fs_gt(a, b)		__builtin_spe_evfscmpgt (__pred_all, (a), (b))
960132718Skan#define __ev_upper_fs_gt(a, b)		__builtin_spe_evfscmpgt (__pred_upper, (a), (b))
961132718Skan#define __ev_lower_fs_gt(a, b)		__builtin_spe_evfscmpgt (__pred_lower, (a), (b))
962132718Skan#define __ev_select_fs_gt		__builtin_spe_evsel_fsgt
963117395Skan
964132718Skan#define __ev_any_fs_lt(a, b)		__builtin_spe_evfscmplt (__pred_any, (a), (b))
965132718Skan#define __ev_all_fs_lt(a, b)		__builtin_spe_evfscmplt (__pred_all, (a), (b))
966132718Skan#define __ev_upper_fs_lt(a, b)		__builtin_spe_evfscmplt (__pred_upper, (a), (b))
967132718Skan#define __ev_lower_fs_lt(a, b)		__builtin_spe_evfscmplt (__pred_lower, (a), (b))
968132718Skan#define __ev_select_fs_lt		__builtin_spe_evsel_fslt
969117395Skan
970132718Skan#define __ev_any_fs_eq(a, b)		__builtin_spe_evfscmpeq (__pred_any, (a), (b))
971132718Skan#define __ev_all_fs_eq(a, b)		__builtin_spe_evfscmpeq (__pred_all, (a), (b))
972132718Skan#define __ev_upper_fs_eq(a, b)		__builtin_spe_evfscmpeq (__pred_upper, (a), (b))
973132718Skan#define __ev_lower_fs_eq(a, b)		__builtin_spe_evfscmpeq (__pred_lower, (a), (b))
974132718Skan#define __ev_select_fs_eq		__builtin_spe_evsel_fseq
975117395Skan
976132718Skan#define __ev_any_fs_tst_gt(a, b)	__builtin_spe_evfststgt (__pred_any, (a), (b))
977132718Skan#define __ev_all_fs_tst_gt(a, b)	__builtin_spe_evfststgt (__pred_all, (a), (b))
978132718Skan#define __ev_upper_fs_tst_gt(a, b)	__builtin_spe_evfststgt (__pred_upper, (a), (b))
979132718Skan#define __ev_lower_fs_tst_gt(a, b)	__builtin_spe_evfststgt (__pred_lower, (a), (b))
980132718Skan#define __ev_select_fs_tst_gt           __builtin_spe_evsel_fststgt
981117395Skan
982132718Skan#define __ev_any_fs_tst_lt(a, b)	__builtin_spe_evfststlt (__pred_any, (a), (b))
983132718Skan#define __ev_all_fs_tst_lt(a, b)	__builtin_spe_evfststlt (__pred_all, (a), (b))
984132718Skan#define __ev_upper_fs_tst_lt(a, b)	__builtin_spe_evfststlt (__pred_upper, (a), (b))
985132718Skan#define __ev_lower_fs_tst_lt(a, b)	__builtin_spe_evfststlt (__pred_lower, (a), (b))
986132718Skan#define __ev_select_fs_tst_lt		__builtin_spe_evsel_fststlt
987117395Skan
988132718Skan#define __ev_any_fs_tst_eq(a, b)	__builtin_spe_evfststeq (__pred_any, (a), (b))
989132718Skan#define __ev_all_fs_tst_eq(a, b)	__builtin_spe_evfststeq (__pred_all, (a), (b))
990132718Skan#define __ev_upper_fs_tst_eq(a, b)	__builtin_spe_evfststeq (__pred_upper, (a), (b))
991132718Skan#define __ev_lower_fs_tst_eq(a, b)	__builtin_spe_evfststeq (__pred_lower, (a), (b))
992132718Skan#define __ev_select_fs_tst_eq		__builtin_spe_evsel_fststeq
993117395Skan
994132718Skan/* SPEFSCR accessor functions.  */
995117395Skan
996117395Skan#define __SPEFSCR_SOVH		0x80000000
997117395Skan#define __SPEFSCR_OVH		0x40000000
998117395Skan#define __SPEFSCR_FGH		0x20000000
999117395Skan#define __SPEFSCR_FXH		0x10000000
1000117395Skan#define __SPEFSCR_FINVH		0x08000000
1001117395Skan#define __SPEFSCR_FDBZH		0x04000000
1002117395Skan#define __SPEFSCR_FUNFH		0x02000000
1003117395Skan#define __SPEFSCR_FOVFH		0x01000000
1004117395Skan/* 2 unused bits.  */
1005117395Skan#define __SPEFSCR_FINXS		0x00200000
1006117395Skan#define __SPEFSCR_FINVS		0x00100000
1007117395Skan#define __SPEFSCR_FDBZS		0x00080000
1008117395Skan#define __SPEFSCR_FUNFS		0x00040000
1009117395Skan#define __SPEFSCR_FOVFS		0x00020000
1010117395Skan#define __SPEFSCR_MODE		0x00010000
1011117395Skan#define __SPEFSCR_SOV		0x00008000
1012117395Skan#define __SPEFSCR_OV		0x00004000
1013117395Skan#define __SPEFSCR_FG		0x00002000
1014117395Skan#define __SPEFSCR_FX		0x00001000
1015117395Skan#define __SPEFSCR_FINV		0x00000800
1016117395Skan#define __SPEFSCR_FDBZ		0x00000400
1017117395Skan#define __SPEFSCR_FUNF		0x00000200
1018117395Skan#define __SPEFSCR_FOVF		0x00000100
1019117395Skan/* 1 unused bit.  */
1020117395Skan#define __SPEFSCR_FINXE		0x00000040
1021117395Skan#define __SPEFSCR_FINVE		0x00000020
1022117395Skan#define __SPEFSCR_FDBZE		0x00000010
1023117395Skan#define __SPEFSCR_FUNFE		0x00000008
1024117395Skan#define __SPEFSCR_FOVFE		0x00000004
1025117395Skan#define __SPEFSCR_FRMC		0x00000003
1026117395Skan
1027117395Skan#define __ev_get_spefscr_sovh() (__builtin_spe_mfspefscr () & __SPEFSCR_SOVH)
1028117395Skan#define __ev_get_spefscr_ovh() (__builtin_spe_mfspefscr () & __SPEFSCR_OVH)
1029117395Skan#define __ev_get_spefscr_fgh() (__builtin_spe_mfspefscr () & __SPEFSCR_FGH)
1030117395Skan#define __ev_get_spefscr_fxh() (__builtin_spe_mfspefscr () & __SPEFSCR_FXH)
1031117395Skan#define __ev_get_spefscr_finvh() (__builtin_spe_mfspefscr () & __SPEFSCR_FINVH)
1032117395Skan#define __ev_get_spefscr_fdbzh() (__builtin_spe_mfspefscr () & __SPEFSCR_FDBZH)
1033117395Skan#define __ev_get_spefscr_funfh() (__builtin_spe_mfspefscr () & __SPEFSCR_FUNFH)
1034117395Skan#define __ev_get_spefscr_fovfh() (__builtin_spe_mfspefscr () & __SPEFSCR_FOVFH)
1035117395Skan#define __ev_get_spefscr_finxs() (__builtin_spe_mfspefscr () & __SPEFSCR_FINXS)
1036117395Skan#define __ev_get_spefscr_finvs() (__builtin_spe_mfspefscr () & __SPEFSCR_FINVS)
1037117395Skan#define __ev_get_spefscr_fdbzs() (__builtin_spe_mfspefscr () & __SPEFSCR_FDBZS)
1038117395Skan#define __ev_get_spefscr_funfs() (__builtin_spe_mfspefscr () & __SPEFSCR_FUNFS)
1039117395Skan#define __ev_get_spefscr_fovfs() (__builtin_spe_mfspefscr () & __SPEFSCR_FOVFS)
1040117395Skan#define __ev_get_spefscr_mode() (__builtin_spe_mfspefscr () & __SPEFSCR_MODE)
1041117395Skan#define __ev_get_spefscr_sov() (__builtin_spe_mfspefscr () & __SPEFSCR_SOV)
1042117395Skan#define __ev_get_spefscr_ov() (__builtin_spe_mfspefscr () & __SPEFSCR_OV)
1043117395Skan#define __ev_get_spefscr_fg() (__builtin_spe_mfspefscr () & __SPEFSCR_FG)
1044117395Skan#define __ev_get_spefscr_fx() (__builtin_spe_mfspefscr () & __SPEFSCR_FX)
1045117395Skan#define __ev_get_spefscr_finv() (__builtin_spe_mfspefscr () & __SPEFSCR_FINV)
1046117395Skan#define __ev_get_spefscr_fdbz() (__builtin_spe_mfspefscr () & __SPEFSCR_FDBZ)
1047117395Skan#define __ev_get_spefscr_funf() (__builtin_spe_mfspefscr () & __SPEFSCR_FUNF)
1048117395Skan#define __ev_get_spefscr_fovf() (__builtin_spe_mfspefscr () & __SPEFSCR_FOVF)
1049117395Skan#define __ev_get_spefscr_finxe() (__builtin_spe_mfspefscr () & __SPEFSCR_FINXE)
1050117395Skan#define __ev_get_spefscr_finve() (__builtin_spe_mfspefscr () & __SPEFSCR_FINVE)
1051117395Skan#define __ev_get_spefscr_fdbze() (__builtin_spe_mfspefscr () & __SPEFSCR_FDBZE)
1052117395Skan#define __ev_get_spefscr_funfe() (__builtin_spe_mfspefscr () & __SPEFSCR_FUNFE)
1053117395Skan#define __ev_get_spefscr_fovfe() (__builtin_spe_mfspefscr () & __SPEFSCR_FOVFE)
1054117395Skan#define __ev_get_spefscr_frmc() (__builtin_spe_mfspefscr () & __SPEFSCR_FRMC)
1055117395Skan
1056117395Skanstatic inline void
1057117395Skan__ev_clr_spefscr_field (int mask)
1058117395Skan{
1059117395Skan  int i;
1060117395Skan
1061117395Skan  i = __builtin_spe_mfspefscr ();
1062117395Skan  i &= ~mask;
1063117395Skan  __builtin_spe_mtspefscr (i);
1064117395Skan}
1065117395Skan
1066117395Skan#define __ev_clr_spefscr_sovh() __ev_clr_spefscr_field (__SPEFSCR_SOVH)
1067117395Skan#define __ev_clr_spefscr_sov() __ev_clr_spefscr_field (__SPEFSCR_SOV)
1068117395Skan#define __ev_clr_spefscr_finxs() __ev_clr_spefscr_field (__SPEFSCR_FINXS)
1069117395Skan#define __ev_clr_spefscr_finvs() __ev_clr_spefscr_field (__SPEFSCR_FINVS)
1070117395Skan#define __ev_clr_spefscr_fdbzs() __ev_clr_spefscr_field (__SPEFSCR_FDBZS)
1071117395Skan#define __ev_clr_spefscr_funfs() __ev_clr_spefscr_field (__SPEFSCR_FUNFS)
1072117395Skan#define __ev_clr_spefscr_fovfs() __ev_clr_spefscr_field (__SPEFSCR_FOVFS)
1073117395Skan
1074117395Skan/* Set rounding mode:
1075117395Skan     rnd = 0 (nearest)
1076117395Skan     rnd = 1 (zero)
1077117395Skan     rnd = 2 (+inf)
1078117395Skan     rnd = 3 (-inf).  */
1079117395Skan
1080117395Skanstatic inline void
1081117395Skan__ev_set_spefscr_frmc (int rnd)
1082117395Skan{
1083117395Skan  int i;
1084117395Skan
1085117395Skan  i = __builtin_spe_mfspefscr ();
1086117395Skan  i &= ~__SPEFSCR_FRMC;
1087117395Skan  i |= rnd;
1088132718Skan  __builtin_spe_mtspefscr (i);
1089117395Skan}
1090117395Skan
1091146895Skan/* The SPE PIM says these are declared in <spe.h>, although they are
1092146895Skan   not provided by GCC: they must be taken from a separate
1093146895Skan   library.  */
1094146895Skanextern short int atosfix16 (const char *);
1095146895Skanextern int atosfix32 (const char *);
1096146895Skanextern long long atosfix64 (const char *);
1097146895Skan
1098146895Skanextern unsigned short atoufix16 (const char *);
1099146895Skanextern unsigned int atoufix32 (const char *);
1100146895Skanextern unsigned long long atoufix64 (const char *);
1101146895Skan
1102146895Skanextern short int strtosfix16 (const char *, char **);
1103146895Skanextern int strtosfix32 (const char *, char **);
1104146895Skanextern long long strtosfix64 (const char *, char **);
1105146895Skan
1106146895Skanextern unsigned short int strtoufix16 (const char *, char **);
1107146895Skanextern unsigned int strtoufix32 (const char *, char **);
1108146895Skanextern unsigned long long strtoufix64 (const char *, char **);
1109146895Skan
1110117395Skan#endif /* _SPE_H */
1111