1139c1837SPaolo Bonzini#define GEN_VXFORM(name, opc2, opc3) \ 2139c1837SPaolo BonziniGEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC) 3139c1837SPaolo Bonzini 4139c1837SPaolo Bonzini#define GEN_VXFORM_207(name, opc2, opc3) \ 5139c1837SPaolo BonziniGEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ALTIVEC_207) 6139c1837SPaolo Bonzini 7139c1837SPaolo Bonzini#define GEN_VXFORM_300(name, opc2, opc3) \ 8139c1837SPaolo BonziniGEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300) 9139c1837SPaolo Bonzini 10139c1837SPaolo Bonzini#define GEN_VXFORM_300_EXT(name, opc2, opc3, inval) \ 11139c1837SPaolo BonziniGEN_HANDLER_E(name, 0x04, opc2, opc3, inval, PPC_NONE, PPC2_ISA300) 12139c1837SPaolo Bonzini 13139c1837SPaolo Bonzini#define GEN_VXFORM_300_EO(name, opc2, opc3, opc4) \ 14139c1837SPaolo BonziniGEN_HANDLER_E_2(name, 0x04, opc2, opc3, opc4, 0x00000000, PPC_NONE, \ 15139c1837SPaolo Bonzini PPC2_ISA300) 16139c1837SPaolo Bonzini 17dd8014e4SPeter Maydell#define GEN_VXFORM_310(name, opc2, opc3) \ 18dd8014e4SPeter MaydellGEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA310) 19dd8014e4SPeter Maydell 20139c1837SPaolo Bonzini#define GEN_VXFORM_DUAL(name0, name1, opc2, opc3, type0, type1) \ 21139c1837SPaolo BonziniGEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, type0, type1) 22139c1837SPaolo Bonzini 23139c1837SPaolo Bonzini#define GEN_VXRFORM_DUAL(name0, name1, opc2, opc3, tp0, tp1) \ 24139c1837SPaolo BonziniGEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, tp0, tp1), \ 25139c1837SPaolo BonziniGEN_HANDLER_E(name0##_##name1, 0x4, opc2, (opc3 | 0x10), 0x00000000, tp0, tp1), 26139c1837SPaolo Bonzini 27139c1837SPaolo BonziniGEN_VXFORM_DUAL(vaddubm, vmul10cuq, 0, 0, PPC_ALTIVEC, PPC_NONE), 28139c1837SPaolo BonziniGEN_VXFORM_DUAL(vadduhm, vmul10ecuq, 0, 1, PPC_ALTIVEC, PPC_NONE), 29139c1837SPaolo BonziniGEN_VXFORM(vadduwm, 0, 2), 30139c1837SPaolo BonziniGEN_VXFORM_207(vaddudm, 0, 3), 31139c1837SPaolo BonziniGEN_VXFORM_DUAL(vsububm, bcdadd, 0, 16, PPC_ALTIVEC, PPC_NONE), 32139c1837SPaolo BonziniGEN_VXFORM_DUAL(vsubuhm, bcdsub, 0, 17, PPC_ALTIVEC, PPC_NONE), 33139c1837SPaolo BonziniGEN_VXFORM_DUAL(vsubuwm, bcdus, 0, 18, PPC_ALTIVEC, PPC2_ISA300), 34139c1837SPaolo BonziniGEN_VXFORM_DUAL(vsubudm, bcds, 0, 19, PPC2_ALTIVEC_207, PPC2_ISA300), 35139c1837SPaolo BonziniGEN_VXFORM_300(bcds, 0, 27), 36139c1837SPaolo BonziniGEN_VXFORM(vmrghb, 6, 0), 37139c1837SPaolo BonziniGEN_VXFORM(vmrghh, 6, 1), 38139c1837SPaolo BonziniGEN_VXFORM(vmrghw, 6, 2), 39139c1837SPaolo BonziniGEN_VXFORM(vmrglb, 6, 4), 40139c1837SPaolo BonziniGEN_VXFORM(vmrglh, 6, 5), 41139c1837SPaolo BonziniGEN_VXFORM(vmrglw, 6, 6), 42139c1837SPaolo BonziniGEN_VXFORM_300(vextublx, 6, 24), 43139c1837SPaolo BonziniGEN_VXFORM_300(vextuhlx, 6, 25), 44139c1837SPaolo BonziniGEN_VXFORM_DUAL(vmrgow, vextuwlx, 6, 26, PPC_NONE, PPC2_ALTIVEC_207), 45139c1837SPaolo BonziniGEN_VXFORM_300(vextubrx, 6, 28), 46139c1837SPaolo BonziniGEN_VXFORM_300(vextuhrx, 6, 29), 47139c1837SPaolo BonziniGEN_VXFORM_DUAL(vmrgew, vextuwrx, 6, 30, PPC_NONE, PPC2_ALTIVEC_207), 4880eca687SLucas Mateus Castro (alqotel)GEN_VXFORM_207(vmuluwm, 4, 2), 49139c1837SPaolo BonziniGEN_VXFORM_300(vsrv, 2, 28), 50139c1837SPaolo BonziniGEN_VXFORM_300(vslv, 2, 29), 51139c1837SPaolo BonziniGEN_VXFORM(vslo, 6, 16), 52139c1837SPaolo BonziniGEN_VXFORM(vsro, 6, 17), 53139c1837SPaolo Bonzini 54611bc69bSLucas Mateus Castro (alqotel)GEN_VXFORM(xpnd04_1, 0, 22), 55139c1837SPaolo BonziniGEN_VXFORM_300(bcdsr, 0, 23), 56139c1837SPaolo BonziniGEN_VXFORM_300(bcdsr, 0, 31), 57*a7e10fabSChinmay RathGEN_VXFORM_300_EXT(vmul10uq, 0, 8, 0x0000F800), 58*a7e10fabSChinmay RathGEN_VXFORM_300(vmul10euq, 0, 9), 59*a7e10fabSChinmay RathGEN_VXFORM_300(bcdcpsgn, 0, 13), 60*a7e10fabSChinmay RathGEN_VXFORM_207(bcdadd, 0, 24), 61*a7e10fabSChinmay RathGEN_VXFORM_207(bcdsub, 0, 25), 62*a7e10fabSChinmay RathGEN_VXFORM_300(bcdtrunc, 0, 28), 63*a7e10fabSChinmay RathGEN_VXFORM_300(xpnd04_2, 0, 30), 64b132be53SMatheus FerstGEN_VXFORM_300(bcdtrunc, 0, 20), 65b7d30faeSMatheus FerstGEN_VXFORM_300(bcdutrunc, 0, 21), 6602c74f0eSMatheus FerstGEN_VXFORM(vsl, 2, 7), 67139c1837SPaolo BonziniGEN_VXFORM(vsr, 2, 11), 68139c1837SPaolo BonziniGEN_VXFORM(vpkuhum, 7, 0), 69139c1837SPaolo BonziniGEN_VXFORM(vpkuwum, 7, 1), 70139c1837SPaolo BonziniGEN_VXFORM_207(vpkudum, 7, 17), 71139c1837SPaolo BonziniGEN_VXFORM(vpkuhus, 7, 2), 72139c1837SPaolo BonziniGEN_VXFORM(vpkuwus, 7, 3), 73139c1837SPaolo BonziniGEN_VXFORM_207(vpkudus, 7, 19), 74139c1837SPaolo BonziniGEN_VXFORM(vpkshus, 7, 4), 75139c1837SPaolo BonziniGEN_VXFORM(vpkswus, 7, 5), 76139c1837SPaolo BonziniGEN_VXFORM_207(vpksdus, 7, 21), 77139c1837SPaolo BonziniGEN_VXFORM(vpkshss, 7, 6), 78139c1837SPaolo BonziniGEN_VXFORM(vpkswss, 7, 7), 79139c1837SPaolo BonziniGEN_VXFORM_207(vpksdss, 7, 23), 80139c1837SPaolo BonziniGEN_VXFORM(vpkpx, 7, 12), 81139c1837SPaolo BonziniGEN_VXFORM(vsum4ubs, 4, 24), 82139c1837SPaolo BonziniGEN_VXFORM(vsum4sbs, 4, 28), 83139c1837SPaolo BonziniGEN_VXFORM(vsum4shs, 4, 25), 84139c1837SPaolo BonziniGEN_VXFORM(vsum2sws, 4, 26), 85139c1837SPaolo BonziniGEN_VXFORM(vsumsws, 4, 30), 86139c1837SPaolo BonziniGEN_VXFORM(vaddfp, 5, 0), 87139c1837SPaolo BonziniGEN_VXFORM(vsubfp, 5, 1), 88139c1837SPaolo BonziniGEN_VXFORM(vmaxfp, 5, 16), 89139c1837SPaolo BonziniGEN_VXFORM(vminfp, 5, 17), 90139c1837SPaolo Bonzini 91139c1837SPaolo Bonzini#define GEN_VXRFORM1(opname, name, str, opc2, opc3) \ 92139c1837SPaolo Bonzini GEN_HANDLER2(name, str, 0x4, opc2, opc3, 0x00000000, PPC_ALTIVEC), 93139c1837SPaolo Bonzini#define GEN_VXRFORM1_300(opname, name, str, opc2, opc3) \ 94139c1837SPaolo BonziniGEN_HANDLER2_E(name, str, 0x4, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300), 95139c1837SPaolo Bonzini#define GEN_VXRFORM(name, opc2, opc3) \ 96139c1837SPaolo Bonzini GEN_VXRFORM1(name, name, #name, opc2, opc3) \ 97139c1837SPaolo Bonzini GEN_VXRFORM1(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4))) 98139c1837SPaolo Bonzini#define GEN_VXRFORM_300(name, opc2, opc3) \ 99139c1837SPaolo Bonzini GEN_VXRFORM1_300(name, name, #name, opc2, opc3) \ 100139c1837SPaolo Bonzini GEN_VXRFORM1_300(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4))) 101139c1837SPaolo Bonzini 1026a394290SMatheus FerstGEN_VXRFORM(vcmpeqfp, 3, 3) 103139c1837SPaolo BonziniGEN_VXRFORM(vcmpgefp, 3, 7) 1046a394290SMatheus FerstGEN_VXRFORM(vcmpgtfp, 3, 11) 1056a394290SMatheus FerstGEN_VXRFORM(vcmpbfp, 3, 15) 106139c1837SPaolo Bonzini 107139c1837SPaolo Bonzini#define GEN_VXFORM_DUAL_INV(name0, name1, opc2, opc3, inval0, inval1, type) \ 108139c1837SPaolo BonziniGEN_OPCODE_DUAL(name0##_##name1, 0x04, opc2, opc3, inval0, inval1, type, \ 109139c1837SPaolo Bonzini PPC_NONE) 110139c1837SPaolo BonziniGEN_VXFORM_DUAL_INV(vspltb, vextractub, 6, 8, 0x00000000, 0x100000, 111139c1837SPaolo Bonzini PPC_ALTIVEC), 112139c1837SPaolo BonziniGEN_VXFORM_DUAL_INV(vsplth, vextractuh, 6, 9, 0x00000000, 0x100000, 113139c1837SPaolo Bonzini PPC_ALTIVEC), 114139c1837SPaolo BonziniGEN_VXFORM_DUAL_INV(vspltw, vextractuw, 6, 10, 0x00000000, 0x100000, 115139c1837SPaolo Bonzini PPC_ALTIVEC), 116139c1837SPaolo BonziniGEN_VXFORM_300_EXT(vextractd, 6, 11, 0x100000), 117b422c2cbSMatheus FerstGEN_VXFORM(vspltisb, 6, 12), 118b422c2cbSMatheus FerstGEN_VXFORM(vspltish, 6, 13), 119b422c2cbSMatheus FerstGEN_VXFORM(vspltisw, 6, 14), 120139c1837SPaolo BonziniGEN_VXFORM_300_EO(vctzb, 0x01, 0x18, 0x1C), 121139c1837SPaolo BonziniGEN_VXFORM_300_EO(vctzh, 0x01, 0x18, 0x1D), 122139c1837SPaolo BonziniGEN_VXFORM_300_EO(vctzw, 0x01, 0x18, 0x1E), 123139c1837SPaolo BonziniGEN_VXFORM_300_EO(vctzd, 0x01, 0x18, 0x1F), 124139c1837SPaolo BonziniGEN_VXFORM_300_EO(vclzlsbb, 0x01, 0x18, 0x0), 125139c1837SPaolo BonziniGEN_VXFORM_300_EO(vctzlsbb, 0x01, 0x18, 0x1), 126139c1837SPaolo Bonzini 127139c1837SPaolo Bonzini#define GEN_VXFORM_NOA(name, opc2, opc3) \ 128139c1837SPaolo Bonzini GEN_HANDLER(name, 0x04, opc2, opc3, 0x001f0000, PPC_ALTIVEC) 129139c1837SPaolo BonziniGEN_VXFORM_NOA(vupkhsb, 7, 8), 130139c1837SPaolo BonziniGEN_VXFORM_NOA(vupkhsh, 7, 9), 131139c1837SPaolo BonziniGEN_VXFORM_207(vupkhsw, 7, 25), 132139c1837SPaolo BonziniGEN_VXFORM_NOA(vupklsb, 7, 10), 133139c1837SPaolo BonziniGEN_VXFORM_NOA(vupklsh, 7, 11), 134139c1837SPaolo BonziniGEN_VXFORM_207(vupklsw, 7, 27), 135139c1837SPaolo BonziniGEN_VXFORM_NOA(vupkhpx, 7, 13), 136139c1837SPaolo BonziniGEN_VXFORM_NOA(vupklpx, 7, 15), 137139c1837SPaolo BonziniGEN_VXFORM_NOA(vrefp, 5, 4), 138139c1837SPaolo BonziniGEN_VXFORM_NOA(vrsqrtefp, 5, 5), 139139c1837SPaolo BonziniGEN_VXFORM_NOA(vexptefp, 5, 6), 140139c1837SPaolo BonziniGEN_VXFORM_NOA(vlogefp, 5, 7), 141139c1837SPaolo BonziniGEN_VXFORM_NOA(vrfim, 5, 11), 142139c1837SPaolo BonziniGEN_VXFORM_NOA(vrfin, 5, 8), 143139c1837SPaolo BonziniGEN_VXFORM_NOA(vrfip, 5, 10), 144139c1837SPaolo BonziniGEN_VXFORM_NOA(vrfiz, 5, 9), 145139c1837SPaolo Bonzini 146139c1837SPaolo Bonzini#define GEN_VXFORM_UIMM(name, opc2, opc3) \ 147139c1837SPaolo Bonzini GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC) 148139c1837SPaolo BonziniGEN_VXFORM_UIMM(vcfux, 5, 12), 149139c1837SPaolo BonziniGEN_VXFORM_UIMM(vcfsx, 5, 13), 150139c1837SPaolo BonziniGEN_VXFORM_UIMM(vctuxs, 5, 14), 151139c1837SPaolo BonziniGEN_VXFORM_UIMM(vctsxs, 5, 15), 152139c1837SPaolo Bonzini 153139c1837SPaolo Bonzini#define GEN_VAFORM_PAIRED(name0, name1, opc2) \ 154139c1837SPaolo Bonzini GEN_HANDLER(name0##_##name1, 0x04, opc2, 0xFF, 0x00000000, PPC_ALTIVEC) 155139c1837SPaolo BonziniGEN_VAFORM_PAIRED(vmaddfp, vnmsubfp, 23), 156139c1837SPaolo Bonzini 157139c1837SPaolo BonziniGEN_VXFORM_DUAL(vclzb, vpopcntb, 1, 28, PPC_NONE, PPC2_ALTIVEC_207), 158139c1837SPaolo BonziniGEN_VXFORM_DUAL(vclzh, vpopcnth, 1, 29, PPC_NONE, PPC2_ALTIVEC_207), 159139c1837SPaolo BonziniGEN_VXFORM_DUAL(vclzw, vpopcntw, 1, 30, PPC_NONE, PPC2_ALTIVEC_207), 160139c1837SPaolo BonziniGEN_VXFORM_DUAL(vclzd, vpopcntd, 1, 31, PPC_NONE, PPC2_ALTIVEC_207), 161139c1837SPaolo Bonzini 162139c1837SPaolo BonziniGEN_VXFORM_300(vbpermd, 6, 23), 163139c1837SPaolo BonziniGEN_VXFORM_207(vbpermq, 6, 21), 164139c1837SPaolo BonziniGEN_VXFORM_207(vgbbd, 6, 20), 165139c1837SPaolo BonziniGEN_VXFORM_207(vpmsumb, 4, 16), 166139c1837SPaolo BonziniGEN_VXFORM_207(vpmsumh, 4, 17), 167139c1837SPaolo BonziniGEN_VXFORM_207(vpmsumw, 4, 18), 168139c1837SPaolo Bonzini 169139c1837SPaolo BonziniGEN_VXFORM_207(vsbox, 4, 23), 170139c1837SPaolo Bonzini 171139c1837SPaolo BonziniGEN_VXFORM_DUAL(vcipher, vcipherlast, 4, 20, PPC_NONE, PPC2_ALTIVEC_207), 172139c1837SPaolo BonziniGEN_VXFORM_DUAL(vncipher, vncipherlast, 4, 21, PPC_NONE, PPC2_ALTIVEC_207), 173139c1837SPaolo Bonzini 174139c1837SPaolo BonziniGEN_VXFORM_207(vshasigmaw, 1, 26), 175139c1837SPaolo BonziniGEN_VXFORM_207(vshasigmad, 1, 27), 176139c1837SPaolo Bonzini 177139c1837SPaolo BonziniGEN_VXFORM_DUAL(vsldoi, vpermxor, 22, 0xFF, PPC_ALTIVEC, PPC_NONE), 178