Merge tag 'v9.1.0'
[qemu/ar7.git] / target / ppc / translate / vmx-ops.c.inc
blobe28958a126a66cca6a4db37a3f1c6ec52be1044e
1 #define GEN_VXFORM(name, opc2, opc3)                                    \
2 GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC)
4 #define GEN_VXFORM_207(name, opc2, opc3) \
5 GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ALTIVEC_207)
7 #define GEN_VXFORM_300(name, opc2, opc3)                                \
8 GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300)
10 #define GEN_VXFORM_300_EXT(name, opc2, opc3, inval)                     \
11 GEN_HANDLER_E(name, 0x04, opc2, opc3, inval, PPC_NONE, PPC2_ISA300)
13 #define GEN_VXFORM_300_EO(name, opc2, opc3, opc4)                     \
14 GEN_HANDLER_E_2(name, 0x04, opc2, opc3, opc4, 0x00000000, PPC_NONE,     \
15                                                        PPC2_ISA300)
17 #define GEN_VXFORM_310(name, opc2, opc3)                                \
18 GEN_HANDLER_E(name, 0x04, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA310)
20 #define GEN_VXFORM_DUAL(name0, name1, opc2, opc3, type0, type1) \
21 GEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, type0, type1)
23 #define GEN_VXRFORM_DUAL(name0, name1, opc2, opc3, tp0, tp1) \
24 GEN_HANDLER_E(name0##_##name1, 0x4, opc2, opc3, 0x00000000, tp0, tp1), \
25 GEN_HANDLER_E(name0##_##name1, 0x4, opc2, (opc3 | 0x10), 0x00000000, tp0, tp1),
27 GEN_VXFORM_DUAL(vaddubm, vmul10cuq, 0, 0, PPC_ALTIVEC, PPC_NONE),
28 GEN_VXFORM_DUAL(vadduhm, vmul10ecuq, 0, 1, PPC_ALTIVEC, PPC_NONE),
29 GEN_VXFORM(vadduwm, 0, 2),
30 GEN_VXFORM_207(vaddudm, 0, 3),
31 GEN_VXFORM_DUAL(vsububm, bcdadd, 0, 16, PPC_ALTIVEC, PPC_NONE),
32 GEN_VXFORM_DUAL(vsubuhm, bcdsub, 0, 17, PPC_ALTIVEC, PPC_NONE),
33 GEN_VXFORM_DUAL(vsubuwm, bcdus, 0, 18, PPC_ALTIVEC, PPC2_ISA300),
34 GEN_VXFORM_DUAL(vsubudm, bcds, 0, 19, PPC2_ALTIVEC_207, PPC2_ISA300),
35 GEN_VXFORM_300(bcds, 0, 27),
36 GEN_VXFORM(vmrghb, 6, 0),
37 GEN_VXFORM(vmrghh, 6, 1),
38 GEN_VXFORM(vmrghw, 6, 2),
39 GEN_VXFORM(vmrglb, 6, 4),
40 GEN_VXFORM(vmrglh, 6, 5),
41 GEN_VXFORM(vmrglw, 6, 6),
42 GEN_VXFORM_300(vextublx, 6, 24),
43 GEN_VXFORM_300(vextuhlx, 6, 25),
44 GEN_VXFORM_DUAL(vmrgow, vextuwlx, 6, 26, PPC_NONE, PPC2_ALTIVEC_207),
45 GEN_VXFORM_300(vextubrx, 6, 28),
46 GEN_VXFORM_300(vextuhrx, 6, 29),
47 GEN_VXFORM_DUAL(vmrgew, vextuwrx, 6, 30, PPC_NONE, PPC2_ALTIVEC_207),
48 GEN_VXFORM_207(vmuluwm, 4, 2),
49 GEN_VXFORM_300(vsrv, 2, 28),
50 GEN_VXFORM_300(vslv, 2, 29),
51 GEN_VXFORM(vslo, 6, 16),
52 GEN_VXFORM(vsro, 6, 17),
54 GEN_VXFORM(xpnd04_1, 0, 22),
55 GEN_VXFORM_300(bcdsr, 0, 23),
56 GEN_VXFORM_300(bcdsr, 0, 31),
57 GEN_VXFORM_300_EXT(vmul10uq, 0, 8, 0x0000F800),
58 GEN_VXFORM_300(vmul10euq, 0, 9),
59 GEN_VXFORM_300(bcdcpsgn, 0, 13),
60 GEN_VXFORM_207(bcdadd, 0, 24),
61 GEN_VXFORM_207(bcdsub, 0, 25),
62 GEN_VXFORM_300(bcdtrunc, 0, 28),
63 GEN_VXFORM_300(xpnd04_2, 0, 30),
64 GEN_VXFORM_300(bcdtrunc, 0, 20),
65 GEN_VXFORM_300(bcdutrunc, 0, 21),
66 GEN_VXFORM(vsl, 2, 7),
67 GEN_VXFORM(vsr, 2, 11),
68 GEN_VXFORM(vpkuhum, 7, 0),
69 GEN_VXFORM(vpkuwum, 7, 1),
70 GEN_VXFORM_207(vpkudum, 7, 17),
71 GEN_VXFORM(vpkuhus, 7, 2),
72 GEN_VXFORM(vpkuwus, 7, 3),
73 GEN_VXFORM_207(vpkudus, 7, 19),
74 GEN_VXFORM(vpkshus, 7, 4),
75 GEN_VXFORM(vpkswus, 7, 5),
76 GEN_VXFORM_207(vpksdus, 7, 21),
77 GEN_VXFORM(vpkshss, 7, 6),
78 GEN_VXFORM(vpkswss, 7, 7),
79 GEN_VXFORM_207(vpksdss, 7, 23),
80 GEN_VXFORM(vpkpx, 7, 12),
81 GEN_VXFORM(vsum4ubs, 4, 24),
82 GEN_VXFORM(vsum4sbs, 4, 28),
83 GEN_VXFORM(vsum4shs, 4, 25),
84 GEN_VXFORM(vsum2sws, 4, 26),
85 GEN_VXFORM(vsumsws, 4, 30),
86 GEN_VXFORM(vaddfp, 5, 0),
87 GEN_VXFORM(vsubfp, 5, 1),
88 GEN_VXFORM(vmaxfp, 5, 16),
89 GEN_VXFORM(vminfp, 5, 17),
91 #define GEN_VXRFORM1(opname, name, str, opc2, opc3)                     \
92     GEN_HANDLER2(name, str, 0x4, opc2, opc3, 0x00000000, PPC_ALTIVEC),
93 #define GEN_VXRFORM1_300(opname, name, str, opc2, opc3)                 \
94 GEN_HANDLER2_E(name, str, 0x4, opc2, opc3, 0x00000000, PPC_NONE, PPC2_ISA300),
95 #define GEN_VXRFORM(name, opc2, opc3)                                \
96     GEN_VXRFORM1(name, name, #name, opc2, opc3)                      \
97     GEN_VXRFORM1(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4)))
98 #define GEN_VXRFORM_300(name, opc2, opc3)                                   \
99     GEN_VXRFORM1_300(name, name, #name, opc2, opc3)                         \
100     GEN_VXRFORM1_300(name##_dot, name##_, #name ".", opc2, (opc3 | (0x1 << 4)))
102 GEN_VXRFORM(vcmpeqfp, 3, 3)
103 GEN_VXRFORM(vcmpgefp, 3, 7)
104 GEN_VXRFORM(vcmpgtfp, 3, 11)
105 GEN_VXRFORM(vcmpbfp, 3, 15)
107 #define GEN_VXFORM_DUAL_INV(name0, name1, opc2, opc3, inval0, inval1, type) \
108 GEN_OPCODE_DUAL(name0##_##name1, 0x04, opc2, opc3, inval0, inval1, type, \
109                                                                PPC_NONE)
110 GEN_VXFORM_DUAL_INV(vspltb, vextractub, 6, 8, 0x00000000, 0x100000,
111                                                PPC_ALTIVEC),
112 GEN_VXFORM_DUAL_INV(vsplth, vextractuh, 6, 9, 0x00000000, 0x100000,
113                                                PPC_ALTIVEC),
114 GEN_VXFORM_DUAL_INV(vspltw, vextractuw, 6, 10, 0x00000000, 0x100000,
115                                                PPC_ALTIVEC),
116 GEN_VXFORM_300_EXT(vextractd, 6, 11, 0x100000),
117 GEN_VXFORM(vspltisb, 6, 12),
118 GEN_VXFORM(vspltish, 6, 13),
119 GEN_VXFORM(vspltisw, 6, 14),
120 GEN_VXFORM_300_EO(vctzb, 0x01, 0x18, 0x1C),
121 GEN_VXFORM_300_EO(vctzh, 0x01, 0x18, 0x1D),
122 GEN_VXFORM_300_EO(vctzw, 0x01, 0x18, 0x1E),
123 GEN_VXFORM_300_EO(vctzd, 0x01, 0x18, 0x1F),
124 GEN_VXFORM_300_EO(vclzlsbb, 0x01, 0x18, 0x0),
125 GEN_VXFORM_300_EO(vctzlsbb, 0x01, 0x18, 0x1),
127 #define GEN_VXFORM_NOA(name, opc2, opc3)                                \
128     GEN_HANDLER(name, 0x04, opc2, opc3, 0x001f0000, PPC_ALTIVEC)
129 GEN_VXFORM_NOA(vupkhsb, 7, 8),
130 GEN_VXFORM_NOA(vupkhsh, 7, 9),
131 GEN_VXFORM_207(vupkhsw, 7, 25),
132 GEN_VXFORM_NOA(vupklsb, 7, 10),
133 GEN_VXFORM_NOA(vupklsh, 7, 11),
134 GEN_VXFORM_207(vupklsw, 7, 27),
135 GEN_VXFORM_NOA(vupkhpx, 7, 13),
136 GEN_VXFORM_NOA(vupklpx, 7, 15),
137 GEN_VXFORM_NOA(vrefp, 5, 4),
138 GEN_VXFORM_NOA(vrsqrtefp, 5, 5),
139 GEN_VXFORM_NOA(vexptefp, 5, 6),
140 GEN_VXFORM_NOA(vlogefp, 5, 7),
141 GEN_VXFORM_NOA(vrfim, 5, 11),
142 GEN_VXFORM_NOA(vrfin, 5, 8),
143 GEN_VXFORM_NOA(vrfip, 5, 10),
144 GEN_VXFORM_NOA(vrfiz, 5, 9),
146 #define GEN_VXFORM_UIMM(name, opc2, opc3)                               \
147     GEN_HANDLER(name, 0x04, opc2, opc3, 0x00000000, PPC_ALTIVEC)
148 GEN_VXFORM_UIMM(vcfux, 5, 12),
149 GEN_VXFORM_UIMM(vcfsx, 5, 13),
150 GEN_VXFORM_UIMM(vctuxs, 5, 14),
151 GEN_VXFORM_UIMM(vctsxs, 5, 15),
153 #define GEN_VAFORM_PAIRED(name0, name1, opc2)                           \
154     GEN_HANDLER(name0##_##name1, 0x04, opc2, 0xFF, 0x00000000, PPC_ALTIVEC)
155 GEN_VAFORM_PAIRED(vmaddfp, vnmsubfp, 23),
157 GEN_VXFORM_DUAL(vclzb, vpopcntb, 1, 28, PPC_NONE, PPC2_ALTIVEC_207),
158 GEN_VXFORM_DUAL(vclzh, vpopcnth, 1, 29, PPC_NONE, PPC2_ALTIVEC_207),
159 GEN_VXFORM_DUAL(vclzw, vpopcntw, 1, 30, PPC_NONE, PPC2_ALTIVEC_207),
160 GEN_VXFORM_DUAL(vclzd, vpopcntd, 1, 31, PPC_NONE, PPC2_ALTIVEC_207),
162 GEN_VXFORM_300(vbpermd, 6, 23),
163 GEN_VXFORM_207(vbpermq, 6, 21),
164 GEN_VXFORM_207(vgbbd, 6, 20),
165 GEN_VXFORM_207(vpmsumb, 4, 16),
166 GEN_VXFORM_207(vpmsumh, 4, 17),
167 GEN_VXFORM_207(vpmsumw, 4, 18),
169 GEN_VXFORM_207(vsbox, 4, 23),
171 GEN_VXFORM_DUAL(vcipher, vcipherlast, 4, 20, PPC_NONE, PPC2_ALTIVEC_207),
172 GEN_VXFORM_DUAL(vncipher, vncipherlast, 4, 21, PPC_NONE, PPC2_ALTIVEC_207),
174 GEN_VXFORM_207(vshasigmaw, 1, 26),
175 GEN_VXFORM_207(vshasigmad, 1, 27),
177 GEN_VXFORM_DUAL(vsldoi, vpermxor, 22, 0xFF, PPC_ALTIVEC, PPC_NONE),