1#define GEN_VR_LDX(name, opc2, opc3) \ 2GEN_HANDLER(name, 0x1F, opc2, opc3, 0x00000001, PPC_ALTIVEC) 3#define GEN_VR_STX(name, opc2, opc3) \ 4GEN_HANDLER(st##name, 0x1F, opc2, opc3, 0x00000001, PPC_ALTIVEC) 5#define GEN_VR_LVE(name, opc2, opc3) \ 6 GEN_HANDLER(lve##name, 0x1F, opc2, opc3, 0x00000001, PPC_ALTIVEC) 7#define GEN_VR_STVE(name, opc2, opc3) \ 8 GEN_HANDLER(stve##name, 0x1F, opc2, opc3, 0x00000001, PPC_ALTIVEC) 9GEN_VR_LDX(lvx, 0x07, 0x03), 10GEN_VR_LDX(lvxl, 0x07, 0x0B), 11GEN_VR_LVE(bx, 0x07, 0x00), 12GEN_VR_LVE(hx, 0x07, 0x01), 13GEN_VR_LVE(wx, 0x07, 0x02), 14GEN_VR_STX(svx, 0x07, 0x07), 15GEN_VR_STX(svxl, 0x07, 0x0F), 16GEN_VR_STVE(bx, 0x07, 0x04), 17GEN_VR_STVE(hx, 0x07, 0x05), 18GEN_VR_STVE(wx, 0x07, 0x06), 19 20#define GEN_VX_LOGICAL(name, tcg_op, opc2, opc3) \ 21GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC) 22 23#define GEN_VX_LOGICAL_207(name, tcg_op, opc2, opc3) \ 24GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ALTIVEC_207) 25 26GEN_VX_LOGICAL(vand, tcg_gen_and_i64, 2, 16), 27GEN_VX_LOGICAL(vandc, tcg_gen_andc_i64, 2, 17), 28GEN_VX_LOGICAL(vor, tcg_gen_or_i64, 2, 18), 29GEN_VX_LOGICAL(vxor, tcg_gen_xor_i64, 2, 19), 30GEN_VX_LOGICAL(vnor, tcg_gen_nor_i64, 2, 20), 31GEN_VX_LOGICAL_207(veqv, tcg_gen_eqv_i64, 2, 26), 32GEN_VX_LOGICAL_207(vnand, tcg_gen_nand_i64, 2, 22), 33GEN_VX_LOGICAL_207(vorc, tcg_gen_orc_i64, 2, 21), 34 35#define GEN_VXFORM(name, opc2, opc3) \ 36GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC) 37 38#define GEN_VXFORM_207(name, opc2, opc3) \ 39GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ALTIVEC_207) 40 41#define GEN_VXFORM_300(name, opc2, opc3) \ 42GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300) 43 44#define GEN_VXFORM_300_EXT(name, opc2, opc3, inval) \ 45GEN_HANDLER_E(name, 0x04, opc2, opc3, inval, PPC_NONE, PPC2_ISA300) 46 47#define GEN_VXFORM_300_EO(name, opc2, opc3, opc4) \ 48GEN_HANDLER_E_2(name, 0x04, opc2, opc3, opc4, 0x00000000, PPC_NONE, \ 49 PPC2_ISA300) 50 51#define GEN_VXFORM_DUAL(name0, name1, opc2, opc3, type0, type1) \ 52GEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, type0, type1) 53 54#define GEN_VXRFORM_DUAL(name0, name1, opc2, opc3, tp0, tp1) \ 55GEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, tp0, tp1), \ 56GEN_HANDLER_E(name0##_##name1, 0x4, opc2, (opc3 | 0x10), 0x00000000, tp0, tp1), 57 58GEN_VXFORM_DUAL(vaddubm, vmul10cuq, 0, 0, PPC_ALTIVEC, PPC_NONE), 59GEN_VXFORM_DUAL(vadduhm, vmul10ecuq, 0, 1, PPC_ALTIVEC, PPC_NONE), 60GEN_VXFORM(vadduwm, 0, 2), 61GEN_VXFORM_207(vaddudm, 0, 3), 62GEN_VXFORM_DUAL(vsububm, bcdadd, 0, 16, PPC_ALTIVEC, PPC_NONE), 63GEN_VXFORM_DUAL(vsubuhm, bcdsub, 0, 17, PPC_ALTIVEC, PPC_NONE), 64GEN_VXFORM_DUAL(vsubuwm, bcdus, 0, 18, PPC_ALTIVEC, PPC2_ISA300), 65GEN_VXFORM_DUAL(vsubudm, bcds, 0, 19, PPC2_ALTIVEC_207, PPC2_ISA300), 66GEN_VXFORM_300(bcds, 0, 27), 67GEN_VXFORM(vmaxub, 1, 0), 68GEN_VXFORM(vmaxuh, 1, 1), 69GEN_VXFORM(vmaxuw, 1, 2), 70GEN_VXFORM_207(vmaxud, 1, 3), 71GEN_VXFORM(vmaxsb, 1, 4), 72GEN_VXFORM(vmaxsh, 1, 5), 73GEN_VXFORM(vmaxsw, 1, 6), 74GEN_VXFORM_207(vmaxsd, 1, 7), 75GEN_VXFORM(vminub, 1, 8), 76GEN_VXFORM(vminuh, 1, 9), 77GEN_VXFORM(vminuw, 1, 10), 78GEN_VXFORM_207(vminud, 1, 11), 79GEN_VXFORM(vminsb, 1, 12), 80GEN_VXFORM(vminsh, 1, 13), 81GEN_VXFORM(vminsw, 1, 14), 82GEN_VXFORM_207(vminsd, 1, 15), 83GEN_VXFORM_DUAL(vavgub, vabsdub, 1, 16, PPC_ALTIVEC, PPC_NONE), 84GEN_VXFORM_DUAL(vavguh, vabsduh, 1, 17, PPC_ALTIVEC, PPC_NONE), 85GEN_VXFORM_DUAL(vavguw, vabsduw, 1, 18, PPC_ALTIVEC, PPC_NONE), 86GEN_VXFORM(vavgsb, 1, 20), 87GEN_VXFORM(vavgsh, 1, 21), 88GEN_VXFORM(vavgsw, 1, 22), 89GEN_VXFORM(vmrghb, 6, 0), 90GEN_VXFORM(vmrghh, 6, 1), 91GEN_VXFORM(vmrghw, 6, 2), 92GEN_VXFORM(vmrglb, 6, 4), 93GEN_VXFORM(vmrglh, 6, 5), 94GEN_VXFORM(vmrglw, 6, 6), 95GEN_VXFORM_300(vextublx, 6, 24), 96GEN_VXFORM_300(vextuhlx, 6, 25), 97GEN_VXFORM_DUAL(vmrgow, vextuwlx, 6, 26, PPC_NONE, PPC2_ALTIVEC_207), 98GEN_VXFORM_300(vextubrx, 6, 28), 99GEN_VXFORM_300(vextuhrx, 6, 29), 100GEN_VXFORM_DUAL(vmrgew, vextuwrx, 6, 30, PPC_NONE, PPC2_ALTIVEC_207), 101GEN_VXFORM(vmuloub, 4, 0), 102GEN_VXFORM(vmulouh, 4, 1), 103GEN_VXFORM_DUAL(vmulouw, vmuluwm, 4, 2, PPC_ALTIVEC, PPC_NONE), 104GEN_VXFORM(vmulosb, 4, 4), 105GEN_VXFORM(vmulosh, 4, 5), 106GEN_VXFORM_207(vmulosw, 4, 6), 107GEN_VXFORM(vmuleub, 4, 8), 108GEN_VXFORM(vmuleuh, 4, 9), 109GEN_VXFORM_207(vmuleuw, 4, 10), 110GEN_VXFORM(vmulesb, 4, 12), 111GEN_VXFORM(vmulesh, 4, 13), 112GEN_VXFORM_207(vmulesw, 4, 14), 113GEN_VXFORM(vslb, 2, 4), 114GEN_VXFORM(vslh, 2, 5), 115GEN_VXFORM_DUAL(vslw, vrlwnm, 2, 6, PPC_ALTIVEC, PPC_NONE), 116GEN_VXFORM_207(vsld, 2, 23), 117GEN_VXFORM(vsrb, 2, 8), 118GEN_VXFORM(vsrh, 2, 9), 119GEN_VXFORM(vsrw, 2, 10), 120GEN_VXFORM_207(vsrd, 2, 27), 121GEN_VXFORM(vsrab, 2, 12), 122GEN_VXFORM(vsrah, 2, 13), 123GEN_VXFORM(vsraw, 2, 14), 124GEN_VXFORM_207(vsrad, 2, 15), 125GEN_VXFORM_300(vsrv, 2, 28), 126GEN_VXFORM_300(vslv, 2, 29), 127GEN_VXFORM(vslo, 6, 16), 128GEN_VXFORM(vsro, 6, 17), 129GEN_VXFORM(vaddcuw, 0, 6), 130GEN_HANDLER_E_2(vprtybw, 0x4, 0x1, 0x18, 8, 0, PPC_NONE, PPC2_ISA300), 131GEN_HANDLER_E_2(vprtybd, 0x4, 0x1, 0x18, 9, 0, PPC_NONE, PPC2_ISA300), 132GEN_HANDLER_E_2(vprtybq, 0x4, 0x1, 0x18, 10, 0, PPC_NONE, PPC2_ISA300), 133 134GEN_VXFORM_DUAL(vsubcuw, xpnd04_1, 0, 22, PPC_ALTIVEC, PPC_NONE), 135GEN_VXFORM_300(bcdsr, 0, 23), 136GEN_VXFORM_300(bcdsr, 0, 31), 137GEN_VXFORM_DUAL(vaddubs, vmul10uq, 0, 8, PPC_ALTIVEC, PPC_NONE), 138GEN_VXFORM_DUAL(vadduhs, vmul10euq, 0, 9, PPC_ALTIVEC, PPC_NONE), 139GEN_VXFORM(vadduws, 0, 10), 140GEN_VXFORM(vaddsbs, 0, 12), 141GEN_VXFORM_DUAL(vaddshs, bcdcpsgn, 0, 13, PPC_ALTIVEC, PPC_NONE), 142GEN_VXFORM(vaddsws, 0, 14), 143GEN_VXFORM_DUAL(vsububs, bcdadd, 0, 24, PPC_ALTIVEC, PPC_NONE), 144GEN_VXFORM_DUAL(vsubuhs, bcdsub, 0, 25, PPC_ALTIVEC, PPC_NONE), 145GEN_VXFORM(vsubuws, 0, 26), 146GEN_VXFORM_DUAL(vsubsbs, bcdtrunc, 0, 28, PPC_ALTIVEC, PPC2_ISA300), 147GEN_VXFORM(vsubshs, 0, 29), 148GEN_VXFORM_DUAL(vsubsws, xpnd04_2, 0, 30, PPC_ALTIVEC, PPC_NONE), 149GEN_VXFORM_207(vadduqm, 0, 4), 150GEN_VXFORM_207(vaddcuq, 0, 5), 151GEN_VXFORM_DUAL(vaddeuqm, vaddecuq, 30, 0xFF, PPC_NONE, PPC2_ALTIVEC_207), 152GEN_VXFORM_DUAL(vsubuqm, bcdtrunc, 0, 20, PPC2_ALTIVEC_207, PPC2_ISA300), 153GEN_VXFORM_DUAL(vsubcuq, bcdutrunc, 0, 21, PPC2_ALTIVEC_207, PPC2_ISA300), 154GEN_VXFORM_DUAL(vsubeuqm, vsubecuq, 31, 0xFF, PPC_NONE, PPC2_ALTIVEC_207), 155GEN_VXFORM(vrlb, 2, 0), 156GEN_VXFORM(vrlh, 2, 1), 157GEN_VXFORM_DUAL(vrlw, vrlwmi, 2, 2, PPC_ALTIVEC, PPC_NONE), 158GEN_VXFORM_DUAL(vrld, vrldmi, 2, 3, PPC_NONE, PPC2_ALTIVEC_207), 159GEN_VXFORM_DUAL(vsl, vrldnm, 2, 7, PPC_ALTIVEC, PPC_NONE), 160GEN_VXFORM(vsr, 2, 11), 161GEN_VXFORM(vpkuhum, 7, 0), 162GEN_VXFORM(vpkuwum, 7, 1), 163GEN_VXFORM_207(vpkudum, 7, 17), 164GEN_VXFORM(vpkuhus, 7, 2), 165GEN_VXFORM(vpkuwus, 7, 3), 166GEN_VXFORM_207(vpkudus, 7, 19), 167GEN_VXFORM(vpkshus, 7, 4), 168GEN_VXFORM(vpkswus, 7, 5), 169GEN_VXFORM_207(vpksdus, 7, 21), 170GEN_VXFORM(vpkshss, 7, 6), 171GEN_VXFORM(vpkswss, 7, 7), 172GEN_VXFORM_207(vpksdss, 7, 23), 173GEN_VXFORM(vpkpx, 7, 12), 174GEN_VXFORM(vsum4ubs, 4, 24), 175GEN_VXFORM(vsum4sbs, 4, 28), 176GEN_VXFORM(vsum4shs, 4, 25), 177GEN_VXFORM(vsum2sws, 4, 26), 178GEN_VXFORM(vsumsws, 4, 30), 179GEN_VXFORM(vaddfp, 5, 0), 180GEN_VXFORM(vsubfp, 5, 1), 181GEN_VXFORM(vmaxfp, 5, 16), 182GEN_VXFORM(vminfp, 5, 17), 183 184#define GEN_VXRFORM1(opname, name, str, opc2, opc3) \ 185 GEN_HANDLER2(name, str, 0x4, opc2, opc3, 0x00000000, PPC_ALTIVEC), 186#define GEN_VXRFORM1_300(opname, name, str, opc2, opc3) \ 187GEN_HANDLER2_E(name, str, 0x4, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300), 188#define GEN_VXRFORM(name, opc2, opc3) \ 189 GEN_VXRFORM1(name, name, #name, opc2, opc3) \ 190 GEN_VXRFORM1(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4))) 191#define GEN_VXRFORM_300(name, opc2, opc3) \ 192 GEN_VXRFORM1_300(name, name, #name, opc2, opc3) \ 193 GEN_VXRFORM1_300(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4))) 194 195GEN_VXRFORM_300(vcmpnezb, 3, 4) 196GEN_VXRFORM_300(vcmpnezh, 3, 5) 197GEN_VXRFORM_300(vcmpnezw, 3, 6) 198GEN_VXRFORM(vcmpgtsb, 3, 12) 199GEN_VXRFORM(vcmpgtsh, 3, 13) 200GEN_VXRFORM(vcmpgtsw, 3, 14) 201GEN_VXRFORM(vcmpgtub, 3, 8) 202GEN_VXRFORM(vcmpgtuh, 3, 9) 203GEN_VXRFORM(vcmpgtuw, 3, 10) 204GEN_VXRFORM_DUAL(vcmpeqfp, vcmpequd, 3, 3, PPC_ALTIVEC, PPC_NONE) 205GEN_VXRFORM(vcmpgefp, 3, 7) 206GEN_VXRFORM_DUAL(vcmpgtfp, vcmpgtud, 3, 11, PPC_ALTIVEC, PPC_NONE) 207GEN_VXRFORM_DUAL(vcmpbfp, vcmpgtsd, 3, 15, PPC_ALTIVEC, PPC_NONE) 208GEN_VXRFORM_DUAL(vcmpequb, vcmpneb, 3, 0, PPC_ALTIVEC, PPC_NONE) 209GEN_VXRFORM_DUAL(vcmpequh, vcmpneh, 3, 1, PPC_ALTIVEC, PPC_NONE) 210GEN_VXRFORM_DUAL(vcmpequw, vcmpnew, 3, 2, PPC_ALTIVEC, PPC_NONE) 211 212#define GEN_VXFORM_DUAL_INV(name0, name1, opc2, opc3, inval0, inval1, type) \ 213GEN_OPCODE_DUAL(name0##_##name1, 0x04, opc2, opc3, inval0, inval1, type, \ 214 PPC_NONE) 215GEN_VXFORM_DUAL_INV(vspltb, vextractub, 6, 8, 0x00000000, 0x100000, 216 PPC_ALTIVEC), 217GEN_VXFORM_DUAL_INV(vsplth, vextractuh, 6, 9, 0x00000000, 0x100000, 218 PPC_ALTIVEC), 219GEN_VXFORM_DUAL_INV(vspltw, vextractuw, 6, 10, 0x00000000, 0x100000, 220 PPC_ALTIVEC), 221GEN_VXFORM_300_EXT(vextractd, 6, 11, 0x100000), 222GEN_VXFORM_DUAL_INV(vspltisb, vinsertb, 6, 12, 0x00000000, 0x100000, 223 PPC_ALTIVEC), 224GEN_VXFORM_DUAL_INV(vspltish, vinserth, 6, 13, 0x00000000, 0x100000, 225 PPC_ALTIVEC), 226GEN_VXFORM_DUAL_INV(vspltisw, vinsertw, 6, 14, 0x00000000, 0x100000, 227 PPC_ALTIVEC), 228GEN_VXFORM_300_EXT(vinsertd, 6, 15, 0x100000), 229GEN_VXFORM_300_EO(vnegw, 0x01, 0x18, 0x06), 230GEN_VXFORM_300_EO(vnegd, 0x01, 0x18, 0x07), 231GEN_VXFORM_300_EO(vextsb2w, 0x01, 0x18, 0x10), 232GEN_VXFORM_300_EO(vextsh2w, 0x01, 0x18, 0x11), 233GEN_VXFORM_300_EO(vextsb2d, 0x01, 0x18, 0x18), 234GEN_VXFORM_300_EO(vextsh2d, 0x01, 0x18, 0x19), 235GEN_VXFORM_300_EO(vextsw2d, 0x01, 0x18, 0x1A), 236GEN_VXFORM_300_EO(vctzb, 0x01, 0x18, 0x1C), 237GEN_VXFORM_300_EO(vctzh, 0x01, 0x18, 0x1D), 238GEN_VXFORM_300_EO(vctzw, 0x01, 0x18, 0x1E), 239GEN_VXFORM_300_EO(vctzd, 0x01, 0x18, 0x1F), 240GEN_VXFORM_300_EO(vclzlsbb, 0x01, 0x18, 0x0), 241GEN_VXFORM_300_EO(vctzlsbb, 0x01, 0x18, 0x1), 242GEN_VXFORM_300(vpermr, 0x1D, 0xFF), 243 244#define GEN_VXFORM_NOA(name, opc2, opc3) \ 245 GEN_HANDLER(name, 0x04, opc2, opc3, 0x001f0000, PPC_ALTIVEC) 246GEN_VXFORM_NOA(vupkhsb, 7, 8), 247GEN_VXFORM_NOA(vupkhsh, 7, 9), 248GEN_VXFORM_207(vupkhsw, 7, 25), 249GEN_VXFORM_NOA(vupklsb, 7, 10), 250GEN_VXFORM_NOA(vupklsh, 7, 11), 251GEN_VXFORM_207(vupklsw, 7, 27), 252GEN_VXFORM_NOA(vupkhpx, 7, 13), 253GEN_VXFORM_NOA(vupklpx, 7, 15), 254GEN_VXFORM_NOA(vrefp, 5, 4), 255GEN_VXFORM_NOA(vrsqrtefp, 5, 5), 256GEN_VXFORM_NOA(vexptefp, 5, 6), 257GEN_VXFORM_NOA(vlogefp, 5, 7), 258GEN_VXFORM_NOA(vrfim, 5, 11), 259GEN_VXFORM_NOA(vrfin, 5, 8), 260GEN_VXFORM_NOA(vrfip, 5, 10), 261GEN_VXFORM_NOA(vrfiz, 5, 9), 262 263#define GEN_VXFORM_UIMM(name, opc2, opc3) \ 264 GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC) 265GEN_VXFORM_UIMM(vcfux, 5, 12), 266GEN_VXFORM_UIMM(vcfsx, 5, 13), 267GEN_VXFORM_UIMM(vctuxs, 5, 14), 268GEN_VXFORM_UIMM(vctsxs, 5, 15), 269 270 271#define GEN_VAFORM_PAIRED(name0, name1, opc2) \ 272 GEN_HANDLER(name0##_##name1, 0x04, opc2, 0xFF, 0x00000000, PPC_ALTIVEC) 273GEN_VAFORM_PAIRED(vmhaddshs, vmhraddshs, 16), 274GEN_VAFORM_PAIRED(vmsumubm, vmsummbm, 18), 275GEN_VAFORM_PAIRED(vmsumuhm, vmsumuhs, 19), 276GEN_VAFORM_PAIRED(vmsumshm, vmsumshs, 20), 277GEN_VAFORM_PAIRED(vsel, vperm, 21), 278GEN_VAFORM_PAIRED(vmaddfp, vnmsubfp, 23), 279 280GEN_VXFORM_DUAL(vclzb, vpopcntb, 1, 28, PPC_NONE, PPC2_ALTIVEC_207), 281GEN_VXFORM_DUAL(vclzh, vpopcnth, 1, 29, PPC_NONE, PPC2_ALTIVEC_207), 282GEN_VXFORM_DUAL(vclzw, vpopcntw, 1, 30, PPC_NONE, PPC2_ALTIVEC_207), 283GEN_VXFORM_DUAL(vclzd, vpopcntd, 1, 31, PPC_NONE, PPC2_ALTIVEC_207), 284 285GEN_VXFORM_300(vbpermd, 6, 23), 286GEN_VXFORM_207(vbpermq, 6, 21), 287GEN_VXFORM_207(vgbbd, 6, 20), 288GEN_VXFORM_207(vpmsumb, 4, 16), 289GEN_VXFORM_207(vpmsumh, 4, 17), 290GEN_VXFORM_207(vpmsumw, 4, 18), 291GEN_VXFORM_207(vpmsumd, 4, 19), 292 293GEN_VXFORM_207(vsbox, 4, 23), 294 295GEN_VXFORM_DUAL(vcipher, vcipherlast, 4, 20, PPC_NONE, PPC2_ALTIVEC_207), 296GEN_VXFORM_DUAL(vncipher, vncipherlast, 4, 21, PPC_NONE, PPC2_ALTIVEC_207), 297 298GEN_VXFORM_207(vshasigmaw, 1, 26), 299GEN_VXFORM_207(vshasigmad, 1, 27), 300 301GEN_VXFORM_DUAL(vsldoi, vpermxor, 22, 0xFF, PPC_ALTIVEC, PPC_NONE), 302