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