186797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* 286797937017f52bff088d02edf64fb931177a7eaJun Nakajima * MMX/3DNow!/SSE/SSE2/SSE3/SSSE3/SSE4/PNI support 386797937017f52bff088d02edf64fb931177a7eaJun Nakajima * 486797937017f52bff088d02edf64fb931177a7eaJun Nakajima * Copyright (c) 2005 Fabrice Bellard 586797937017f52bff088d02edf64fb931177a7eaJun Nakajima * Copyright (c) 2008 Intel Corporation <andrew.zaborowski@intel.com> 686797937017f52bff088d02edf64fb931177a7eaJun Nakajima * 786797937017f52bff088d02edf64fb931177a7eaJun Nakajima * This library is free software; you can redistribute it and/or 886797937017f52bff088d02edf64fb931177a7eaJun Nakajima * modify it under the terms of the GNU Lesser General Public 986797937017f52bff088d02edf64fb931177a7eaJun Nakajima * License as published by the Free Software Foundation; either 1086797937017f52bff088d02edf64fb931177a7eaJun Nakajima * version 2 of the License, or (at your option) any later version. 1186797937017f52bff088d02edf64fb931177a7eaJun Nakajima * 1286797937017f52bff088d02edf64fb931177a7eaJun Nakajima * This library is distributed in the hope that it will be useful, 1386797937017f52bff088d02edf64fb931177a7eaJun Nakajima * but WITHOUT ANY WARRANTY; without even the implied warranty of 1486797937017f52bff088d02edf64fb931177a7eaJun Nakajima * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1586797937017f52bff088d02edf64fb931177a7eaJun Nakajima * Lesser General Public License for more details. 1686797937017f52bff088d02edf64fb931177a7eaJun Nakajima * 1786797937017f52bff088d02edf64fb931177a7eaJun Nakajima * You should have received a copy of the GNU Lesser General Public 1886797937017f52bff088d02edf64fb931177a7eaJun Nakajima * License along with this library; if not, write to the Free Software 1986797937017f52bff088d02edf64fb931177a7eaJun Nakajima * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301 USA 2086797937017f52bff088d02edf64fb931177a7eaJun Nakajima */ 2186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 2286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define Reg MMXReg 2386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define XMM_ONLY(...) 2486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define B(n) MMX_B(n) 2586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define W(n) MMX_W(n) 2686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define L(n) MMX_L(n) 2786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define Q(n) q 2886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SUFFIX _mmx 2986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#else 3086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define Reg XMMReg 3186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define XMM_ONLY(...) __VA_ARGS__ 3286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define B(n) XMM_B(n) 3386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define W(n) XMM_W(n) 3486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define L(n) XMM_L(n) 3586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define Q(n) XMM_Q(n) 3686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SUFFIX _xmm 3786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 3886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 3986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psrlw, SUFFIX)(Reg *d, Reg *s) 4086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 4186797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 4286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 4386797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 15) { 4486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 4586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 4686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 4786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 4886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 4986797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 5086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) >>= shift; 5186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) >>= shift; 5286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) >>= shift; 5386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) >>= shift; 5486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 5586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) >>= shift; 5686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) >>= shift; 5786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) >>= shift; 5886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) >>= shift; 5986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 6086797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 6186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 6286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 6386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psraw, SUFFIX)(Reg *d, Reg *s) 6486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 6586797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 6686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 6786797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 15) { 6886797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = 15; 6986797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 7086797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 7186797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 7286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = (int16_t)d->W(0) >> shift; 7386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = (int16_t)d->W(1) >> shift; 7486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) = (int16_t)d->W(2) >> shift; 7586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) = (int16_t)d->W(3) >> shift; 7686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 7786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) = (int16_t)d->W(4) >> shift; 7886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) = (int16_t)d->W(5) >> shift; 7986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) = (int16_t)d->W(6) >> shift; 8086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) = (int16_t)d->W(7) >> shift; 8186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 8286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 8386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 8486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psllw, SUFFIX)(Reg *d, Reg *s) 8586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 8686797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 8786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 8886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 15) { 8986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 9086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 9186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 9286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 9386797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 9486797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 9586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) <<= shift; 9686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) <<= shift; 9786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) <<= shift; 9886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) <<= shift; 9986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 10086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) <<= shift; 10186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) <<= shift; 10286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) <<= shift; 10386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) <<= shift; 10486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 10586797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 10686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 10786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 10886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psrld, SUFFIX)(Reg *d, Reg *s) 10986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 11086797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 11186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 11286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 31) { 11386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 11486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 11586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 11686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 11786797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 11886797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 11986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) >>= shift; 12086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) >>= shift; 12186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 12286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) >>= shift; 12386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) >>= shift; 12486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 12586797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 12686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 12786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 12886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psrad, SUFFIX)(Reg *d, Reg *s) 12986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 13086797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 13186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 13286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 31) { 13386797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = 31; 13486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 13586797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 13686797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 13786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = (int32_t)d->L(0) >> shift; 13886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = (int32_t)d->L(1) >> shift; 13986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 14086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) = (int32_t)d->L(2) >> shift; 14186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) = (int32_t)d->L(3) >> shift; 14286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 14386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 14486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 14586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pslld, SUFFIX)(Reg *d, Reg *s) 14686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 14786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 14886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 14986797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 31) { 15086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 15186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 15286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 15386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 15486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 15586797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 15686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) <<= shift; 15786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) <<= shift; 15886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 15986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) <<= shift; 16086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) <<= shift; 16186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 16286797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 16386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 16486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 16586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psrlq, SUFFIX)(Reg *d, Reg *s) 16686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 16786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 16886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 16986797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 63) { 17086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 17186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 17286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 17386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 17486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 17586797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 17686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) >>= shift; 17786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 17886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) >>= shift; 17986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 18086797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 18186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 18286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 18386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psllq, SUFFIX)(Reg *d, Reg *s) 18486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 18586797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift; 18686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 18786797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->Q(0) > 63) { 18886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = 0; 18986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 19086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 19186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 19286797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 19386797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->B(0); 19486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) <<= shift; 19586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 19686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) <<= shift; 19786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 19886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 19986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 20086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 20186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 20286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psrldq, SUFFIX)(Reg *d, Reg *s) 20386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 20486797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift, i; 20586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 20686797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->L(0); 20786797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (shift > 16) 20886797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = 16; 20986797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 0; i < 16 - shift; i++) 21086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = d->B(i + shift); 21186797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 16 - shift; i < 16; i++) 21286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = 0; 21386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 21486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 21586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pslldq, SUFFIX)(Reg *d, Reg *s) 21686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 21786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int shift, i; 21886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 21986797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = s->L(0); 22086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (shift > 16) 22186797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift = 16; 22286797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 15; i >= shift; i--) 22386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = d->B(i - shift); 22486797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 0; i < shift; i++) 22586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = 0; 22686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 22786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 22886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 22986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_B(name, F)\ 23086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 23186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 23286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(0) = F(d->B(0), s->B(0));\ 23386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(1) = F(d->B(1), s->B(1));\ 23486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(2) = F(d->B(2), s->B(2));\ 23586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(3) = F(d->B(3), s->B(3));\ 23686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(4) = F(d->B(4), s->B(4));\ 23786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(5) = F(d->B(5), s->B(5));\ 23886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(6) = F(d->B(6), s->B(6));\ 23986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(7) = F(d->B(7), s->B(7));\ 24086797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(\ 24186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(8) = F(d->B(8), s->B(8));\ 24286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(9) = F(d->B(9), s->B(9));\ 24386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(10) = F(d->B(10), s->B(10));\ 24486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(11) = F(d->B(11), s->B(11));\ 24586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(12) = F(d->B(12), s->B(12));\ 24686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(13) = F(d->B(13), s->B(13));\ 24786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(14) = F(d->B(14), s->B(14));\ 24886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(15) = F(d->B(15), s->B(15));\ 24986797937017f52bff088d02edf64fb931177a7eaJun Nakajima )\ 25086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 25186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 25286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_W(name, F)\ 25386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 25486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 25586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = F(d->W(0), s->W(0));\ 25686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = F(d->W(1), s->W(1));\ 25786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) = F(d->W(2), s->W(2));\ 25886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) = F(d->W(3), s->W(3));\ 25986797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(\ 26086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) = F(d->W(4), s->W(4));\ 26186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) = F(d->W(5), s->W(5));\ 26286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) = F(d->W(6), s->W(6));\ 26386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) = F(d->W(7), s->W(7));\ 26486797937017f52bff088d02edf64fb931177a7eaJun Nakajima )\ 26586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 26686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 26786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_L(name, F)\ 26886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 26986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 27086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = F(d->L(0), s->L(0));\ 27186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = F(d->L(1), s->L(1));\ 27286797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(\ 27386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) = F(d->L(2), s->L(2));\ 27486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) = F(d->L(3), s->L(3));\ 27586797937017f52bff088d02edf64fb931177a7eaJun Nakajima )\ 27686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 27786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 27886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_Q(name, F)\ 27986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 28086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 28186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = F(d->Q(0), s->Q(0));\ 28286797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(\ 28386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = F(d->Q(1), s->Q(1));\ 28486797937017f52bff088d02edf64fb931177a7eaJun Nakajima )\ 28586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 28686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 28786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 28886797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int satub(int x) 28986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 29086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (x < 0) 29186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 0; 29286797937017f52bff088d02edf64fb931177a7eaJun Nakajima else if (x > 255) 29386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 255; 29486797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 29586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return x; 29686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 29786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 29886797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int satuw(int x) 29986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 30086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (x < 0) 30186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 0; 30286797937017f52bff088d02edf64fb931177a7eaJun Nakajima else if (x > 65535) 30386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 65535; 30486797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 30586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return x; 30686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 30786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 30886797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int satsb(int x) 30986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 31086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (x < -128) 31186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return -128; 31286797937017f52bff088d02edf64fb931177a7eaJun Nakajima else if (x > 127) 31386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 127; 31486797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 31586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return x; 31686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 31786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 31886797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int satsw(int x) 31986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 32086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (x < -32768) 32186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return -32768; 32286797937017f52bff088d02edf64fb931177a7eaJun Nakajima else if (x > 32767) 32386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 32767; 32486797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 32586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return x; 32686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 32786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 32886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FADD(a, b) ((a) + (b)) 32986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FADDUB(a, b) satub((a) + (b)) 33086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FADDUW(a, b) satuw((a) + (b)) 33186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FADDSB(a, b) satsb((int8_t)(a) + (int8_t)(b)) 33286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FADDSW(a, b) satsw((int16_t)(a) + (int16_t)(b)) 33386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 33486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSUB(a, b) ((a) - (b)) 33586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSUBUB(a, b) satub((a) - (b)) 33686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSUBUW(a, b) satuw((a) - (b)) 33786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSUBSB(a, b) satsb((int8_t)(a) - (int8_t)(b)) 33886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSUBSW(a, b) satsw((int16_t)(a) - (int16_t)(b)) 33986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMINUB(a, b) ((a) < (b)) ? (a) : (b) 34086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMINSW(a, b) ((int16_t)(a) < (int16_t)(b)) ? (a) : (b) 34186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMAXUB(a, b) ((a) > (b)) ? (a) : (b) 34286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMAXSW(a, b) ((int16_t)(a) > (int16_t)(b)) ? (a) : (b) 34386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 34486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FAND(a, b) (a) & (b) 34586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FANDN(a, b) ((~(a)) & (b)) 34686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FOR(a, b) (a) | (b) 34786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FXOR(a, b) (a) ^ (b) 34886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 34986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPGTB(a, b) (int8_t)(a) > (int8_t)(b) ? -1 : 0 35086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPGTW(a, b) (int16_t)(a) > (int16_t)(b) ? -1 : 0 35186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPGTL(a, b) (int32_t)(a) > (int32_t)(b) ? -1 : 0 35286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPEQ(a, b) (a) == (b) ? -1 : 0 35386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 35486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULLW(a, b) (a) * (b) 35586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULHRW(a, b) ((int16_t)(a) * (int16_t)(b) + 0x8000) >> 16 35686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULHUW(a, b) (a) * (b) >> 16 35786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULHW(a, b) (int16_t)(a) * (int16_t)(b) >> 16 35886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 35986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FAVG(a, b) ((a) + (b) + 1) >> 1 36086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 36186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 36286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_paddb, FADD) 36386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_paddw, FADD) 36486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_paddl, FADD) 36586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_paddq, FADD) 36686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 36786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_psubb, FSUB) 36886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_psubw, FSUB) 36986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_psubl, FSUB) 37086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_psubq, FSUB) 37186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 37286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_paddusb, FADDUB) 37386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_paddsb, FADDSB) 37486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_psubusb, FSUBUB) 37586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_psubsb, FSUBSB) 37686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 37786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_paddusw, FADDUW) 37886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_paddsw, FADDSW) 37986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_psubusw, FSUBUW) 38086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_psubsw, FSUBSW) 38186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 38286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pminub, FMINUB) 38386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pmaxub, FMAXUB) 38486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 38586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pminsw, FMINSW) 38686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmaxsw, FMAXSW) 38786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 38886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_pand, FAND) 38986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_pandn, FANDN) 39086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_por, FOR) 39186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_pxor, FXOR) 39286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 39386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pcmpgtb, FCMPGTB) 39486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pcmpgtw, FCMPGTW) 39586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pcmpgtl, FCMPGTL) 39686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 39786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pcmpeqb, FCMPEQ) 39886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pcmpeqw, FCMPEQ) 39986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pcmpeql, FCMPEQ) 40086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 40186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmullw, FMULLW) 40286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 40386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmulhrw, FMULHRW) 40486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 40586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmulhuw, FMULHUW) 40686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmulhw, FMULHW) 40786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 40886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pavgb, FAVG) 40986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pavgw, FAVG) 41086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 41186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pmuludq, SUFFIX) (Reg *d, Reg *s) 41286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 41386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = (uint64_t)s->L(0) * (uint64_t)d->L(0); 41486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 41586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = (uint64_t)s->L(2) * (uint64_t)d->L(2); 41686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 41786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 41886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 41986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pmaddwd, SUFFIX) (Reg *d, Reg *s) 42086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 42186797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 42286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 42386797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 0; i < (2 << SHIFT); i++) { 42486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(i) = (int16_t)s->W(2*i) * (int16_t)d->W(2*i) + 42586797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int16_t)s->W(2*i+1) * (int16_t)d->W(2*i+1); 42686797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 42786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 42886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 42986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 43086797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int abs1(int a) 43186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 43286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (a < 0) 43386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return -a; 43486797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 43586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return a; 43686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 43786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 43886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_psadbw, SUFFIX) (Reg *d, Reg *s) 43986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 44086797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int val; 44186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 44286797937017f52bff088d02edf64fb931177a7eaJun Nakajima val = 0; 44386797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(0) - s->B(0)); 44486797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(1) - s->B(1)); 44586797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(2) - s->B(2)); 44686797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(3) - s->B(3)); 44786797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(4) - s->B(4)); 44886797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(5) - s->B(5)); 44986797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(6) - s->B(6)); 45086797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(7) - s->B(7)); 45186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = val; 45286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 45386797937017f52bff088d02edf64fb931177a7eaJun Nakajima val = 0; 45486797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(8) - s->B(8)); 45586797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(9) - s->B(9)); 45686797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(10) - s->B(10)); 45786797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(11) - s->B(11)); 45886797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(12) - s->B(12)); 45986797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(13) - s->B(13)); 46086797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(14) - s->B(14)); 46186797937017f52bff088d02edf64fb931177a7eaJun Nakajima val += abs1(d->B(15) - s->B(15)); 46286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = val; 46386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 46486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 46586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 46686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_maskmov, SUFFIX) (Reg *d, Reg *s, target_ulong a0) 46786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 46886797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 46986797937017f52bff088d02edf64fb931177a7eaJun Nakajima for(i = 0; i < (8 << SHIFT); i++) { 47086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->B(i) & 0x80) 47186797937017f52bff088d02edf64fb931177a7eaJun Nakajima stb(a0 + i, d->B(i)); 47286797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 47386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 47486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 47586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_movl_mm_T0, SUFFIX) (Reg *d, uint32_t val) 47686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 47786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = val; 47886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = 0; 47986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 48086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 48186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 48286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 48386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 48486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#ifdef TARGET_X86_64 48586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_movq_mm_T0, SUFFIX) (Reg *d, uint64_t val) 48686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 48786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = val; 48886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 48986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 49086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 49186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 49286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 49386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 49486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 49586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pshufw, SUFFIX) (Reg *d, Reg *s, int order) 49686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 49786797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 49886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(0) = s->W(order & 3); 49986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(1) = s->W((order >> 2) & 3); 50086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(2) = s->W((order >> 4) & 3); 50186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(3) = s->W((order >> 6) & 3); 50286797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 50386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 50486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#else 50586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_shufps(Reg *d, Reg *s, int order) 50686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 50786797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 50886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(0) = d->L(order & 3); 50986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(1) = d->L((order >> 2) & 3); 51086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(2) = s->L((order >> 4) & 3); 51186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(3) = s->L((order >> 6) & 3); 51286797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 51386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 51486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 51586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_shufpd(Reg *d, Reg *s, int order) 51686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 51786797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 51886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = d->Q(order & 1); 51986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(1) = s->Q((order >> 1) & 1); 52086797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 52186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 52286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 52386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pshufd, SUFFIX) (Reg *d, Reg *s, int order) 52486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 52586797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 52686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(0) = s->L(order & 3); 52786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(1) = s->L((order >> 2) & 3); 52886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(2) = s->L((order >> 4) & 3); 52986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(3) = s->L((order >> 6) & 3); 53086797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 53186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 53286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 53386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pshuflw, SUFFIX) (Reg *d, Reg *s, int order) 53486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 53586797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 53686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(0) = s->W(order & 3); 53786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(1) = s->W((order >> 2) & 3); 53886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(2) = s->W((order >> 4) & 3); 53986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(3) = s->W((order >> 6) & 3); 54086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(1) = s->Q(1); 54186797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 54286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 54386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 54486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pshufhw, SUFFIX) (Reg *d, Reg *s, int order) 54586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 54686797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 54786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = s->Q(0); 54886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(4) = s->W(4 + (order & 3)); 54986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(5) = s->W(4 + ((order >> 2) & 3)); 55086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(6) = s->W(4 + ((order >> 4) & 3)); 55186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(7) = s->W(4 + ((order >> 6) & 3)); 55286797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 55386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 55486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 55586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 55686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 55786797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* FPU ops */ 55886797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* XXX: not accurate */ 55986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 56086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_S(name, F)\ 56186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## ps (Reg *d, Reg *s)\ 56286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 56386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = F(32, d->XMM_S(0), s->XMM_S(0));\ 56486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = F(32, d->XMM_S(1), s->XMM_S(1));\ 56586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(2) = F(32, d->XMM_S(2), s->XMM_S(2));\ 56686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(3) = F(32, d->XMM_S(3), s->XMM_S(3));\ 56786797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 56886797937017f52bff088d02edf64fb931177a7eaJun Nakajima\ 56986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## ss (Reg *d, Reg *s)\ 57086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 57186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = F(32, d->XMM_S(0), s->XMM_S(0));\ 57286797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 57386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## pd (Reg *d, Reg *s)\ 57486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 57586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = F(64, d->XMM_D(0), s->XMM_D(0));\ 57686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(1) = F(64, d->XMM_D(1), s->XMM_D(1));\ 57786797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 57886797937017f52bff088d02edf64fb931177a7eaJun Nakajima\ 57986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## sd (Reg *d, Reg *s)\ 58086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 58186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = F(64, d->XMM_D(0), s->XMM_D(0));\ 58286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 58386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 58486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_ADD(size, a, b) float ## size ## _add(a, b, &env->sse_status) 58586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_SUB(size, a, b) float ## size ## _sub(a, b, &env->sse_status) 58686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_MUL(size, a, b) float ## size ## _mul(a, b, &env->sse_status) 58786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_DIV(size, a, b) float ## size ## _div(a, b, &env->sse_status) 58886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_MIN(size, a, b) (a) < (b) ? (a) : (b) 58986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_MAX(size, a, b) (a) > (b) ? (a) : (b) 59086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_SQRT(size, a, b) float ## size ## _sqrt(b, &env->sse_status) 59186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 59286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(add, FPU_ADD) 59386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(sub, FPU_SUB) 59486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(mul, FPU_MUL) 59586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(div, FPU_DIV) 59686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(min, FPU_MIN) 59786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(max, FPU_MAX) 59886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_S(sqrt, FPU_SQRT) 59986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 60086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 60186797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* float to float conversions */ 60286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtps2pd(Reg *d, Reg *s) 60386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 60486797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32 s0, s1; 60586797937017f52bff088d02edf64fb931177a7eaJun Nakajima s0 = s->XMM_S(0); 60686797937017f52bff088d02edf64fb931177a7eaJun Nakajima s1 = s->XMM_S(1); 60786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = float32_to_float64(s0, &env->sse_status); 60886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(1) = float32_to_float64(s1, &env->sse_status); 60986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 61086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 61186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtpd2ps(Reg *d, Reg *s) 61286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 61386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = float64_to_float32(s->XMM_D(0), &env->sse_status); 61486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = float64_to_float32(s->XMM_D(1), &env->sse_status); 61586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 61686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 61786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 61886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtss2sd(Reg *d, Reg *s) 61986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 62086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = float32_to_float64(s->XMM_S(0), &env->sse_status); 62186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 62286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 62386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtsd2ss(Reg *d, Reg *s) 62486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 62586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = float64_to_float32(s->XMM_D(0), &env->sse_status); 62686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 62786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 62886797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* integer to float */ 62986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtdq2ps(Reg *d, Reg *s) 63086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 63186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = int32_to_float32(s->XMM_L(0), &env->sse_status); 63286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = int32_to_float32(s->XMM_L(1), &env->sse_status); 63386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(2) = int32_to_float32(s->XMM_L(2), &env->sse_status); 63486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(3) = int32_to_float32(s->XMM_L(3), &env->sse_status); 63586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 63686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 63786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtdq2pd(Reg *d, Reg *s) 63886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 63986797937017f52bff088d02edf64fb931177a7eaJun Nakajima int32_t l0, l1; 64086797937017f52bff088d02edf64fb931177a7eaJun Nakajima l0 = (int32_t)s->XMM_L(0); 64186797937017f52bff088d02edf64fb931177a7eaJun Nakajima l1 = (int32_t)s->XMM_L(1); 64286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = int32_to_float64(l0, &env->sse_status); 64386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(1) = int32_to_float64(l1, &env->sse_status); 64486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 64586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 64686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtpi2ps(XMMReg *d, MMXReg *s) 64786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 64886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = int32_to_float32(s->MMX_L(0), &env->sse_status); 64986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = int32_to_float32(s->MMX_L(1), &env->sse_status); 65086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 65186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 65286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtpi2pd(XMMReg *d, MMXReg *s) 65386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 65486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = int32_to_float64(s->MMX_L(0), &env->sse_status); 65586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(1) = int32_to_float64(s->MMX_L(1), &env->sse_status); 65686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 65786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 65886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtsi2ss(XMMReg *d, uint32_t val) 65986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 66086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = int32_to_float32(val, &env->sse_status); 66186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 66286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 66386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtsi2sd(XMMReg *d, uint32_t val) 66486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 66586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = int32_to_float64(val, &env->sse_status); 66686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 66786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 66886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#ifdef TARGET_X86_64 66986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtsq2ss(XMMReg *d, uint64_t val) 67086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 67186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = int64_to_float32(val, &env->sse_status); 67286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 67386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 67486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtsq2sd(XMMReg *d, uint64_t val) 67586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 67686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = int64_to_float64(val, &env->sse_status); 67786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 67886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 67986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 68086797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* float to integer */ 68186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtps2dq(XMMReg *d, XMMReg *s) 68286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 68386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = float32_to_int32(s->XMM_S(0), &env->sse_status); 68486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(1) = float32_to_int32(s->XMM_S(1), &env->sse_status); 68586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(2) = float32_to_int32(s->XMM_S(2), &env->sse_status); 68686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(3) = float32_to_int32(s->XMM_S(3), &env->sse_status); 68786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 68886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 68986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtpd2dq(XMMReg *d, XMMReg *s) 69086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 69186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = float64_to_int32(s->XMM_D(0), &env->sse_status); 69286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(1) = float64_to_int32(s->XMM_D(1), &env->sse_status); 69386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_Q(1) = 0; 69486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 69586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 69686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtps2pi(MMXReg *d, XMMReg *s) 69786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 69886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_to_int32(s->XMM_S(0), &env->sse_status); 69986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_to_int32(s->XMM_S(1), &env->sse_status); 70086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 70186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 70286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvtpd2pi(MMXReg *d, XMMReg *s) 70386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 70486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float64_to_int32(s->XMM_D(0), &env->sse_status); 70586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float64_to_int32(s->XMM_D(1), &env->sse_status); 70686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 70786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 70886797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint32_t helper_cvtss2si(XMMReg *s) 70986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 71086797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float32_to_int32(s->XMM_S(0), &env->sse_status); 71186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 71286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 71386797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint32_t helper_cvtsd2si(XMMReg *s) 71486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 71586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float64_to_int32(s->XMM_D(0), &env->sse_status); 71686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 71786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 71886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#ifdef TARGET_X86_64 71986797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint64_t helper_cvtss2sq(XMMReg *s) 72086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 72186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float32_to_int64(s->XMM_S(0), &env->sse_status); 72286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 72386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 72486797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint64_t helper_cvtsd2sq(XMMReg *s) 72586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 72686797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float64_to_int64(s->XMM_D(0), &env->sse_status); 72786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 72886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 72986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 73086797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* float to integer truncated */ 73186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvttps2dq(XMMReg *d, XMMReg *s) 73286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 73386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = float32_to_int32_round_to_zero(s->XMM_S(0), &env->sse_status); 73486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(1) = float32_to_int32_round_to_zero(s->XMM_S(1), &env->sse_status); 73586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(2) = float32_to_int32_round_to_zero(s->XMM_S(2), &env->sse_status); 73686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(3) = float32_to_int32_round_to_zero(s->XMM_S(3), &env->sse_status); 73786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 73886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 73986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvttpd2dq(XMMReg *d, XMMReg *s) 74086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 74186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = float64_to_int32_round_to_zero(s->XMM_D(0), &env->sse_status); 74286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(1) = float64_to_int32_round_to_zero(s->XMM_D(1), &env->sse_status); 74386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_Q(1) = 0; 74486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 74586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 74686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvttps2pi(MMXReg *d, XMMReg *s) 74786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 74886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_to_int32_round_to_zero(s->XMM_S(0), &env->sse_status); 74986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_to_int32_round_to_zero(s->XMM_S(1), &env->sse_status); 75086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 75186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 75286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_cvttpd2pi(MMXReg *d, XMMReg *s) 75386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 75486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float64_to_int32_round_to_zero(s->XMM_D(0), &env->sse_status); 75586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float64_to_int32_round_to_zero(s->XMM_D(1), &env->sse_status); 75686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 75786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 75886797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint32_t helper_cvttss2si(XMMReg *s) 75986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 76086797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float32_to_int32_round_to_zero(s->XMM_S(0), &env->sse_status); 76186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 76286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 76386797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint32_t helper_cvttsd2si(XMMReg *s) 76486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 76586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float64_to_int32_round_to_zero(s->XMM_D(0), &env->sse_status); 76686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 76786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 76886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#ifdef TARGET_X86_64 76986797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint64_t helper_cvttss2sq(XMMReg *s) 77086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 77186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float32_to_int64_round_to_zero(s->XMM_S(0), &env->sse_status); 77286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 77386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 77486797937017f52bff088d02edf64fb931177a7eaJun Nakajimaint64_t helper_cvttsd2sq(XMMReg *s) 77586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 77686797937017f52bff088d02edf64fb931177a7eaJun Nakajima return float64_to_int64_round_to_zero(s->XMM_D(0), &env->sse_status); 77786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 77886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 77986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 78086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_rsqrtps(XMMReg *d, XMMReg *s) 78186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 78286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = approx_rsqrt(s->XMM_S(0)); 78386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = approx_rsqrt(s->XMM_S(1)); 78486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(2) = approx_rsqrt(s->XMM_S(2)); 78586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(3) = approx_rsqrt(s->XMM_S(3)); 78686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 78786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 78886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_rsqrtss(XMMReg *d, XMMReg *s) 78986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 79086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = approx_rsqrt(s->XMM_S(0)); 79186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 79286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 79386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_rcpps(XMMReg *d, XMMReg *s) 79486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 79586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = approx_rcp(s->XMM_S(0)); 79686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = approx_rcp(s->XMM_S(1)); 79786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(2) = approx_rcp(s->XMM_S(2)); 79886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(3) = approx_rcp(s->XMM_S(3)); 79986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 80086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 80186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_rcpss(XMMReg *d, XMMReg *s) 80286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 80386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = approx_rcp(s->XMM_S(0)); 80486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 80586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 80686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_haddps(XMMReg *d, XMMReg *s) 80786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 80886797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMMReg r; 80986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(0) = d->XMM_S(0) + d->XMM_S(1); 81086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(1) = d->XMM_S(2) + d->XMM_S(3); 81186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(2) = s->XMM_S(0) + s->XMM_S(1); 81286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(3) = s->XMM_S(2) + s->XMM_S(3); 81386797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 81486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 81586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 81686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_haddpd(XMMReg *d, XMMReg *s) 81786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 81886797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMMReg r; 81986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_D(0) = d->XMM_D(0) + d->XMM_D(1); 82086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_D(1) = s->XMM_D(0) + s->XMM_D(1); 82186797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 82286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 82386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 82486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_hsubps(XMMReg *d, XMMReg *s) 82586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 82686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMMReg r; 82786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(0) = d->XMM_S(0) - d->XMM_S(1); 82886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(1) = d->XMM_S(2) - d->XMM_S(3); 82986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(2) = s->XMM_S(0) - s->XMM_S(1); 83086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_S(3) = s->XMM_S(2) - s->XMM_S(3); 83186797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 83286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 83386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 83486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_hsubpd(XMMReg *d, XMMReg *s) 83586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 83686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMMReg r; 83786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_D(0) = d->XMM_D(0) - d->XMM_D(1); 83886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.XMM_D(1) = s->XMM_D(0) - s->XMM_D(1); 83986797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 84086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 84186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 84286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_addsubps(XMMReg *d, XMMReg *s) 84386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 84486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(0) = d->XMM_S(0) - s->XMM_S(0); 84586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(1) = d->XMM_S(1) + s->XMM_S(1); 84686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(2) = d->XMM_S(2) - s->XMM_S(2); 84786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_S(3) = d->XMM_S(3) + s->XMM_S(3); 84886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 84986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 85086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_addsubpd(XMMReg *d, XMMReg *s) 85186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 85286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(0) = d->XMM_D(0) - s->XMM_D(0); 85386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_D(1) = d->XMM_D(1) + s->XMM_D(1); 85486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 85586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 85686797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* XXX: unordered */ 85786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_CMP(name, F)\ 85886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## ps (Reg *d, Reg *s)\ 85986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 86086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = F(32, d->XMM_S(0), s->XMM_S(0));\ 86186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(1) = F(32, d->XMM_S(1), s->XMM_S(1));\ 86286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(2) = F(32, d->XMM_S(2), s->XMM_S(2));\ 86386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(3) = F(32, d->XMM_S(3), s->XMM_S(3));\ 86486797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 86586797937017f52bff088d02edf64fb931177a7eaJun Nakajima\ 86686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## ss (Reg *d, Reg *s)\ 86786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 86886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_L(0) = F(32, d->XMM_S(0), s->XMM_S(0));\ 86986797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 87086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## pd (Reg *d, Reg *s)\ 87186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 87286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_Q(0) = F(64, d->XMM_D(0), s->XMM_D(0));\ 87386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_Q(1) = F(64, d->XMM_D(1), s->XMM_D(1));\ 87486797937017f52bff088d02edf64fb931177a7eaJun Nakajima}\ 87586797937017f52bff088d02edf64fb931177a7eaJun Nakajima\ 87686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ ## name ## sd (Reg *d, Reg *s)\ 87786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 87886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->XMM_Q(0) = F(64, d->XMM_D(0), s->XMM_D(0));\ 87986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 88086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 88186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPEQ(size, a, b) float ## size ## _eq(a, b, &env->sse_status) ? -1 : 0 88286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPLT(size, a, b) float ## size ## _lt(a, b, &env->sse_status) ? -1 : 0 88386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPLE(size, a, b) float ## size ## _le(a, b, &env->sse_status) ? -1 : 0 88486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPUNORD(size, a, b) float ## size ## _unordered(a, b, &env->sse_status) ? - 1 : 0 88586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPNEQ(size, a, b) float ## size ## _eq(a, b, &env->sse_status) ? 0 : -1 88686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPNLT(size, a, b) float ## size ## _lt(a, b, &env->sse_status) ? 0 : -1 88786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPNLE(size, a, b) float ## size ## _le(a, b, &env->sse_status) ? 0 : -1 88886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FPU_CMPORD(size, a, b) float ## size ## _unordered(a, b, &env->sse_status) ? 0 : -1 88986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 89086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpeq, FPU_CMPEQ) 89186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmplt, FPU_CMPLT) 89286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmple, FPU_CMPLE) 89386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpunord, FPU_CMPUNORD) 89486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpneq, FPU_CMPNEQ) 89586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpnlt, FPU_CMPNLT) 89686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpnle, FPU_CMPNLE) 89786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_CMP(cmpord, FPU_CMPORD) 89886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 89986797937017f52bff088d02edf64fb931177a7eaJun Nakajimaconst int comis_eflags[4] = {CC_C, CC_Z, 0, CC_Z | CC_P | CC_C}; 90086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 90186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ucomiss(Reg *d, Reg *s) 90286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 90386797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret; 90486797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32 s0, s1; 90586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 90686797937017f52bff088d02edf64fb931177a7eaJun Nakajima s0 = d->XMM_S(0); 90786797937017f52bff088d02edf64fb931177a7eaJun Nakajima s1 = s->XMM_S(0); 90886797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret = float32_compare_quiet(s0, s1, &env->sse_status); 90986797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = comis_eflags[ret + 1]; 91086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 91186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 91286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_comiss(Reg *d, Reg *s) 91386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 91486797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret; 91586797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32 s0, s1; 91686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 91786797937017f52bff088d02edf64fb931177a7eaJun Nakajima s0 = d->XMM_S(0); 91886797937017f52bff088d02edf64fb931177a7eaJun Nakajima s1 = s->XMM_S(0); 91986797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret = float32_compare(s0, s1, &env->sse_status); 92086797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = comis_eflags[ret + 1]; 92186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 92286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 92386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_ucomisd(Reg *d, Reg *s) 92486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 92586797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret; 92686797937017f52bff088d02edf64fb931177a7eaJun Nakajima float64 d0, d1; 92786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 92886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d0 = d->XMM_D(0); 92986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d1 = s->XMM_D(0); 93086797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret = float64_compare_quiet(d0, d1, &env->sse_status); 93186797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = comis_eflags[ret + 1]; 93286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 93386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 93486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_comisd(Reg *d, Reg *s) 93586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 93686797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret; 93786797937017f52bff088d02edf64fb931177a7eaJun Nakajima float64 d0, d1; 93886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 93986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d0 = d->XMM_D(0); 94086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d1 = s->XMM_D(0); 94186797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret = float64_compare(d0, d1, &env->sse_status); 94286797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = comis_eflags[ret + 1]; 94386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 94486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 94586797937017f52bff088d02edf64fb931177a7eaJun Nakajimauint32_t helper_movmskps(Reg *s) 94686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 94786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int b0, b1, b2, b3; 94886797937017f52bff088d02edf64fb931177a7eaJun Nakajima b0 = s->XMM_L(0) >> 31; 94986797937017f52bff088d02edf64fb931177a7eaJun Nakajima b1 = s->XMM_L(1) >> 31; 95086797937017f52bff088d02edf64fb931177a7eaJun Nakajima b2 = s->XMM_L(2) >> 31; 95186797937017f52bff088d02edf64fb931177a7eaJun Nakajima b3 = s->XMM_L(3) >> 31; 95286797937017f52bff088d02edf64fb931177a7eaJun Nakajima return b0 | (b1 << 1) | (b2 << 2) | (b3 << 3); 95386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 95486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 95586797937017f52bff088d02edf64fb931177a7eaJun Nakajimauint32_t helper_movmskpd(Reg *s) 95686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 95786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int b0, b1; 95886797937017f52bff088d02edf64fb931177a7eaJun Nakajima b0 = s->XMM_L(1) >> 31; 95986797937017f52bff088d02edf64fb931177a7eaJun Nakajima b1 = s->XMM_L(3) >> 31; 96086797937017f52bff088d02edf64fb931177a7eaJun Nakajima return b0 | (b1 << 1); 96186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 96286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 96386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 96486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 96586797937017f52bff088d02edf64fb931177a7eaJun Nakajimauint32_t glue(helper_pmovmskb, SUFFIX)(Reg *s) 96686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 96786797937017f52bff088d02edf64fb931177a7eaJun Nakajima uint32_t val; 96886797937017f52bff088d02edf64fb931177a7eaJun Nakajima val = 0; 96986797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(0) >> 7); 97086797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(1) >> 6) & 0x02; 97186797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(2) >> 5) & 0x04; 97286797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(3) >> 4) & 0x08; 97386797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(4) >> 3) & 0x10; 97486797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(5) >> 2) & 0x20; 97586797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(6) >> 1) & 0x40; 97686797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(7)) & 0x80; 97786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 97886797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(8) << 1) & 0x0100; 97986797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(9) << 2) & 0x0200; 98086797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(10) << 3) & 0x0400; 98186797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(11) << 4) & 0x0800; 98286797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(12) << 5) & 0x1000; 98386797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(13) << 6) & 0x2000; 98486797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(14) << 7) & 0x4000; 98586797937017f52bff088d02edf64fb931177a7eaJun Nakajima val |= (s->B(15) << 8) & 0x8000; 98686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 98786797937017f52bff088d02edf64fb931177a7eaJun Nakajima return val; 98886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 98986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 99086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_packsswb, SUFFIX) (Reg *d, Reg *s) 99186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 99286797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 99386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 99486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(0) = satsb((int16_t)d->W(0)); 99586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(1) = satsb((int16_t)d->W(1)); 99686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(2) = satsb((int16_t)d->W(2)); 99786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(3) = satsb((int16_t)d->W(3)); 99886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 99986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(4) = satsb((int16_t)d->W(4)); 100086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(5) = satsb((int16_t)d->W(5)); 100186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(6) = satsb((int16_t)d->W(6)); 100286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(7) = satsb((int16_t)d->W(7)); 100386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 100486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 0) = satsb((int16_t)s->W(0)); 100586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 1) = satsb((int16_t)s->W(1)); 100686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 2) = satsb((int16_t)s->W(2)); 100786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 3) = satsb((int16_t)s->W(3)); 100886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 100986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(12) = satsb((int16_t)s->W(4)); 101086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(13) = satsb((int16_t)s->W(5)); 101186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(14) = satsb((int16_t)s->W(6)); 101286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(15) = satsb((int16_t)s->W(7)); 101386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 101486797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 101586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 101686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 101786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_packuswb, SUFFIX) (Reg *d, Reg *s) 101886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 101986797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 102086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 102186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(0) = satub((int16_t)d->W(0)); 102286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(1) = satub((int16_t)d->W(1)); 102386797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(2) = satub((int16_t)d->W(2)); 102486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(3) = satub((int16_t)d->W(3)); 102586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 102686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(4) = satub((int16_t)d->W(4)); 102786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(5) = satub((int16_t)d->W(5)); 102886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(6) = satub((int16_t)d->W(6)); 102986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(7) = satub((int16_t)d->W(7)); 103086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 103186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 0) = satub((int16_t)s->W(0)); 103286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 1) = satub((int16_t)s->W(1)); 103386797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 2) = satub((int16_t)s->W(2)); 103486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B((4 << SHIFT) + 3) = satub((int16_t)s->W(3)); 103586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 103686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(12) = satub((int16_t)s->W(4)); 103786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(13) = satub((int16_t)s->W(5)); 103886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(14) = satub((int16_t)s->W(6)); 103986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(15) = satub((int16_t)s->W(7)); 104086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 104186797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 104286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 104386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 104486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_packssdw, SUFFIX) (Reg *d, Reg *s) 104586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 104686797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 104786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 104886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(0) = satsw(d->L(0)); 104986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(1) = satsw(d->L(1)); 105086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 105186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(2) = satsw(d->L(2)); 105286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(3) = satsw(d->L(3)); 105386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 105486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W((2 << SHIFT) + 0) = satsw(s->L(0)); 105586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W((2 << SHIFT) + 1) = satsw(s->L(1)); 105686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 105786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(6) = satsw(s->L(2)); 105886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(7) = satsw(s->L(3)); 105986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 106086797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 106186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 106286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 106386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define UNPCK_OP(base_name, base) \ 106486797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 106586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_punpck ## base_name ## bw, SUFFIX) (Reg *d, Reg *s) \ 106686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ \ 106786797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; \ 106886797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 106986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(0) = d->B((base << (SHIFT + 2)) + 0); \ 107086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(1) = s->B((base << (SHIFT + 2)) + 0); \ 107186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(2) = d->B((base << (SHIFT + 2)) + 1); \ 107286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(3) = s->B((base << (SHIFT + 2)) + 1); \ 107386797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(4) = d->B((base << (SHIFT + 2)) + 2); \ 107486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(5) = s->B((base << (SHIFT + 2)) + 2); \ 107586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(6) = d->B((base << (SHIFT + 2)) + 3); \ 107686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(7) = s->B((base << (SHIFT + 2)) + 3); \ 107786797937017f52bff088d02edf64fb931177a7eaJun NakajimaXMM_ONLY( \ 107886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(8) = d->B((base << (SHIFT + 2)) + 4); \ 107986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(9) = s->B((base << (SHIFT + 2)) + 4); \ 108086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(10) = d->B((base << (SHIFT + 2)) + 5); \ 108186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(11) = s->B((base << (SHIFT + 2)) + 5); \ 108286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(12) = d->B((base << (SHIFT + 2)) + 6); \ 108386797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(13) = s->B((base << (SHIFT + 2)) + 6); \ 108486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(14) = d->B((base << (SHIFT + 2)) + 7); \ 108586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(15) = s->B((base << (SHIFT + 2)) + 7); \ 108686797937017f52bff088d02edf64fb931177a7eaJun Nakajima) \ 108786797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; \ 108886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} \ 108986797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 109086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_punpck ## base_name ## wd, SUFFIX) (Reg *d, Reg *s) \ 109186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ \ 109286797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; \ 109386797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 109486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(0) = d->W((base << (SHIFT + 1)) + 0); \ 109586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(1) = s->W((base << (SHIFT + 1)) + 0); \ 109686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(2) = d->W((base << (SHIFT + 1)) + 1); \ 109786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(3) = s->W((base << (SHIFT + 1)) + 1); \ 109886797937017f52bff088d02edf64fb931177a7eaJun NakajimaXMM_ONLY( \ 109986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(4) = d->W((base << (SHIFT + 1)) + 2); \ 110086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(5) = s->W((base << (SHIFT + 1)) + 2); \ 110186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(6) = d->W((base << (SHIFT + 1)) + 3); \ 110286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(7) = s->W((base << (SHIFT + 1)) + 3); \ 110386797937017f52bff088d02edf64fb931177a7eaJun Nakajima) \ 110486797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; \ 110586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} \ 110686797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 110786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_punpck ## base_name ## dq, SUFFIX) (Reg *d, Reg *s) \ 110886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ \ 110986797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; \ 111086797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 111186797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(0) = d->L((base << SHIFT) + 0); \ 111286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(1) = s->L((base << SHIFT) + 0); \ 111386797937017f52bff088d02edf64fb931177a7eaJun NakajimaXMM_ONLY( \ 111486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(2) = d->L((base << SHIFT) + 1); \ 111586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.L(3) = s->L((base << SHIFT) + 1); \ 111686797937017f52bff088d02edf64fb931177a7eaJun Nakajima) \ 111786797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; \ 111886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} \ 111986797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 112086797937017f52bff088d02edf64fb931177a7eaJun NakajimaXMM_ONLY( \ 112186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_punpck ## base_name ## qdq, SUFFIX) (Reg *d, Reg *s) \ 112286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ \ 112386797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; \ 112486797937017f52bff088d02edf64fb931177a7eaJun Nakajima \ 112586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = d->Q(base); \ 112686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(1) = s->Q(base); \ 112786797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; \ 112886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} \ 112986797937017f52bff088d02edf64fb931177a7eaJun Nakajima) 113086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 113186797937017f52bff088d02edf64fb931177a7eaJun NakajimaUNPCK_OP(l, 0) 113286797937017f52bff088d02edf64fb931177a7eaJun NakajimaUNPCK_OP(h, 1) 113386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 113486797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* 3DNow! float ops */ 113586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 113686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pi2fd(MMXReg *d, MMXReg *s) 113786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 113886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = int32_to_float32(s->MMX_L(0), &env->mmx_status); 113986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = int32_to_float32(s->MMX_L(1), &env->mmx_status); 114086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 114186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 114286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pi2fw(MMXReg *d, MMXReg *s) 114386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 114486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = int32_to_float32((int16_t)s->MMX_W(0), &env->mmx_status); 114586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = int32_to_float32((int16_t)s->MMX_W(2), &env->mmx_status); 114686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 114786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 114886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pf2id(MMXReg *d, MMXReg *s) 114986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 115086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_to_int32_round_to_zero(s->MMX_S(0), &env->mmx_status); 115186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_to_int32_round_to_zero(s->MMX_S(1), &env->mmx_status); 115286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 115386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 115486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pf2iw(MMXReg *d, MMXReg *s) 115586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 115686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = satsw(float32_to_int32_round_to_zero(s->MMX_S(0), &env->mmx_status)); 115786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = satsw(float32_to_int32_round_to_zero(s->MMX_S(1), &env->mmx_status)); 115886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 115986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 116086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfacc(MMXReg *d, MMXReg *s) 116186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 116286797937017f52bff088d02edf64fb931177a7eaJun Nakajima MMXReg r; 116386797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(0) = float32_add(d->MMX_S(0), d->MMX_S(1), &env->mmx_status); 116486797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(1) = float32_add(s->MMX_S(0), s->MMX_S(1), &env->mmx_status); 116586797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 116686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 116786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 116886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfadd(MMXReg *d, MMXReg *s) 116986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 117086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = float32_add(d->MMX_S(0), s->MMX_S(0), &env->mmx_status); 117186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = float32_add(d->MMX_S(1), s->MMX_S(1), &env->mmx_status); 117286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 117386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 117486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfcmpeq(MMXReg *d, MMXReg *s) 117586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 117686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_eq(d->MMX_S(0), s->MMX_S(0), &env->mmx_status) ? -1 : 0; 117786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_eq(d->MMX_S(1), s->MMX_S(1), &env->mmx_status) ? -1 : 0; 117886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 117986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 118086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfcmpge(MMXReg *d, MMXReg *s) 118186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 118286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_le(s->MMX_S(0), d->MMX_S(0), &env->mmx_status) ? -1 : 0; 118386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_le(s->MMX_S(1), d->MMX_S(1), &env->mmx_status) ? -1 : 0; 118486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 118586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 118686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfcmpgt(MMXReg *d, MMXReg *s) 118786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 118886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = float32_lt(s->MMX_S(0), d->MMX_S(0), &env->mmx_status) ? -1 : 0; 118986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = float32_lt(s->MMX_S(1), d->MMX_S(1), &env->mmx_status) ? -1 : 0; 119086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 119186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 119286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfmax(MMXReg *d, MMXReg *s) 119386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 119486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (float32_lt(d->MMX_S(0), s->MMX_S(0), &env->mmx_status)) 119586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = s->MMX_S(0); 119686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (float32_lt(d->MMX_S(1), s->MMX_S(1), &env->mmx_status)) 119786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = s->MMX_S(1); 119886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 119986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 120086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfmin(MMXReg *d, MMXReg *s) 120186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 120286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (float32_lt(s->MMX_S(0), d->MMX_S(0), &env->mmx_status)) 120386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = s->MMX_S(0); 120486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (float32_lt(s->MMX_S(1), d->MMX_S(1), &env->mmx_status)) 120586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = s->MMX_S(1); 120686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 120786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 120886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfmul(MMXReg *d, MMXReg *s) 120986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 121086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = float32_mul(d->MMX_S(0), s->MMX_S(0), &env->mmx_status); 121186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = float32_mul(d->MMX_S(1), s->MMX_S(1), &env->mmx_status); 121286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 121386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 121486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfnacc(MMXReg *d, MMXReg *s) 121586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 121686797937017f52bff088d02edf64fb931177a7eaJun Nakajima MMXReg r; 121786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(0) = float32_sub(d->MMX_S(0), d->MMX_S(1), &env->mmx_status); 121886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(1) = float32_sub(s->MMX_S(0), s->MMX_S(1), &env->mmx_status); 121986797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 122086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 122186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 122286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfpnacc(MMXReg *d, MMXReg *s) 122386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 122486797937017f52bff088d02edf64fb931177a7eaJun Nakajima MMXReg r; 122586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(0) = float32_sub(d->MMX_S(0), d->MMX_S(1), &env->mmx_status); 122686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_S(1) = float32_add(s->MMX_S(0), s->MMX_S(1), &env->mmx_status); 122786797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 122886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 122986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 123086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfrcp(MMXReg *d, MMXReg *s) 123186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 123286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = approx_rcp(s->MMX_S(0)); 123386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = d->MMX_S(0); 123486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 123586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 123686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfrsqrt(MMXReg *d, MMXReg *s) 123786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 123886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) = s->MMX_L(0) & 0x7fffffff; 123986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = approx_rsqrt(d->MMX_S(1)); 124086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(1) |= s->MMX_L(0) & 0x80000000; 124186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_L(0) = d->MMX_L(1); 124286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 124386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 124486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfsub(MMXReg *d, MMXReg *s) 124586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 124686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = float32_sub(d->MMX_S(0), s->MMX_S(0), &env->mmx_status); 124786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = float32_sub(d->MMX_S(1), s->MMX_S(1), &env->mmx_status); 124886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 124986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 125086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pfsubr(MMXReg *d, MMXReg *s) 125186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 125286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(0) = float32_sub(s->MMX_S(0), d->MMX_S(0), &env->mmx_status); 125386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->MMX_S(1) = float32_sub(s->MMX_S(1), d->MMX_S(1), &env->mmx_status); 125486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 125586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 125686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid helper_pswapd(MMXReg *d, MMXReg *s) 125786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 125886797937017f52bff088d02edf64fb931177a7eaJun Nakajima MMXReg r; 125986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_L(0) = s->MMX_L(1); 126086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.MMX_L(1) = s->MMX_L(0); 126186797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 126286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 126386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 126486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 126586797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* SSSE3 op helpers */ 126686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pshufb, SUFFIX) (Reg *d, Reg *s) 126786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 126886797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 126986797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 127086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 127186797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i < (8 << SHIFT); i++) 127286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.B(i) = (s->B(i) & 0x80) ? 0 : (d->B(s->B(i) & ((8 << SHIFT) - 1))); 127386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 127486797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 127586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 127686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 127786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phaddw, SUFFIX) (Reg *d, Reg *s) 127886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 127986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = (int16_t)d->W(0) + (int16_t)d->W(1); 128086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = (int16_t)d->W(2) + (int16_t)d->W(3); 128186797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(2) = (int16_t)d->W(4) + (int16_t)d->W(5)); 128286797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(3) = (int16_t)d->W(6) + (int16_t)d->W(7)); 128386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 0) = (int16_t)s->W(0) + (int16_t)s->W(1); 128486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 1) = (int16_t)s->W(2) + (int16_t)s->W(3); 128586797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(6) = (int16_t)s->W(4) + (int16_t)s->W(5)); 128686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(7) = (int16_t)s->W(6) + (int16_t)s->W(7)); 128786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 128886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 128986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phaddd, SUFFIX) (Reg *d, Reg *s) 129086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 129186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = (int32_t)d->L(0) + (int32_t)d->L(1); 129286797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->L(1) = (int32_t)d->L(2) + (int32_t)d->L(3)); 129386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L((1 << SHIFT) + 0) = (int32_t)s->L(0) + (int32_t)s->L(1); 129486797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->L(3) = (int32_t)s->L(2) + (int32_t)s->L(3)); 129586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 129686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 129786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phaddsw, SUFFIX) (Reg *d, Reg *s) 129886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 129986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = satsw((int16_t)d->W(0) + (int16_t)d->W(1)); 130086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = satsw((int16_t)d->W(2) + (int16_t)d->W(3)); 130186797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(2) = satsw((int16_t)d->W(4) + (int16_t)d->W(5))); 130286797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(3) = satsw((int16_t)d->W(6) + (int16_t)d->W(7))); 130386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 0) = satsw((int16_t)s->W(0) + (int16_t)s->W(1)); 130486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 1) = satsw((int16_t)s->W(2) + (int16_t)s->W(3)); 130586797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(6) = satsw((int16_t)s->W(4) + (int16_t)s->W(5))); 130686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(7) = satsw((int16_t)s->W(6) + (int16_t)s->W(7))); 130786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 130886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 130986797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pmaddubsw, SUFFIX) (Reg *d, Reg *s) 131086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 131186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = satsw((int8_t)s->B( 0) * (uint8_t)d->B( 0) + 131286797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B( 1) * (uint8_t)d->B( 1)); 131386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = satsw((int8_t)s->B( 2) * (uint8_t)d->B( 2) + 131486797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B( 3) * (uint8_t)d->B( 3)); 131586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) = satsw((int8_t)s->B( 4) * (uint8_t)d->B( 4) + 131686797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B( 5) * (uint8_t)d->B( 5)); 131786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) = satsw((int8_t)s->B( 6) * (uint8_t)d->B( 6) + 131886797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B( 7) * (uint8_t)d->B( 7)); 131986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 132086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) = satsw((int8_t)s->B( 8) * (uint8_t)d->B( 8) + 132186797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B( 9) * (uint8_t)d->B( 9)); 132286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) = satsw((int8_t)s->B(10) * (uint8_t)d->B(10) + 132386797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B(11) * (uint8_t)d->B(11)); 132486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) = satsw((int8_t)s->B(12) * (uint8_t)d->B(12) + 132586797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B(13) * (uint8_t)d->B(13)); 132686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) = satsw((int8_t)s->B(14) * (uint8_t)d->B(14) + 132786797937017f52bff088d02edf64fb931177a7eaJun Nakajima (int8_t)s->B(15) * (uint8_t)d->B(15)); 132886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 132986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 133086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 133186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phsubw, SUFFIX) (Reg *d, Reg *s) 133286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 133386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = (int16_t)d->W(0) - (int16_t)d->W(1); 133486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = (int16_t)d->W(2) - (int16_t)d->W(3); 133586797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(2) = (int16_t)d->W(4) - (int16_t)d->W(5)); 133686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(3) = (int16_t)d->W(6) - (int16_t)d->W(7)); 133786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 0) = (int16_t)s->W(0) - (int16_t)s->W(1); 133886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 1) = (int16_t)s->W(2) - (int16_t)s->W(3); 133986797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(6) = (int16_t)s->W(4) - (int16_t)s->W(5)); 134086797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(7) = (int16_t)s->W(6) - (int16_t)s->W(7)); 134186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 134286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 134386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phsubd, SUFFIX) (Reg *d, Reg *s) 134486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 134586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = (int32_t)d->L(0) - (int32_t)d->L(1); 134686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->L(1) = (int32_t)d->L(2) - (int32_t)d->L(3)); 134786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L((1 << SHIFT) + 0) = (int32_t)s->L(0) - (int32_t)s->L(1); 134886797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->L(3) = (int32_t)s->L(2) - (int32_t)s->L(3)); 134986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 135086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 135186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phsubsw, SUFFIX) (Reg *d, Reg *s) 135286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 135386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = satsw((int16_t)d->W(0) - (int16_t)d->W(1)); 135486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = satsw((int16_t)d->W(2) - (int16_t)d->W(3)); 135586797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(2) = satsw((int16_t)d->W(4) - (int16_t)d->W(5))); 135686797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(3) = satsw((int16_t)d->W(6) - (int16_t)d->W(7))); 135786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 0) = satsw((int16_t)s->W(0) - (int16_t)s->W(1)); 135886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W((2 << SHIFT) + 1) = satsw((int16_t)s->W(2) - (int16_t)s->W(3)); 135986797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(6) = satsw((int16_t)s->W(4) - (int16_t)s->W(5))); 136086797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(d->W(7) = satsw((int16_t)s->W(6) - (int16_t)s->W(7))); 136186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 136286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 136386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FABSB(_, x) x > INT8_MAX ? -(int8_t ) x : x 136486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FABSW(_, x) x > INT16_MAX ? -(int16_t) x : x 136586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FABSL(_, x) x > INT32_MAX ? -(int32_t) x : x 136686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pabsb, FABSB) 136786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pabsw, FABSW) 136886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pabsd, FABSL) 136986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 137086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULHRSW(d, s) ((int16_t) d * (int16_t) s + 0x4000) >> 15 137186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmulhrsw, FMULHRSW) 137286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 137386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSIGNB(d, s) s <= INT8_MAX ? s ? d : 0 : -(int8_t ) d 137486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSIGNW(d, s) s <= INT16_MAX ? s ? d : 0 : -(int16_t) d 137586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FSIGNL(d, s) s <= INT32_MAX ? s ? d : 0 : -(int32_t) d 137686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_psignb, FSIGNB) 137786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_psignw, FSIGNW) 137886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_psignd, FSIGNL) 137986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 138086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_palignr, SUFFIX) (Reg *d, Reg *s, int32_t shift) 138186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 138286797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 138386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 138486797937017f52bff088d02edf64fb931177a7eaJun Nakajima /* XXX could be checked during translation */ 138586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (shift >= (16 << SHIFT)) { 138686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = 0; 138786797937017f52bff088d02edf64fb931177a7eaJun Nakajima XMM_ONLY(r.Q(1) = 0); 138886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 138986797937017f52bff088d02edf64fb931177a7eaJun Nakajima shift <<= 3; 139086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SHR(v, i) (i < 64 && i > -64 ? i > 0 ? v >> (i) : (v << -(i)) : 0) 139186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 0 139286797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = SHR(s->Q(0), shift - 0) | 139386797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(d->Q(0), shift - 64); 139486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#else 139586797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(0) = SHR(s->Q(0), shift - 0) | 139686797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(s->Q(1), shift - 64) | 139786797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(d->Q(0), shift - 128) | 139886797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(d->Q(1), shift - 192); 139986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.Q(1) = SHR(s->Q(0), shift + 64) | 140086797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(s->Q(1), shift - 0) | 140186797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(d->Q(0), shift - 64) | 140286797937017f52bff088d02edf64fb931177a7eaJun Nakajima SHR(d->Q(1), shift - 128); 140386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 140486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef SHR 140586797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 140686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 140786797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 140886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 140986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 141086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define XMM0 env->xmm_regs[0] 141186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 141286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if SHIFT == 1 141386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_V(name, elem, num, F)\ 141486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 141586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 141686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(0) = F(d->elem(0), s->elem(0), XMM0.elem(0));\ 141786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(1) = F(d->elem(1), s->elem(1), XMM0.elem(1));\ 141886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 2) {\ 141986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(2) = F(d->elem(2), s->elem(2), XMM0.elem(2));\ 142086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(3) = F(d->elem(3), s->elem(3), XMM0.elem(3));\ 142186797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 4) {\ 142286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(4) = F(d->elem(4), s->elem(4), XMM0.elem(4));\ 142386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(5) = F(d->elem(5), s->elem(5), XMM0.elem(5));\ 142486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(6) = F(d->elem(6), s->elem(6), XMM0.elem(6));\ 142586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(7) = F(d->elem(7), s->elem(7), XMM0.elem(7));\ 142686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 8) {\ 142786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(8) = F(d->elem(8), s->elem(8), XMM0.elem(8));\ 142886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(9) = F(d->elem(9), s->elem(9), XMM0.elem(9));\ 142986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(10) = F(d->elem(10), s->elem(10), XMM0.elem(10));\ 143086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(11) = F(d->elem(11), s->elem(11), XMM0.elem(11));\ 143186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(12) = F(d->elem(12), s->elem(12), XMM0.elem(12));\ 143286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(13) = F(d->elem(13), s->elem(13), XMM0.elem(13));\ 143386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(14) = F(d->elem(14), s->elem(14), XMM0.elem(14));\ 143486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(15) = F(d->elem(15), s->elem(15), XMM0.elem(15));\ 143586797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 143686797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 143786797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 143886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 143986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 144086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_I(name, elem, num, F)\ 144186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s, uint32_t imm)\ 144286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 144386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(0) = F(d->elem(0), s->elem(0), ((imm >> 0) & 1));\ 144486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(1) = F(d->elem(1), s->elem(1), ((imm >> 1) & 1));\ 144586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 2) {\ 144686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(2) = F(d->elem(2), s->elem(2), ((imm >> 2) & 1));\ 144786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(3) = F(d->elem(3), s->elem(3), ((imm >> 3) & 1));\ 144886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 4) {\ 144986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(4) = F(d->elem(4), s->elem(4), ((imm >> 4) & 1));\ 145086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(5) = F(d->elem(5), s->elem(5), ((imm >> 5) & 1));\ 145186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(6) = F(d->elem(6), s->elem(6), ((imm >> 6) & 1));\ 145286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(7) = F(d->elem(7), s->elem(7), ((imm >> 7) & 1));\ 145386797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 8) {\ 145486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(8) = F(d->elem(8), s->elem(8), ((imm >> 8) & 1));\ 145586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(9) = F(d->elem(9), s->elem(9), ((imm >> 9) & 1));\ 145686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(10) = F(d->elem(10), s->elem(10), ((imm >> 10) & 1));\ 145786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(11) = F(d->elem(11), s->elem(11), ((imm >> 11) & 1));\ 145886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(12) = F(d->elem(12), s->elem(12), ((imm >> 12) & 1));\ 145986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(13) = F(d->elem(13), s->elem(13), ((imm >> 13) & 1));\ 146086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(14) = F(d->elem(14), s->elem(14), ((imm >> 14) & 1));\ 146186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(15) = F(d->elem(15), s->elem(15), ((imm >> 15) & 1));\ 146286797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 146386797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 146486797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 146586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 146686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 146786797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* SSE4.1 op helpers */ 146886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FBLENDVB(d, s, m) (m & 0x80) ? s : d 146986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FBLENDVPS(d, s, m) (m & 0x80000000) ? s : d 147086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FBLENDVPD(d, s, m) (m & 0x8000000000000000LL) ? s : d 147186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_V(helper_pblendvb, B, 16, FBLENDVB) 147286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_V(helper_blendvps, L, 4, FBLENDVPS) 147386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_V(helper_blendvpd, Q, 2, FBLENDVPD) 147486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 147586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_ptest, SUFFIX) (Reg *d, Reg *s) 147686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 147786797937017f52bff088d02edf64fb931177a7eaJun Nakajima uint64_t zf = (s->Q(0) & d->Q(0)) | (s->Q(1) & d->Q(1)); 147886797937017f52bff088d02edf64fb931177a7eaJun Nakajima uint64_t cf = (s->Q(0) & ~d->Q(0)) | (s->Q(1) & ~d->Q(1)); 147986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 148086797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = (zf ? 0 : CC_Z) | (cf ? 0 : CC_C); 148186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 148286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 148386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define SSE_HELPER_F(name, elem, num, F)\ 148486797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(name, SUFFIX) (Reg *d, Reg *s)\ 148586797937017f52bff088d02edf64fb931177a7eaJun Nakajima{\ 148686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(0) = F(0);\ 148786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(1) = F(1);\ 148886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 2) {\ 148986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(2) = F(2);\ 149086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(3) = F(3);\ 149186797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (num > 4) {\ 149286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(4) = F(4);\ 149386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(5) = F(5);\ 149486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(6) = F(6);\ 149586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->elem(7) = F(7);\ 149686797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 149786797937017f52bff088d02edf64fb931177a7eaJun Nakajima }\ 149886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 149986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 150086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxbw, W, 8, (int8_t) s->B) 150186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxbd, L, 4, (int8_t) s->B) 150286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxbq, Q, 2, (int8_t) s->B) 150386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxwd, L, 4, (int16_t) s->W) 150486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxwq, Q, 2, (int16_t) s->W) 150586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovsxdq, Q, 2, (int32_t) s->L) 150686797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxbw, W, 8, s->B) 150786797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxbd, L, 4, s->B) 150886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxbq, Q, 2, s->B) 150986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxwd, L, 4, s->W) 151086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxwq, Q, 2, s->W) 151186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_F(helper_pmovzxdq, Q, 2, s->L) 151286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 151386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pmuldq, SUFFIX) (Reg *d, Reg *s) 151486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 151586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = (int64_t) (int32_t) d->L(0) * (int32_t) s->L(0); 151686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = (int64_t) (int32_t) d->L(2) * (int32_t) s->L(2); 151786797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 151886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 151986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPEQQ(d, s) d == s ? -1 : 0 152086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_pcmpeqq, FCMPEQQ) 152186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 152286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_packusdw, SUFFIX) (Reg *d, Reg *s) 152386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 152486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = satuw((int32_t) d->L(0)); 152586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = satuw((int32_t) d->L(1)); 152686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(2) = satuw((int32_t) d->L(2)); 152786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(3) = satuw((int32_t) d->L(3)); 152886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(4) = satuw((int32_t) s->L(0)); 152986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(5) = satuw((int32_t) s->L(1)); 153086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(6) = satuw((int32_t) s->L(2)); 153186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(7) = satuw((int32_t) s->L(3)); 153286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 153386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 153486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMINSB(d, s) MIN((int8_t) d, (int8_t) s) 153586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMINSD(d, s) MIN((int32_t) d, (int32_t) s) 153686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMAXSB(d, s) MAX((int8_t) d, (int8_t) s) 153786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMAXSD(d, s) MAX((int32_t) d, (int32_t) s) 153886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pminsb, FMINSB) 153986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pminsd, FMINSD) 154086797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pminuw, MIN) 154186797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pminud, MIN) 154286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_B(helper_pmaxsb, FMAXSB) 154386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pmaxsd, FMAXSD) 154486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_W(helper_pmaxuw, MAX) 154586797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pmaxud, MAX) 154686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 154786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FMULLD(d, s) (int32_t) d * (int32_t) s 154886797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_L(helper_pmulld, FMULLD) 154986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 155086797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_phminposuw, SUFFIX) (Reg *d, Reg *s) 155186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 155286797937017f52bff088d02edf64fb931177a7eaJun Nakajima int idx = 0; 155386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 155486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(1) < s->W(idx)) 155586797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 1; 155686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(2) < s->W(idx)) 155786797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 2; 155886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(3) < s->W(idx)) 155986797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 3; 156086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(4) < s->W(idx)) 156186797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 4; 156286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(5) < s->W(idx)) 156386797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 5; 156486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(6) < s->W(idx)) 156586797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 6; 156686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (s->W(7) < s->W(idx)) 156786797937017f52bff088d02edf64fb931177a7eaJun Nakajima idx = 7; 156886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 156986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 157086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = 0; 157186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(1) = idx; 157286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(0) = s->W(idx); 157386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 157486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 157586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_roundps, SUFFIX) (Reg *d, Reg *s, uint32_t mode) 157686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 157786797937017f52bff088d02edf64fb931177a7eaJun Nakajima signed char prev_rounding_mode; 157886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 157986797937017f52bff088d02edf64fb931177a7eaJun Nakajima prev_rounding_mode = env->sse_status.float_rounding_mode; 158086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (!(mode & (1 << 2))) 158186797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch (mode & 3) { 158286797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 158386797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_nearest_even, &env->sse_status); 158486797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 158586797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 158686797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_down, &env->sse_status); 158786797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 158886797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 158986797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_up, &env->sse_status); 159086797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 159186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 159286797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_to_zero, &env->sse_status); 159386797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 159486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 159586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 159686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = float64_round_to_int(s->L(0), &env->sse_status); 159786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = float64_round_to_int(s->L(1), &env->sse_status); 159886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) = float64_round_to_int(s->L(2), &env->sse_status); 159986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) = float64_round_to_int(s->L(3), &env->sse_status); 160086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 160186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if 0 /* TODO */ 160286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mode & (1 << 3)) 160386797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_exception_flags( 160486797937017f52bff088d02edf64fb931177a7eaJun Nakajima get_float_exception_flags(&env->sse_status) & 160586797937017f52bff088d02edf64fb931177a7eaJun Nakajima ~float_flag_inexact, 160686797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 160786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 160886797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->sse_status.float_rounding_mode = prev_rounding_mode; 160986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 161086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 161186797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_roundpd, SUFFIX) (Reg *d, Reg *s, uint32_t mode) 161286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 161386797937017f52bff088d02edf64fb931177a7eaJun Nakajima signed char prev_rounding_mode; 161486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 161586797937017f52bff088d02edf64fb931177a7eaJun Nakajima prev_rounding_mode = env->sse_status.float_rounding_mode; 161686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (!(mode & (1 << 2))) 161786797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch (mode & 3) { 161886797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 161986797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_nearest_even, &env->sse_status); 162086797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 162186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 162286797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_down, &env->sse_status); 162386797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 162486797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 162586797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_up, &env->sse_status); 162686797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 162786797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 162886797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_to_zero, &env->sse_status); 162986797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 163086797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 163186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 163286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = float64_round_to_int(s->Q(0), &env->sse_status); 163386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = float64_round_to_int(s->Q(1), &env->sse_status); 163486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 163586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if 0 /* TODO */ 163686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mode & (1 << 3)) 163786797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_exception_flags( 163886797937017f52bff088d02edf64fb931177a7eaJun Nakajima get_float_exception_flags(&env->sse_status) & 163986797937017f52bff088d02edf64fb931177a7eaJun Nakajima ~float_flag_inexact, 164086797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 164186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 164286797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->sse_status.float_rounding_mode = prev_rounding_mode; 164386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 164486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 164586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_roundss, SUFFIX) (Reg *d, Reg *s, uint32_t mode) 164686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 164786797937017f52bff088d02edf64fb931177a7eaJun Nakajima signed char prev_rounding_mode; 164886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 164986797937017f52bff088d02edf64fb931177a7eaJun Nakajima prev_rounding_mode = env->sse_status.float_rounding_mode; 165086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (!(mode & (1 << 2))) 165186797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch (mode & 3) { 165286797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 165386797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_nearest_even, &env->sse_status); 165486797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 165586797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 165686797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_down, &env->sse_status); 165786797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 165886797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 165986797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_up, &env->sse_status); 166086797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 166186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 166286797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_to_zero, &env->sse_status); 166386797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 166486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 166586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 166686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = float64_round_to_int(s->L(0), &env->sse_status); 166786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 166886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if 0 /* TODO */ 166986797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mode & (1 << 3)) 167086797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_exception_flags( 167186797937017f52bff088d02edf64fb931177a7eaJun Nakajima get_float_exception_flags(&env->sse_status) & 167286797937017f52bff088d02edf64fb931177a7eaJun Nakajima ~float_flag_inexact, 167386797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 167486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 167586797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->sse_status.float_rounding_mode = prev_rounding_mode; 167686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 167786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 167886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_roundsd, SUFFIX) (Reg *d, Reg *s, uint32_t mode) 167986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 168086797937017f52bff088d02edf64fb931177a7eaJun Nakajima signed char prev_rounding_mode; 168186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 168286797937017f52bff088d02edf64fb931177a7eaJun Nakajima prev_rounding_mode = env->sse_status.float_rounding_mode; 168386797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (!(mode & (1 << 2))) 168486797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch (mode & 3) { 168586797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 168686797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_nearest_even, &env->sse_status); 168786797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 168886797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 168986797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_down, &env->sse_status); 169086797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 169186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 169286797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_up, &env->sse_status); 169386797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 169486797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 169586797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_rounding_mode(float_round_to_zero, &env->sse_status); 169686797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 169786797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 169886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 169986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = float64_round_to_int(s->Q(0), &env->sse_status); 170086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 170186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#if 0 /* TODO */ 170286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mode & (1 << 3)) 170386797937017f52bff088d02edf64fb931177a7eaJun Nakajima set_float_exception_flags( 170486797937017f52bff088d02edf64fb931177a7eaJun Nakajima get_float_exception_flags(&env->sse_status) & 170586797937017f52bff088d02edf64fb931177a7eaJun Nakajima ~float_flag_inexact, 170686797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 170786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 170886797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->sse_status.float_rounding_mode = prev_rounding_mode; 170986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 171086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 171186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FBLENDP(d, s, m) m ? s : d 171286797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_I(helper_blendps, L, 4, FBLENDP) 171386797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_I(helper_blendpd, Q, 2, FBLENDP) 171486797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_I(helper_pblendw, W, 8, FBLENDP) 171586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 171686797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_dpps, SUFFIX) (Reg *d, Reg *s, uint32_t mask) 171786797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 171886797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32 iresult = 0 /*float32_zero*/; 171986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 172086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 4)) 172186797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float32_add(iresult, 172286797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32_mul(d->L(0), s->L(0), &env->sse_status), 172386797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 172486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 5)) 172586797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float32_add(iresult, 172686797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32_mul(d->L(1), s->L(1), &env->sse_status), 172786797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 172886797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 6)) 172986797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float32_add(iresult, 173086797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32_mul(d->L(2), s->L(2), &env->sse_status), 173186797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 173286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 7)) 173386797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float32_add(iresult, 173486797937017f52bff088d02edf64fb931177a7eaJun Nakajima float32_mul(d->L(3), s->L(3), &env->sse_status), 173586797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 173686797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(0) = (mask & (1 << 0)) ? iresult : 0 /*float32_zero*/; 173786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(1) = (mask & (1 << 1)) ? iresult : 0 /*float32_zero*/; 173886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(2) = (mask & (1 << 2)) ? iresult : 0 /*float32_zero*/; 173986797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->L(3) = (mask & (1 << 3)) ? iresult : 0 /*float32_zero*/; 174086797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 174186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 174286797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_dppd, SUFFIX) (Reg *d, Reg *s, uint32_t mask) 174386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 174486797937017f52bff088d02edf64fb931177a7eaJun Nakajima float64 iresult = 0 /*float64_zero*/; 174586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 174686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 4)) 174786797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float64_add(iresult, 174886797937017f52bff088d02edf64fb931177a7eaJun Nakajima float64_mul(d->Q(0), s->Q(0), &env->sse_status), 174986797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 175086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (mask & (1 << 5)) 175186797937017f52bff088d02edf64fb931177a7eaJun Nakajima iresult = float64_add(iresult, 175286797937017f52bff088d02edf64fb931177a7eaJun Nakajima float64_mul(d->Q(1), s->Q(1), &env->sse_status), 175386797937017f52bff088d02edf64fb931177a7eaJun Nakajima &env->sse_status); 175486797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = (mask & (1 << 0)) ? iresult : 0 /*float64_zero*/; 175586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = (mask & (1 << 1)) ? iresult : 0 /*float64_zero*/; 175686797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 175786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 175886797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_mpsadbw, SUFFIX) (Reg *d, Reg *s, uint32_t offset) 175986797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 176086797937017f52bff088d02edf64fb931177a7eaJun Nakajima int s0 = (offset & 3) << 2; 176186797937017f52bff088d02edf64fb931177a7eaJun Nakajima int d0 = (offset & 4) << 0; 176286797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 176386797937017f52bff088d02edf64fb931177a7eaJun Nakajima Reg r; 176486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 176586797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i < 8; i++, d0++) { 176686797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(i) = 0; 176786797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(i) += abs1(d->B(d0 + 0) - s->B(s0 + 0)); 176886797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(i) += abs1(d->B(d0 + 1) - s->B(s0 + 1)); 176986797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(i) += abs1(d->B(d0 + 2) - s->B(s0 + 2)); 177086797937017f52bff088d02edf64fb931177a7eaJun Nakajima r.W(i) += abs1(d->B(d0 + 3) - s->B(s0 + 3)); 177186797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 177286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 177386797937017f52bff088d02edf64fb931177a7eaJun Nakajima *d = r; 177486797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 177586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 177686797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* SSE4.2 op helpers */ 177786797937017f52bff088d02edf64fb931177a7eaJun Nakajima/* it's unclear whether signed or unsigned */ 177886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define FCMPGTQ(d, s) d > s ? -1 : 0 177986797937017f52bff088d02edf64fb931177a7eaJun NakajimaSSE_HELPER_Q(helper_pcmpgtq, FCMPGTQ) 178086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 178186797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int pcmp_elen(int reg, uint32_t ctrl) 178286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 178386797937017f52bff088d02edf64fb931177a7eaJun Nakajima int val; 178486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 178586797937017f52bff088d02edf64fb931177a7eaJun Nakajima /* Presence of REX.W is indicated by a bit higher than 7 set */ 178686797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (ctrl >> 8) 178786797937017f52bff088d02edf64fb931177a7eaJun Nakajima val = abs1((int64_t) env->regs[reg]); 178886797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 178986797937017f52bff088d02edf64fb931177a7eaJun Nakajima val = abs1((int32_t) env->regs[reg]); 179086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 179186797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (ctrl & 1) { 179286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (val > 8) 179386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 8; 179486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else 179586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (val > 16) 179686797937017f52bff088d02edf64fb931177a7eaJun Nakajima return 16; 179786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 179886797937017f52bff088d02edf64fb931177a7eaJun Nakajima return val; 179986797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 180086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 180186797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int pcmp_ilen(Reg *r, uint8_t ctrl) 180286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 180386797937017f52bff088d02edf64fb931177a7eaJun Nakajima int val = 0; 180486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 180586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (ctrl & 1) { 180686797937017f52bff088d02edf64fb931177a7eaJun Nakajima while (val < 8 && r->W(val)) 180786797937017f52bff088d02edf64fb931177a7eaJun Nakajima val++; 180886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else 180986797937017f52bff088d02edf64fb931177a7eaJun Nakajima while (val < 16 && r->B(val)) 181086797937017f52bff088d02edf64fb931177a7eaJun Nakajima val++; 181186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 181286797937017f52bff088d02edf64fb931177a7eaJun Nakajima return val; 181386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 181486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 181586797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int pcmp_val(Reg *r, uint8_t ctrl, int i) 181686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 181786797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch ((ctrl >> 0) & 3) { 181886797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 181986797937017f52bff088d02edf64fb931177a7eaJun Nakajima return r->B(i); 182086797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 182186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return r->W(i); 182286797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 182386797937017f52bff088d02edf64fb931177a7eaJun Nakajima return (int8_t) r->B(i); 182486797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 182586797937017f52bff088d02edf64fb931177a7eaJun Nakajima default: 182686797937017f52bff088d02edf64fb931177a7eaJun Nakajima return (int16_t) r->W(i); 182786797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 182886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 182986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 183086797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline unsigned pcmpxstrx(Reg *d, Reg *s, 183186797937017f52bff088d02edf64fb931177a7eaJun Nakajima int8_t ctrl, int valids, int validd) 183286797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 183386797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int res = 0; 183486797937017f52bff088d02edf64fb931177a7eaJun Nakajima int v; 183586797937017f52bff088d02edf64fb931177a7eaJun Nakajima int j, i; 183686797937017f52bff088d02edf64fb931177a7eaJun Nakajima int upper = (ctrl & 1) ? 7 : 15; 183786797937017f52bff088d02edf64fb931177a7eaJun Nakajima 183886797937017f52bff088d02edf64fb931177a7eaJun Nakajima valids--; 183986797937017f52bff088d02edf64fb931177a7eaJun Nakajima validd--; 184086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 184186797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = (valids < upper ? CC_Z : 0) | (validd < upper ? CC_S : 0); 184286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 184386797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch ((ctrl >> 2) & 3) { 184486797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 0: 184586797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (j = valids; j >= 0; j--) { 184686797937017f52bff088d02edf64fb931177a7eaJun Nakajima res <<= 1; 184786797937017f52bff088d02edf64fb931177a7eaJun Nakajima v = pcmp_val(s, ctrl, j); 184886797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = validd; i >= 0; i--) 184986797937017f52bff088d02edf64fb931177a7eaJun Nakajima res |= (v == pcmp_val(d, ctrl, i)); 185086797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 185186797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 185286797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 185386797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (j = valids; j >= 0; j--) { 185486797937017f52bff088d02edf64fb931177a7eaJun Nakajima res <<= 1; 185586797937017f52bff088d02edf64fb931177a7eaJun Nakajima v = pcmp_val(s, ctrl, j); 185686797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = ((validd - 1) | 1); i >= 0; i -= 2) 185786797937017f52bff088d02edf64fb931177a7eaJun Nakajima res |= (pcmp_val(d, ctrl, i - 0) <= v && 185886797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_val(d, ctrl, i - 1) >= v); 185986797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 186086797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 186186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 2: 186286797937017f52bff088d02edf64fb931177a7eaJun Nakajima res = (2 << (upper - MAX(valids, validd))) - 1; 186386797937017f52bff088d02edf64fb931177a7eaJun Nakajima res <<= MAX(valids, validd) - MIN(valids, validd); 186486797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = MIN(valids, validd); i >= 0; i--) { 186586797937017f52bff088d02edf64fb931177a7eaJun Nakajima res <<= 1; 186686797937017f52bff088d02edf64fb931177a7eaJun Nakajima v = pcmp_val(s, ctrl, i); 186786797937017f52bff088d02edf64fb931177a7eaJun Nakajima res |= (v == pcmp_val(d, ctrl, i)); 186886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 186986797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 187086797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 187186797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (j = valids - validd; j >= 0; j--) { 187286797937017f52bff088d02edf64fb931177a7eaJun Nakajima res <<= 1; 187386797937017f52bff088d02edf64fb931177a7eaJun Nakajima res |= 1; 187486797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = MIN(upper - j, validd); i >= 0; i--) 187586797937017f52bff088d02edf64fb931177a7eaJun Nakajima res &= (pcmp_val(s, ctrl, i + j) == pcmp_val(d, ctrl, i)); 187686797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 187786797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 187886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 187986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 188086797937017f52bff088d02edf64fb931177a7eaJun Nakajima switch ((ctrl >> 4) & 3) { 188186797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 1: 188286797937017f52bff088d02edf64fb931177a7eaJun Nakajima res ^= (2 << upper) - 1; 188386797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 188486797937017f52bff088d02edf64fb931177a7eaJun Nakajima case 3: 188586797937017f52bff088d02edf64fb931177a7eaJun Nakajima res ^= (2 << valids) - 1; 188686797937017f52bff088d02edf64fb931177a7eaJun Nakajima break; 188786797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 188886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 188986797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (res) 189086797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC |= CC_C; 189186797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (res & 1) 189286797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC |= CC_O; 189386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 189486797937017f52bff088d02edf64fb931177a7eaJun Nakajima return res; 189586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 189686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 189786797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int rffs1(unsigned int val) 189886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 189986797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret = 1, hi; 190086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 190186797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (hi = sizeof(val) * 4; hi; hi /= 2) 190286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (val >> hi) { 190386797937017f52bff088d02edf64fb931177a7eaJun Nakajima val >>= hi; 190486797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret += hi; 190586797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 190686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 190786797937017f52bff088d02edf64fb931177a7eaJun Nakajima return ret; 190886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 190986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 191086797937017f52bff088d02edf64fb931177a7eaJun Nakajimastatic inline int ffs1(unsigned int val) 191186797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 191286797937017f52bff088d02edf64fb931177a7eaJun Nakajima int ret = 1, hi; 191386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 191486797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (hi = sizeof(val) * 4; hi; hi /= 2) 191586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (val << hi) { 191686797937017f52bff088d02edf64fb931177a7eaJun Nakajima val <<= hi; 191786797937017f52bff088d02edf64fb931177a7eaJun Nakajima ret += hi; 191886797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 191986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 192086797937017f52bff088d02edf64fb931177a7eaJun Nakajima return ret; 192186797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 192286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 192386797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pcmpestri, SUFFIX) (Reg *d, Reg *s, uint32_t ctrl) 192486797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 192586797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int res = pcmpxstrx(d, s, ctrl, 192686797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_elen(R_EDX, ctrl), 192786797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_elen(R_EAX, ctrl)); 192886797937017f52bff088d02edf64fb931177a7eaJun Nakajima 192986797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (res) 193086797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->regs[R_ECX] = ((ctrl & (1 << 6)) ? rffs1 : ffs1)(res) - 1; 193186797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 193286797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->regs[R_ECX] = 16 >> (ctrl & (1 << 0)); 193386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 193486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 193586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pcmpestrm, SUFFIX) (Reg *d, Reg *s, uint32_t ctrl) 193686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 193786797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 193886797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int res = pcmpxstrx(d, s, ctrl, 193986797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_elen(R_EDX, ctrl), 194086797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_elen(R_EAX, ctrl)); 194186797937017f52bff088d02edf64fb931177a7eaJun Nakajima 194286797937017f52bff088d02edf64fb931177a7eaJun Nakajima if ((ctrl >> 6) & 1) { 194386797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (ctrl & 1) 194486797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i <= 8; i--, res >>= 1) 194586797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(i) = (res & 1) ? ~0 : 0; 194686797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 194786797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i <= 16; i--, res >>= 1) 194886797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = (res & 1) ? ~0 : 0; 194986797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 195086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 195186797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = res; 195286797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 195386797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 195486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 195586797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pcmpistri, SUFFIX) (Reg *d, Reg *s, uint32_t ctrl) 195686797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 195786797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int res = pcmpxstrx(d, s, ctrl, 195886797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_ilen(s, ctrl), 195986797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_ilen(d, ctrl)); 196086797937017f52bff088d02edf64fb931177a7eaJun Nakajima 196186797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (res) 196286797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->regs[R_ECX] = ((ctrl & (1 << 6)) ? rffs1 : ffs1)(res) - 1; 196386797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 196486797937017f52bff088d02edf64fb931177a7eaJun Nakajima env->regs[R_ECX] = 16 >> (ctrl & (1 << 0)); 196586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 196686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 196786797937017f52bff088d02edf64fb931177a7eaJun Nakajimavoid glue(helper_pcmpistrm, SUFFIX) (Reg *d, Reg *s, uint32_t ctrl) 196886797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 196986797937017f52bff088d02edf64fb931177a7eaJun Nakajima int i; 197086797937017f52bff088d02edf64fb931177a7eaJun Nakajima unsigned int res = pcmpxstrx(d, s, ctrl, 197186797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_ilen(s, ctrl), 197286797937017f52bff088d02edf64fb931177a7eaJun Nakajima pcmp_ilen(d, ctrl)); 197386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 197486797937017f52bff088d02edf64fb931177a7eaJun Nakajima if ((ctrl >> 6) & 1) { 197586797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (ctrl & 1) 197686797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i <= 8; i--, res >>= 1) 197786797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->W(i) = (res & 1) ? ~0 : 0; 197886797937017f52bff088d02edf64fb931177a7eaJun Nakajima else 197986797937017f52bff088d02edf64fb931177a7eaJun Nakajima for (i = 0; i <= 16; i--, res >>= 1) 198086797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->B(i) = (res & 1) ? ~0 : 0; 198186797937017f52bff088d02edf64fb931177a7eaJun Nakajima } else { 198286797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(1) = 0; 198386797937017f52bff088d02edf64fb931177a7eaJun Nakajima d->Q(0) = res; 198486797937017f52bff088d02edf64fb931177a7eaJun Nakajima } 198586797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 198686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 198786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define CRCPOLY 0x1edc6f41 198886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define CRCPOLY_BITREV 0x82f63b78 198986797937017f52bff088d02edf64fb931177a7eaJun Nakajimatarget_ulong helper_crc32(uint32_t crc1, target_ulong msg, uint32_t len) 199086797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 199186797937017f52bff088d02edf64fb931177a7eaJun Nakajima target_ulong crc = (msg & ((target_ulong) -1 >> 199286797937017f52bff088d02edf64fb931177a7eaJun Nakajima (TARGET_LONG_BITS - len))) ^ crc1; 199386797937017f52bff088d02edf64fb931177a7eaJun Nakajima 199486797937017f52bff088d02edf64fb931177a7eaJun Nakajima while (len--) 199586797937017f52bff088d02edf64fb931177a7eaJun Nakajima crc = (crc >> 1) ^ ((crc & 1) ? CRCPOLY_BITREV : 0); 199686797937017f52bff088d02edf64fb931177a7eaJun Nakajima 199786797937017f52bff088d02edf64fb931177a7eaJun Nakajima return crc; 199886797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 199986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 200086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define POPMASK(i) ((target_ulong) -1 / ((1LL << (1 << i)) + 1)) 200186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#define POPCOUNT(n, i) (n & POPMASK(i)) + ((n >> (1 << i)) & POPMASK(i)) 200286797937017f52bff088d02edf64fb931177a7eaJun Nakajimatarget_ulong helper_popcnt(target_ulong n, uint32_t type) 200386797937017f52bff088d02edf64fb931177a7eaJun Nakajima{ 200486797937017f52bff088d02edf64fb931177a7eaJun Nakajima CC_SRC = n ? 0 : CC_Z; 200586797937017f52bff088d02edf64fb931177a7eaJun Nakajima 200686797937017f52bff088d02edf64fb931177a7eaJun Nakajima n = POPCOUNT(n, 0); 200786797937017f52bff088d02edf64fb931177a7eaJun Nakajima n = POPCOUNT(n, 1); 200886797937017f52bff088d02edf64fb931177a7eaJun Nakajima n = POPCOUNT(n, 2); 200986797937017f52bff088d02edf64fb931177a7eaJun Nakajima n = POPCOUNT(n, 3); 201086797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (type == 1) 201186797937017f52bff088d02edf64fb931177a7eaJun Nakajima return n & 0xff; 201286797937017f52bff088d02edf64fb931177a7eaJun Nakajima 201386797937017f52bff088d02edf64fb931177a7eaJun Nakajima n = POPCOUNT(n, 4); 201486797937017f52bff088d02edf64fb931177a7eaJun Nakajima#ifndef TARGET_X86_64 201586797937017f52bff088d02edf64fb931177a7eaJun Nakajima return n; 201686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#else 201786797937017f52bff088d02edf64fb931177a7eaJun Nakajima if (type == 2) 201886797937017f52bff088d02edf64fb931177a7eaJun Nakajima return n & 0xff; 201986797937017f52bff088d02edf64fb931177a7eaJun Nakajima 202086797937017f52bff088d02edf64fb931177a7eaJun Nakajima return POPCOUNT(n, 5); 202186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 202286797937017f52bff088d02edf64fb931177a7eaJun Nakajima} 202386797937017f52bff088d02edf64fb931177a7eaJun Nakajima#endif 202486797937017f52bff088d02edf64fb931177a7eaJun Nakajima 202586797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef SHIFT 202686797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef XMM_ONLY 202786797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef Reg 202886797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef B 202986797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef W 203086797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef L 203186797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef Q 203286797937017f52bff088d02edf64fb931177a7eaJun Nakajima#undef SUFFIX 2033