spe.h revision 132718
1117395Skan/* PowerPC E500 user include file. 2117395Skan Copyright (C) 2002, 2003 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 19132718Skan Free Software Foundation, 59 Temple Place - Suite 330, Boston, 20132718Skan MA 02111-1307, 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 1091117395Skan#endif /* _SPE_H */ 1092