/[pearpc]/src/cpu/cpu_jitc_x86/ppc_dec.cc
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Contents of /src/cpu/cpu_jitc_x86/ppc_dec.cc

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1 - (show annotations)
Wed Sep 5 17:11:21 2007 UTC (12 years, 2 months ago) by dpavlin
File size: 40385 byte(s)
import upstream CVS
1 /*
2 * PearPC
3 * ppc_dec.cc
4 *
5 * Copyright (C) 2003, 2004 Sebastian Biallas (sb@biallas.net)
6 * Copyright (C) 2004 Daniel Foesch (dfoesch@cs.nmsu.edu)
7 *
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 as
10 * published by the Free Software Foundation.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22
23 #include <cstring>
24
25 #include "system/types.h"
26 #include "debug/tracers.h"
27 #include "cpu/cpu.h"
28 #include "ppc_alu.h"
29 #include "ppc_cpu.h"
30 #include "ppc_dec.h"
31 #include "ppc_esc.h"
32 #include "ppc_exc.h"
33 #include "ppc_fpu.h"
34 #include "ppc_vec.h"
35 #include "ppc_mmu.h"
36 #include "ppc_opc.h"
37 #include "jitc_asm.h"
38 #include "x86asm.h"
39
40 #include "io/prom/promosi.h"
41
42 static void ppc_opc_invalid()
43 {
44 SINGLESTEP("unknown instruction\n");
45 }
46
47 static JITCFlow ppc_opc_gen_invalid()
48 {
49 // PPC_DEC_WARN("invalid instruction 0x%08x\n", gJITC.current_opc);
50 jitcClobberAll();
51 asmALURegImm(X86_MOV, ESI, gJITC.pc);
52 asmALURegImm(X86_MOV, EDX, gJITC.current_opc);
53 asmALURegImm(X86_MOV, ECX, PPC_EXC_PROGRAM_ILL);
54 asmJMP((NativeAddress)ppc_program_exception_asm);
55 return flowEndBlockUnreachable;
56 }
57
58 static void ppc_opc_special()
59 {
60 if (gCPU.pc == gPromOSIEntry && gCPU.current_opc == PROM_MAGIC_OPCODE) {
61 call_prom_osi();
62 return;
63 }
64 if (gCPU.current_opc == 0x00333301) {
65 // memset(r3, r4, r5)
66 uint32 dest = gCPU.gpr[3];
67 uint32 c = gCPU.gpr[4];
68 uint32 size = gCPU.gpr[5];
69 if (dest & 0xfff) {
70 byte *dst;
71 ppc_direct_effective_memory_handle(dest, dst);
72 uint32 a = 4096 - (dest & 0xfff);
73 memset(dst, c, a);
74 size -= a;
75 dest += a;
76 }
77 while (size >= 4096) {
78 byte *dst;
79 ppc_direct_effective_memory_handle(dest, dst);
80 memset(dst, c, 4096);
81 dest += 4096;
82 size -= 4096;
83 }
84 if (size) {
85 byte *dst;
86 ppc_direct_effective_memory_handle(dest, dst);
87 memset(dst, c, size);
88 }
89 gCPU.pc = gCPU.npc;
90 return;
91 }
92 if (gCPU.current_opc == 0x00333302) {
93 // memcpy
94 uint32 dest = gCPU.gpr[3];
95 uint32 src = gCPU.gpr[4];
96 uint32 size = gCPU.gpr[5];
97 byte *d, *s;
98 ppc_direct_effective_memory_handle(dest, d);
99 ppc_direct_effective_memory_handle(src, s);
100 while (size--) {
101 if (!(dest & 0xfff)) ppc_direct_effective_memory_handle(dest, d);
102 if (!(src & 0xfff)) ppc_direct_effective_memory_handle(src, s);
103 *d = *s;
104 src++; dest++; d++; s++;
105 }
106 gCPU.pc = gCPU.npc;
107 return;
108 }
109 ppc_opc_invalid();
110 }
111
112 static JITCFlow ppc_opc_gen_special()
113 {
114 if (gJITC.current_opc == PPC_OPC_ESCAPE_VM) {
115 jitcGetClientRegister(PPC_GPR(3), NATIVE_REG | EAX);
116 jitcClobberAll();
117 asmALURegReg(X86_MOV, EDX, ESP);
118 asmALURegImm(X86_MOV, ECX, gJITC.pc);
119 PPC_ESC_TRACE("pc = %08x\n", gJITC.pc);
120 asmCALL((NativeAddress)&ppc_escape_vm);
121 return flowEndBlock;
122 }
123 if (gJITC.pc == (gPromOSIEntry&0xfff) && gJITC.current_opc == PROM_MAGIC_OPCODE) {
124 jitcClobberAll();
125
126 asmMOVRegDMem(EAX, (uint32)&gCPU.current_code_base);
127 asmALURegImm(X86_ADD, EAX, gJITC.pc);
128 asmMOVDMemReg((uint32)&gCPU.pc, EAX);
129 asmCALL((NativeAddress)&call_prom_osi);
130 return flowEndBlock;
131 }
132 return ppc_opc_gen_invalid();
133 }
134
135 // main opcode 19
136 static void ppc_opc_group_1()
137 {
138 uint32 ext = PPC_OPC_EXT(gCPU.current_opc);
139 if (ext & 1) {
140 // crxxx
141 if (ext <= 225) {
142 switch (ext) {
143 case 33: ppc_opc_crnor(); return;
144 case 129: ppc_opc_crandc(); return;
145 case 193: ppc_opc_crxor(); return;
146 case 225: ppc_opc_crnand(); return;
147 }
148 } else {
149 switch (ext) {
150 case 257: ppc_opc_crand(); return;
151 case 289: ppc_opc_creqv(); return;
152 case 417: ppc_opc_crorc(); return;
153 case 449: ppc_opc_cror(); return;
154 }
155 }
156 } else if (ext & (1<<9)) {
157 // bcctrx
158 if (ext == 528) {
159 ppc_opc_bcctrx();
160 return;
161 }
162 } else {
163 switch (ext) {
164 case 16: ppc_opc_bclrx(); return;
165 case 0: ppc_opc_mcrf(); return;
166 case 50: ppc_opc_rfi(); return;
167 case 150: ppc_opc_isync(); return;
168 }
169 }
170 return ppc_opc_invalid();
171 }
172 static JITCFlow ppc_opc_gen_group_1()
173 {
174 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
175 if (ext & 1) {
176 // crxxx
177 if (ext <= 225) {
178 switch (ext) {
179 case 33: return ppc_opc_gen_crnor();
180 case 129: return ppc_opc_gen_crandc();
181 case 193: return ppc_opc_gen_crxor();
182 case 225: return ppc_opc_gen_crnand();
183 }
184 } else {
185 switch (ext) {
186 case 257: return ppc_opc_gen_crand();
187 case 289: return ppc_opc_gen_creqv();
188 case 417: return ppc_opc_gen_crorc();
189 case 449: return ppc_opc_gen_cror();
190 }
191 }
192 } else if (ext & (1<<9)) {
193 // bcctrx
194 if (ext == 528) {
195 return ppc_opc_gen_bcctrx();
196 }
197 } else {
198 switch (ext) {
199 case 16: return ppc_opc_gen_bclrx();
200 case 0: return ppc_opc_gen_mcrf();
201 case 50: return ppc_opc_gen_rfi();
202 case 150: return ppc_opc_gen_isync();
203 }
204 }
205 return ppc_opc_gen_invalid();
206 }
207
208 ppc_opc_function ppc_opc_table_group2[1015];
209 ppc_opc_gen_function ppc_opc_table_gen_group2[1015];
210
211 // main opcode 31
212 static void ppc_opc_init_group2()
213 {
214 for (uint i=0; i<(sizeof ppc_opc_table_group2 / sizeof ppc_opc_table_group2[0]); i++) {
215 ppc_opc_table_group2[i] = ppc_opc_invalid;
216 ppc_opc_table_gen_group2[i] = ppc_opc_gen_invalid;
217 }
218 ppc_opc_table_group2[0] = ppc_opc_cmp;
219 ppc_opc_table_group2[4] = ppc_opc_tw;
220 ppc_opc_table_group2[8] = ppc_opc_subfcx;//+
221 ppc_opc_table_group2[10] = ppc_opc_addcx;//+
222 ppc_opc_table_group2[11] = ppc_opc_mulhwux;
223 ppc_opc_table_group2[19] = ppc_opc_mfcr;
224 ppc_opc_table_group2[20] = ppc_opc_lwarx;
225 ppc_opc_table_group2[23] = ppc_opc_lwzx;
226 ppc_opc_table_group2[24] = ppc_opc_slwx;
227 ppc_opc_table_group2[26] = ppc_opc_cntlzwx;
228 ppc_opc_table_group2[28] = ppc_opc_andx;
229 ppc_opc_table_group2[32] = ppc_opc_cmpl;
230 ppc_opc_table_group2[40] = ppc_opc_subfx;
231 ppc_opc_table_group2[54] = ppc_opc_dcbst;
232 ppc_opc_table_group2[55] = ppc_opc_lwzux;
233 ppc_opc_table_group2[60] = ppc_opc_andcx;
234 ppc_opc_table_group2[75] = ppc_opc_mulhwx;
235 ppc_opc_table_group2[83] = ppc_opc_mfmsr;
236 ppc_opc_table_group2[86] = ppc_opc_dcbf;
237 ppc_opc_table_group2[87] = ppc_opc_lbzx;
238 ppc_opc_table_group2[104] = ppc_opc_negx;
239 ppc_opc_table_group2[119] = ppc_opc_lbzux;
240 ppc_opc_table_group2[124] = ppc_opc_norx;
241 ppc_opc_table_group2[136] = ppc_opc_subfex;//+
242 ppc_opc_table_group2[138] = ppc_opc_addex;//+
243 ppc_opc_table_group2[144] = ppc_opc_mtcrf;
244 ppc_opc_table_group2[146] = ppc_opc_mtmsr;
245 ppc_opc_table_group2[150] = ppc_opc_stwcx_;
246 ppc_opc_table_group2[151] = ppc_opc_stwx;
247 ppc_opc_table_group2[183] = ppc_opc_stwux;
248 ppc_opc_table_group2[200] = ppc_opc_subfzex;//+
249 ppc_opc_table_group2[202] = ppc_opc_addzex;//+
250 ppc_opc_table_group2[210] = ppc_opc_mtsr;
251 ppc_opc_table_group2[215] = ppc_opc_stbx;
252 ppc_opc_table_group2[232] = ppc_opc_subfmex;//+
253 ppc_opc_table_group2[234] = ppc_opc_addmex;
254 ppc_opc_table_group2[235] = ppc_opc_mullwx;//+
255 ppc_opc_table_group2[242] = ppc_opc_mtsrin;
256 ppc_opc_table_group2[246] = ppc_opc_dcbtst;
257 ppc_opc_table_group2[247] = ppc_opc_stbux;
258 ppc_opc_table_group2[266] = ppc_opc_addx;//+
259 ppc_opc_table_group2[278] = ppc_opc_dcbt;
260 ppc_opc_table_group2[279] = ppc_opc_lhzx;
261 ppc_opc_table_group2[284] = ppc_opc_eqvx;
262 ppc_opc_table_group2[306] = ppc_opc_tlbie;
263 ppc_opc_table_group2[310] = ppc_opc_eciwx;
264 ppc_opc_table_group2[311] = ppc_opc_lhzux;
265 ppc_opc_table_group2[316] = ppc_opc_xorx;
266 ppc_opc_table_group2[339] = ppc_opc_mfspr;
267 ppc_opc_table_group2[343] = ppc_opc_lhax;
268 ppc_opc_table_group2[370] = ppc_opc_tlbia;
269 ppc_opc_table_group2[371] = ppc_opc_mftb;
270 ppc_opc_table_group2[375] = ppc_opc_lhaux;
271 ppc_opc_table_group2[407] = ppc_opc_sthx;
272 ppc_opc_table_group2[412] = ppc_opc_orcx;
273 ppc_opc_table_group2[438] = ppc_opc_ecowx;
274 ppc_opc_table_group2[439] = ppc_opc_sthux;
275 ppc_opc_table_group2[444] = ppc_opc_orx;
276 ppc_opc_table_group2[459] = ppc_opc_divwux;//+
277 ppc_opc_table_group2[467] = ppc_opc_mtspr;
278 ppc_opc_table_group2[470] = ppc_opc_dcbi;
279 ppc_opc_table_group2[476] = ppc_opc_nandx;
280 ppc_opc_table_group2[491] = ppc_opc_divwx;//+
281 ppc_opc_table_group2[512] = ppc_opc_mcrxr;
282 ppc_opc_table_group2[533] = ppc_opc_lswx;
283 ppc_opc_table_group2[534] = ppc_opc_lwbrx;
284 ppc_opc_table_group2[535] = ppc_opc_lfsx;
285 ppc_opc_table_group2[536] = ppc_opc_srwx;
286 ppc_opc_table_group2[566] = ppc_opc_tlbsync;
287 ppc_opc_table_group2[567] = ppc_opc_lfsux;
288 ppc_opc_table_group2[595] = ppc_opc_mfsr;
289 ppc_opc_table_group2[597] = ppc_opc_lswi;
290 ppc_opc_table_group2[598] = ppc_opc_sync;
291 ppc_opc_table_group2[599] = ppc_opc_lfdx;
292 ppc_opc_table_group2[631] = ppc_opc_lfdux;
293 ppc_opc_table_group2[659] = ppc_opc_mfsrin;
294 ppc_opc_table_group2[661] = ppc_opc_stswx;
295 ppc_opc_table_group2[662] = ppc_opc_stwbrx;
296 ppc_opc_table_group2[663] = ppc_opc_stfsx;
297 ppc_opc_table_group2[695] = ppc_opc_stfsux;
298 ppc_opc_table_group2[725] = ppc_opc_stswi;
299 ppc_opc_table_group2[727] = ppc_opc_stfdx;
300 ppc_opc_table_group2[758] = ppc_opc_dcba;
301 ppc_opc_table_group2[759] = ppc_opc_stfdux;
302 ppc_opc_table_group2[790] = ppc_opc_lhbrx;
303 ppc_opc_table_group2[792] = ppc_opc_srawx;
304 ppc_opc_table_group2[824] = ppc_opc_srawix;
305 ppc_opc_table_group2[854] = ppc_opc_eieio;
306 ppc_opc_table_group2[918] = ppc_opc_sthbrx;
307 ppc_opc_table_group2[922] = ppc_opc_extshx;
308 ppc_opc_table_group2[954] = ppc_opc_extsbx;
309 ppc_opc_table_group2[982] = ppc_opc_icbi;
310 ppc_opc_table_group2[983] = ppc_opc_stfiwx;
311 ppc_opc_table_group2[1014] = ppc_opc_dcbz;
312 ppc_opc_table_gen_group2[0] = ppc_opc_gen_cmp;
313 ppc_opc_table_gen_group2[4] = ppc_opc_gen_tw;
314 ppc_opc_table_gen_group2[8] = ppc_opc_gen_subfcx;//+
315 ppc_opc_table_gen_group2[10] = ppc_opc_gen_addcx;//+
316 ppc_opc_table_gen_group2[11] = ppc_opc_gen_mulhwux;
317 ppc_opc_table_gen_group2[19] = ppc_opc_gen_mfcr;
318 ppc_opc_table_gen_group2[20] = ppc_opc_gen_lwarx;
319 ppc_opc_table_gen_group2[23] = ppc_opc_gen_lwzx;
320 ppc_opc_table_gen_group2[24] = ppc_opc_gen_slwx;
321 ppc_opc_table_gen_group2[26] = ppc_opc_gen_cntlzwx;
322 ppc_opc_table_gen_group2[28] = ppc_opc_gen_andx;
323 ppc_opc_table_gen_group2[32] = ppc_opc_gen_cmpl;
324 ppc_opc_table_gen_group2[40] = ppc_opc_gen_subfx;
325 ppc_opc_table_gen_group2[54] = ppc_opc_gen_dcbst;
326 ppc_opc_table_gen_group2[55] = ppc_opc_gen_lwzux;
327 ppc_opc_table_gen_group2[60] = ppc_opc_gen_andcx;
328 ppc_opc_table_gen_group2[75] = ppc_opc_gen_mulhwx;
329 ppc_opc_table_gen_group2[83] = ppc_opc_gen_mfmsr;
330 ppc_opc_table_gen_group2[86] = ppc_opc_gen_dcbf;
331 ppc_opc_table_gen_group2[87] = ppc_opc_gen_lbzx;
332 ppc_opc_table_gen_group2[104] = ppc_opc_gen_negx;
333 ppc_opc_table_gen_group2[119] = ppc_opc_gen_lbzux;
334 ppc_opc_table_gen_group2[124] = ppc_opc_gen_norx;
335 ppc_opc_table_gen_group2[136] = ppc_opc_gen_subfex;//+
336 ppc_opc_table_gen_group2[138] = ppc_opc_gen_addex;//+
337 ppc_opc_table_gen_group2[144] = ppc_opc_gen_mtcrf;
338 ppc_opc_table_gen_group2[146] = ppc_opc_gen_mtmsr;
339 ppc_opc_table_gen_group2[150] = ppc_opc_gen_stwcx_;
340 ppc_opc_table_gen_group2[151] = ppc_opc_gen_stwx;
341 ppc_opc_table_gen_group2[183] = ppc_opc_gen_stwux;
342 ppc_opc_table_gen_group2[200] = ppc_opc_gen_subfzex;//+
343 ppc_opc_table_gen_group2[202] = ppc_opc_gen_addzex;//+
344 ppc_opc_table_gen_group2[210] = ppc_opc_gen_mtsr;
345 ppc_opc_table_gen_group2[215] = ppc_opc_gen_stbx;
346 ppc_opc_table_gen_group2[232] = ppc_opc_gen_subfmex;//+
347 ppc_opc_table_gen_group2[234] = ppc_opc_gen_addmex;
348 ppc_opc_table_gen_group2[235] = ppc_opc_gen_mullwx;//+
349 ppc_opc_table_gen_group2[242] = ppc_opc_gen_mtsrin;
350 ppc_opc_table_gen_group2[246] = ppc_opc_gen_dcbtst;
351 ppc_opc_table_gen_group2[247] = ppc_opc_gen_stbux;
352 ppc_opc_table_gen_group2[266] = ppc_opc_gen_addx;//+
353 ppc_opc_table_gen_group2[278] = ppc_opc_gen_dcbt;
354 ppc_opc_table_gen_group2[279] = ppc_opc_gen_lhzx;
355 ppc_opc_table_gen_group2[284] = ppc_opc_gen_eqvx;
356 ppc_opc_table_gen_group2[306] = ppc_opc_gen_tlbie;
357 ppc_opc_table_gen_group2[310] = ppc_opc_gen_eciwx;
358 ppc_opc_table_gen_group2[311] = ppc_opc_gen_lhzux;
359 ppc_opc_table_gen_group2[316] = ppc_opc_gen_xorx;
360 ppc_opc_table_gen_group2[339] = ppc_opc_gen_mfspr;
361 ppc_opc_table_gen_group2[343] = ppc_opc_gen_lhax;
362 ppc_opc_table_gen_group2[370] = ppc_opc_gen_tlbia;
363 ppc_opc_table_gen_group2[371] = ppc_opc_gen_mftb;
364 ppc_opc_table_gen_group2[375] = ppc_opc_gen_lhaux;
365 ppc_opc_table_gen_group2[407] = ppc_opc_gen_sthx;
366 ppc_opc_table_gen_group2[412] = ppc_opc_gen_orcx;
367 ppc_opc_table_gen_group2[438] = ppc_opc_gen_ecowx;
368 ppc_opc_table_gen_group2[439] = ppc_opc_gen_sthux;
369 ppc_opc_table_gen_group2[444] = ppc_opc_gen_orx;
370 ppc_opc_table_gen_group2[459] = ppc_opc_gen_divwux;//+
371 ppc_opc_table_gen_group2[467] = ppc_opc_gen_mtspr;
372 ppc_opc_table_gen_group2[470] = ppc_opc_gen_dcbi;
373 ppc_opc_table_gen_group2[476] = ppc_opc_gen_nandx;
374 ppc_opc_table_gen_group2[491] = ppc_opc_gen_divwx;//+
375 ppc_opc_table_gen_group2[512] = ppc_opc_gen_mcrxr;
376 ppc_opc_table_gen_group2[533] = ppc_opc_gen_lswx;
377 ppc_opc_table_gen_group2[534] = ppc_opc_gen_lwbrx;
378 ppc_opc_table_gen_group2[535] = ppc_opc_gen_lfsx;
379 ppc_opc_table_gen_group2[536] = ppc_opc_gen_srwx;
380 ppc_opc_table_gen_group2[566] = ppc_opc_gen_tlbsync;
381 ppc_opc_table_gen_group2[567] = ppc_opc_gen_lfsux;
382 ppc_opc_table_gen_group2[595] = ppc_opc_gen_mfsr;
383 ppc_opc_table_gen_group2[597] = ppc_opc_gen_lswi;
384 ppc_opc_table_gen_group2[598] = ppc_opc_gen_sync;
385 ppc_opc_table_gen_group2[599] = ppc_opc_gen_lfdx;
386 ppc_opc_table_gen_group2[631] = ppc_opc_gen_lfdux;
387 ppc_opc_table_gen_group2[659] = ppc_opc_gen_mfsrin;
388 ppc_opc_table_gen_group2[661] = ppc_opc_gen_stswx;
389 ppc_opc_table_gen_group2[662] = ppc_opc_gen_stwbrx;
390 ppc_opc_table_gen_group2[663] = ppc_opc_gen_stfsx;
391 ppc_opc_table_gen_group2[695] = ppc_opc_gen_stfsux;
392 ppc_opc_table_gen_group2[725] = ppc_opc_gen_stswi;
393 ppc_opc_table_gen_group2[727] = ppc_opc_gen_stfdx;
394 ppc_opc_table_gen_group2[758] = ppc_opc_gen_dcba;
395 ppc_opc_table_gen_group2[759] = ppc_opc_gen_stfdux;
396 ppc_opc_table_gen_group2[790] = ppc_opc_gen_lhbrx;
397 ppc_opc_table_gen_group2[792] = ppc_opc_gen_srawx;
398 ppc_opc_table_gen_group2[824] = ppc_opc_gen_srawix;
399 ppc_opc_table_gen_group2[854] = ppc_opc_gen_eieio;
400 ppc_opc_table_gen_group2[918] = ppc_opc_gen_sthbrx;
401 ppc_opc_table_gen_group2[922] = ppc_opc_gen_extshx;
402 ppc_opc_table_gen_group2[954] = ppc_opc_gen_extsbx;
403 ppc_opc_table_gen_group2[982] = ppc_opc_gen_icbi;
404 ppc_opc_table_gen_group2[983] = ppc_opc_gen_stfiwx;
405 ppc_opc_table_gen_group2[1014] = ppc_opc_gen_dcbz;
406
407 if ((ppc_cpu_get_pvr(0) & 0xffff0000) == 0x000c0000) {
408 /* Added for Altivec support */
409 ppc_opc_table_group2[6] = ppc_opc_lvsl;
410 ppc_opc_table_group2[7] = ppc_opc_lvebx;
411 ppc_opc_table_group2[38] = ppc_opc_lvsr;
412 ppc_opc_table_group2[39] = ppc_opc_lvehx;
413 ppc_opc_table_group2[71] = ppc_opc_lvewx;
414 ppc_opc_table_group2[103] = ppc_opc_lvx;
415 ppc_opc_table_group2[135] = ppc_opc_stvebx;
416 ppc_opc_table_group2[167] = ppc_opc_stvehx;
417 ppc_opc_table_group2[199] = ppc_opc_stvewx;
418 ppc_opc_table_group2[231] = ppc_opc_stvx;
419 ppc_opc_table_group2[342] = ppc_opc_dst;
420 ppc_opc_table_group2[359] = ppc_opc_lvxl;
421 ppc_opc_table_group2[374] = ppc_opc_dstst;
422 ppc_opc_table_group2[487] = ppc_opc_stvxl;
423 ppc_opc_table_group2[822] = ppc_opc_dss;
424
425 ppc_opc_table_gen_group2[6] = ppc_opc_gen_lvsl;
426 ppc_opc_table_gen_group2[7] = ppc_opc_gen_lvebx;
427 ppc_opc_table_gen_group2[38] = ppc_opc_gen_lvsr;
428 ppc_opc_table_gen_group2[39] = ppc_opc_gen_lvehx;
429 ppc_opc_table_gen_group2[71] = ppc_opc_gen_lvewx;
430 ppc_opc_table_gen_group2[103] = ppc_opc_gen_lvx;
431 ppc_opc_table_gen_group2[135] = ppc_opc_gen_stvebx;
432 ppc_opc_table_gen_group2[167] = ppc_opc_gen_stvehx;
433 ppc_opc_table_gen_group2[199] = ppc_opc_gen_stvewx;
434 ppc_opc_table_gen_group2[231] = ppc_opc_gen_stvx;
435 ppc_opc_table_gen_group2[342] = ppc_opc_gen_dst;
436 ppc_opc_table_gen_group2[359] = ppc_opc_gen_lvxl;
437 ppc_opc_table_gen_group2[374] = ppc_opc_gen_dstst;
438 ppc_opc_table_gen_group2[487] = ppc_opc_gen_stvxl;
439 ppc_opc_table_gen_group2[822] = ppc_opc_gen_dss;
440 }
441 }
442
443 // main opcode 31
444 static void ppc_opc_group_2()
445 {
446 uint32 ext = PPC_OPC_EXT(gCPU.current_opc);
447 if (ext >= (sizeof ppc_opc_table_group2 / sizeof ppc_opc_table_group2[0])) {
448 ppc_opc_invalid();
449 }
450 ppc_opc_table_group2[ext]();
451 }
452 static JITCFlow ppc_opc_gen_group_2()
453 {
454 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
455 if (ext >= (sizeof ppc_opc_table_group2 / sizeof ppc_opc_table_group2[0])) {
456 return ppc_opc_gen_invalid();
457 }
458 return ppc_opc_table_gen_group2[ext]();
459 }
460
461 // main opcode 59
462 static void ppc_opc_group_f1()
463 {
464 if ((gCPU.msr & MSR_FP) == 0) {
465 ppc_exception(PPC_EXC_NO_FPU);
466 return;
467 }
468 uint32 ext = PPC_OPC_EXT(gCPU.current_opc);
469 switch (ext & 0x1f) {
470 case 18: ppc_opc_fdivsx(); return;
471 case 20: ppc_opc_fsubsx(); return;
472 case 21: ppc_opc_faddsx(); return;
473 case 22: ppc_opc_fsqrtsx(); return;
474 case 24: ppc_opc_fresx(); return;
475 case 25: ppc_opc_fmulsx(); return;
476 case 28: ppc_opc_fmsubsx(); return;
477 case 29: ppc_opc_fmaddsx(); return;
478 case 30: ppc_opc_fnmsubsx(); return;
479 case 31: ppc_opc_fnmaddsx(); return;
480 }
481 ppc_opc_invalid();
482 }
483 static JITCFlow ppc_opc_gen_group_f1()
484 {
485 ppc_opc_gen_check_fpu();
486 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
487 switch (ext & 0x1f) {
488 case 18: return ppc_opc_gen_fdivsx();
489 case 20: return ppc_opc_gen_fsubsx();
490 case 21: return ppc_opc_gen_faddsx();
491 case 22: return ppc_opc_gen_fsqrtsx();
492 case 24: return ppc_opc_gen_fresx();
493 case 25: return ppc_opc_gen_fmulsx();
494 case 28: return ppc_opc_gen_fmsubsx();
495 case 29: return ppc_opc_gen_fmaddsx();
496 case 30: return ppc_opc_gen_fnmsubsx();
497 case 31: return ppc_opc_gen_fnmaddsx();
498 }
499 return ppc_opc_gen_invalid();
500 }
501
502 // main opcode 63
503 static void ppc_opc_group_f2()
504 {
505 if ((gCPU.msr & MSR_FP) == 0) {
506 ppc_exception(PPC_EXC_NO_FPU);
507 return;
508 }
509 uint32 ext = PPC_OPC_EXT(gCPU.current_opc);
510 if (ext & 16) {
511 switch (ext & 0x1f) {
512 case 18: ppc_opc_fdivx(); return;
513 case 20: ppc_opc_fsubx(); return;
514 case 21: ppc_opc_faddx(); return;
515 case 22: ppc_opc_fsqrtx(); return;
516 case 23: ppc_opc_fselx(); return;
517 case 25: ppc_opc_fmulx(); return;
518 case 26: ppc_opc_frsqrtex(); return;
519 case 28: ppc_opc_fmsubx(); return;
520 case 29: ppc_opc_fmaddx(); return;
521 case 30: ppc_opc_fnmsubx(); return;
522 case 31: ppc_opc_fnmaddx(); return;
523 }
524 } else {
525 switch (ext) {
526 case 0: ppc_opc_fcmpu(); return;
527 case 12: ppc_opc_frspx(); return;
528 case 14: ppc_opc_fctiwx(); return;
529 case 15: ppc_opc_fctiwzx(); return;
530 //--
531 case 32: ppc_opc_fcmpo(); return;
532 case 38: ppc_opc_mtfsb1x(); return;
533 case 40: ppc_opc_fnegx(); return;
534 case 64: ppc_opc_mcrfs(); return;
535 case 70: ppc_opc_mtfsb0x(); return;
536 case 72: ppc_opc_fmrx(); return;
537 case 134: ppc_opc_mtfsfix(); return;
538 case 136: ppc_opc_fnabsx(); return;
539 case 264: ppc_opc_fabsx(); return;
540 case 583: ppc_opc_mffsx(); return;
541 case 711: ppc_opc_mtfsfx(); return;
542 }
543 }
544 ppc_opc_invalid();
545 }
546 static JITCFlow ppc_opc_gen_group_f2()
547 {
548 ppc_opc_gen_check_fpu();
549 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
550 if (ext & 16) {
551 switch (ext & 0x1f) {
552 case 18: return ppc_opc_gen_fdivx();
553 case 20: return ppc_opc_gen_fsubx();
554 case 21: return ppc_opc_gen_faddx();
555 case 22: return ppc_opc_gen_fsqrtx();
556 case 23: return ppc_opc_gen_fselx();
557 case 25: return ppc_opc_gen_fmulx();
558 case 26: return ppc_opc_gen_frsqrtex();
559 case 28: return ppc_opc_gen_fmsubx();
560 case 29: return ppc_opc_gen_fmaddx();
561 case 30: return ppc_opc_gen_fnmsubx();
562 case 31: return ppc_opc_gen_fnmaddx();
563 }
564 } else {
565 switch (ext) {
566 case 0: return ppc_opc_gen_fcmpu();
567 case 12: return ppc_opc_gen_frspx();
568 case 14: return ppc_opc_gen_fctiwx();
569 case 15: return ppc_opc_gen_fctiwzx();
570 //--
571 case 32: return ppc_opc_gen_fcmpo();
572 case 38: return ppc_opc_gen_mtfsb1x();
573 case 40: return ppc_opc_gen_fnegx();
574 case 64: return ppc_opc_gen_mcrfs();
575 case 70: return ppc_opc_gen_mtfsb0x();
576 case 72: return ppc_opc_gen_fmrx();
577 case 134: return ppc_opc_gen_mtfsfix();
578 case 136: return ppc_opc_gen_fnabsx();
579 case 264: return ppc_opc_gen_fabsx();
580 case 583: return ppc_opc_gen_mffsx();
581 case 711: return ppc_opc_gen_mtfsfx();
582 }
583 }
584 return ppc_opc_gen_invalid();
585 }
586
587 ppc_opc_function ppc_opc_table_groupv[965];
588 ppc_opc_gen_function ppc_opc_table_gen_groupv[965];
589
590 static void ppc_opc_init_groupv()
591 {
592 for (uint i=0; i<(sizeof ppc_opc_table_groupv / sizeof ppc_opc_table_groupv[0]);i++) {
593 ppc_opc_table_groupv[i] = ppc_opc_invalid;
594 ppc_opc_table_gen_groupv[i] = ppc_opc_gen_invalid;
595 }
596 ppc_opc_table_groupv[0] = ppc_opc_vaddubm;
597 ppc_opc_table_groupv[1] = ppc_opc_vmaxub;
598 ppc_opc_table_groupv[2] = ppc_opc_vrlb;
599 ppc_opc_table_groupv[4] = ppc_opc_vmuloub;
600 ppc_opc_table_groupv[5] = ppc_opc_vaddfp;
601 ppc_opc_table_groupv[6] = ppc_opc_vmrghb;
602 ppc_opc_table_groupv[7] = ppc_opc_vpkuhum;
603 ppc_opc_table_groupv[32] = ppc_opc_vadduhm;
604 ppc_opc_table_groupv[33] = ppc_opc_vmaxuh;
605 ppc_opc_table_groupv[34] = ppc_opc_vrlh;
606 ppc_opc_table_groupv[36] = ppc_opc_vmulouh;
607 ppc_opc_table_groupv[37] = ppc_opc_vsubfp;
608 ppc_opc_table_groupv[38] = ppc_opc_vmrghh;
609 ppc_opc_table_groupv[39] = ppc_opc_vpkuwum;
610 ppc_opc_table_groupv[42] = ppc_opc_vpkpx;
611 ppc_opc_table_groupv[64] = ppc_opc_vadduwm;
612 ppc_opc_table_groupv[65] = ppc_opc_vmaxuw;
613 ppc_opc_table_groupv[66] = ppc_opc_vrlw;
614 ppc_opc_table_groupv[70] = ppc_opc_vmrghw;
615 ppc_opc_table_groupv[71] = ppc_opc_vpkuhus;
616 ppc_opc_table_groupv[103] = ppc_opc_vpkuwus;
617 ppc_opc_table_groupv[129] = ppc_opc_vmaxsb;
618 ppc_opc_table_groupv[130] = ppc_opc_vslb;
619 ppc_opc_table_groupv[132] = ppc_opc_vmulosb;
620 ppc_opc_table_groupv[133] = ppc_opc_vrefp;
621 ppc_opc_table_groupv[134] = ppc_opc_vmrglb;
622 ppc_opc_table_groupv[135] = ppc_opc_vpkshus;
623 ppc_opc_table_groupv[161] = ppc_opc_vmaxsh;
624 ppc_opc_table_groupv[162] = ppc_opc_vslh;
625 ppc_opc_table_groupv[164] = ppc_opc_vmulosh;
626 ppc_opc_table_groupv[165] = ppc_opc_vrsqrtefp;
627 ppc_opc_table_groupv[166] = ppc_opc_vmrglh;
628 ppc_opc_table_groupv[167] = ppc_opc_vpkswus;
629 ppc_opc_table_groupv[192] = ppc_opc_vaddcuw;
630 ppc_opc_table_groupv[193] = ppc_opc_vmaxsw;
631 ppc_opc_table_groupv[194] = ppc_opc_vslw;
632 ppc_opc_table_groupv[197] = ppc_opc_vexptefp;
633 ppc_opc_table_groupv[198] = ppc_opc_vmrglw;
634 ppc_opc_table_groupv[199] = ppc_opc_vpkshss;
635 ppc_opc_table_groupv[226] = ppc_opc_vsl;
636 ppc_opc_table_groupv[229] = ppc_opc_vlogefp;
637 ppc_opc_table_groupv[231] = ppc_opc_vpkswss;
638 ppc_opc_table_groupv[256] = ppc_opc_vaddubs;
639 ppc_opc_table_groupv[257] = ppc_opc_vminub;
640 ppc_opc_table_groupv[258] = ppc_opc_vsrb;
641 ppc_opc_table_groupv[260] = ppc_opc_vmuleub;
642 ppc_opc_table_groupv[261] = ppc_opc_vrfin;
643 ppc_opc_table_groupv[262] = ppc_opc_vspltb;
644 ppc_opc_table_groupv[263] = ppc_opc_vupkhsb;
645 ppc_opc_table_groupv[288] = ppc_opc_vadduhs;
646 ppc_opc_table_groupv[289] = ppc_opc_vminuh;
647 ppc_opc_table_groupv[290] = ppc_opc_vsrh;
648 ppc_opc_table_groupv[292] = ppc_opc_vmuleuh;
649 ppc_opc_table_groupv[293] = ppc_opc_vrfiz;
650 ppc_opc_table_groupv[294] = ppc_opc_vsplth;
651 ppc_opc_table_groupv[295] = ppc_opc_vupkhsh;
652 ppc_opc_table_groupv[320] = ppc_opc_vadduws;
653 ppc_opc_table_groupv[321] = ppc_opc_vminuw;
654 ppc_opc_table_groupv[322] = ppc_opc_vsrw;
655 ppc_opc_table_groupv[325] = ppc_opc_vrfip;
656 ppc_opc_table_groupv[326] = ppc_opc_vspltw;
657 ppc_opc_table_groupv[327] = ppc_opc_vupklsb;
658 ppc_opc_table_groupv[354] = ppc_opc_vsr;
659 ppc_opc_table_groupv[357] = ppc_opc_vrfim;
660 ppc_opc_table_groupv[359] = ppc_opc_vupklsh;
661 ppc_opc_table_groupv[384] = ppc_opc_vaddsbs;
662 ppc_opc_table_groupv[385] = ppc_opc_vminsb;
663 ppc_opc_table_groupv[386] = ppc_opc_vsrab;
664 ppc_opc_table_groupv[388] = ppc_opc_vmulesb;
665 ppc_opc_table_groupv[389] = ppc_opc_vcfux;
666 ppc_opc_table_groupv[390] = ppc_opc_vspltisb;
667 ppc_opc_table_groupv[391] = ppc_opc_vpkpx;
668 ppc_opc_table_groupv[416] = ppc_opc_vaddshs;
669 ppc_opc_table_groupv[417] = ppc_opc_vminsh;
670 ppc_opc_table_groupv[418] = ppc_opc_vsrah;
671 ppc_opc_table_groupv[420] = ppc_opc_vmulesh;
672 ppc_opc_table_groupv[421] = ppc_opc_vcfsx;
673 ppc_opc_table_groupv[422] = ppc_opc_vspltish;
674 ppc_opc_table_groupv[423] = ppc_opc_vupkhpx;
675 ppc_opc_table_groupv[448] = ppc_opc_vaddsws;
676 ppc_opc_table_groupv[449] = ppc_opc_vminsw;
677 ppc_opc_table_groupv[450] = ppc_opc_vsraw;
678 ppc_opc_table_groupv[453] = ppc_opc_vctuxs;
679 ppc_opc_table_groupv[454] = ppc_opc_vspltisw;
680 ppc_opc_table_groupv[485] = ppc_opc_vctsxs;
681 ppc_opc_table_groupv[487] = ppc_opc_vupklpx;
682 ppc_opc_table_groupv[512] = ppc_opc_vsububm;
683 ppc_opc_table_groupv[513] = ppc_opc_vavgub;
684 ppc_opc_table_groupv[514] = ppc_opc_vand;
685 ppc_opc_table_groupv[517] = ppc_opc_vmaxfp;
686 ppc_opc_table_groupv[518] = ppc_opc_vslo;
687 ppc_opc_table_groupv[544] = ppc_opc_vsubuhm;
688 ppc_opc_table_groupv[545] = ppc_opc_vavguh;
689 ppc_opc_table_groupv[546] = ppc_opc_vandc;
690 ppc_opc_table_groupv[549] = ppc_opc_vminfp;
691 ppc_opc_table_groupv[550] = ppc_opc_vsro;
692 ppc_opc_table_groupv[576] = ppc_opc_vsubuwm;
693 ppc_opc_table_groupv[577] = ppc_opc_vavguw;
694 ppc_opc_table_groupv[578] = ppc_opc_vor;
695 ppc_opc_table_groupv[610] = ppc_opc_vxor;
696 ppc_opc_table_groupv[641] = ppc_opc_vavgsb;
697 ppc_opc_table_groupv[642] = ppc_opc_vnor;
698 ppc_opc_table_groupv[673] = ppc_opc_vavgsh;
699 ppc_opc_table_groupv[704] = ppc_opc_vsubcuw;
700 ppc_opc_table_groupv[705] = ppc_opc_vavgsw;
701 ppc_opc_table_groupv[768] = ppc_opc_vsububs;
702 ppc_opc_table_groupv[770] = ppc_opc_mfvscr;
703 ppc_opc_table_groupv[772] = ppc_opc_vsum4ubs;
704 ppc_opc_table_groupv[800] = ppc_opc_vsubuhs;
705 ppc_opc_table_groupv[802] = ppc_opc_mtvscr;
706 ppc_opc_table_groupv[804] = ppc_opc_vsum4shs;
707 ppc_opc_table_groupv[832] = ppc_opc_vsubuws;
708 ppc_opc_table_groupv[836] = ppc_opc_vsum2sws;
709 ppc_opc_table_groupv[896] = ppc_opc_vsubsbs;
710 ppc_opc_table_groupv[900] = ppc_opc_vsum4sbs;
711 ppc_opc_table_groupv[928] = ppc_opc_vsubshs;
712 ppc_opc_table_groupv[960] = ppc_opc_vsubsws;
713 ppc_opc_table_groupv[964] = ppc_opc_vsumsws;
714
715 ppc_opc_table_gen_groupv[0] = ppc_opc_gen_vaddubm;
716 ppc_opc_table_gen_groupv[1] = ppc_opc_gen_vmaxub;
717 ppc_opc_table_gen_groupv[2] = ppc_opc_gen_vrlb;
718 ppc_opc_table_gen_groupv[4] = ppc_opc_gen_vmuloub;
719 ppc_opc_table_gen_groupv[5] = ppc_opc_gen_vaddfp;
720 ppc_opc_table_gen_groupv[6] = ppc_opc_gen_vmrghb;
721 ppc_opc_table_gen_groupv[7] = ppc_opc_gen_vpkuhum;
722 ppc_opc_table_gen_groupv[32] = ppc_opc_gen_vadduhm;
723 ppc_opc_table_gen_groupv[33] = ppc_opc_gen_vmaxuh;
724 ppc_opc_table_gen_groupv[34] = ppc_opc_gen_vrlh;
725 ppc_opc_table_gen_groupv[36] = ppc_opc_gen_vmulouh;
726 ppc_opc_table_gen_groupv[37] = ppc_opc_gen_vsubfp;
727 ppc_opc_table_gen_groupv[38] = ppc_opc_gen_vmrghh;
728 ppc_opc_table_gen_groupv[39] = ppc_opc_gen_vpkuwum;
729 ppc_opc_table_gen_groupv[42] = ppc_opc_gen_vpkpx;
730 ppc_opc_table_gen_groupv[64] = ppc_opc_gen_vadduwm;
731 ppc_opc_table_gen_groupv[65] = ppc_opc_gen_vmaxuw;
732 ppc_opc_table_gen_groupv[66] = ppc_opc_gen_vrlw;
733 ppc_opc_table_gen_groupv[70] = ppc_opc_gen_vmrghw;
734 ppc_opc_table_gen_groupv[71] = ppc_opc_gen_vpkuhus;
735 ppc_opc_table_gen_groupv[103] = ppc_opc_gen_vpkuwus;
736 ppc_opc_table_gen_groupv[129] = ppc_opc_gen_vmaxsb;
737 ppc_opc_table_gen_groupv[130] = ppc_opc_gen_vslb;
738 ppc_opc_table_gen_groupv[132] = ppc_opc_gen_vmulosb;
739 ppc_opc_table_gen_groupv[133] = ppc_opc_gen_vrefp;
740 ppc_opc_table_gen_groupv[134] = ppc_opc_gen_vmrglb;
741 ppc_opc_table_gen_groupv[135] = ppc_opc_gen_vpkshus;
742 ppc_opc_table_gen_groupv[161] = ppc_opc_gen_vmaxsh;
743 ppc_opc_table_gen_groupv[162] = ppc_opc_gen_vslh;
744 ppc_opc_table_gen_groupv[164] = ppc_opc_gen_vmulosh;
745 ppc_opc_table_gen_groupv[165] = ppc_opc_gen_vrsqrtefp;
746 ppc_opc_table_gen_groupv[166] = ppc_opc_gen_vmrglh;
747 ppc_opc_table_gen_groupv[167] = ppc_opc_gen_vpkswus;
748 ppc_opc_table_gen_groupv[192] = ppc_opc_gen_vaddcuw;
749 ppc_opc_table_gen_groupv[193] = ppc_opc_gen_vmaxsw;
750 ppc_opc_table_gen_groupv[194] = ppc_opc_gen_vslw;
751 ppc_opc_table_gen_groupv[197] = ppc_opc_gen_vexptefp;
752 ppc_opc_table_gen_groupv[198] = ppc_opc_gen_vmrglw;
753 ppc_opc_table_gen_groupv[199] = ppc_opc_gen_vpkshss;
754 ppc_opc_table_gen_groupv[226] = ppc_opc_gen_vsl;
755 ppc_opc_table_gen_groupv[229] = ppc_opc_gen_vlogefp;
756 ppc_opc_table_gen_groupv[231] = ppc_opc_gen_vpkswss;
757 ppc_opc_table_gen_groupv[256] = ppc_opc_gen_vaddubs;
758 ppc_opc_table_gen_groupv[257] = ppc_opc_gen_vminub;
759 ppc_opc_table_gen_groupv[258] = ppc_opc_gen_vsrb;
760 ppc_opc_table_gen_groupv[260] = ppc_opc_gen_vmuleub;
761 ppc_opc_table_gen_groupv[261] = ppc_opc_gen_vrfin;
762 ppc_opc_table_gen_groupv[262] = ppc_opc_gen_vspltb;
763 ppc_opc_table_gen_groupv[263] = ppc_opc_gen_vupkhsb;
764 ppc_opc_table_gen_groupv[288] = ppc_opc_gen_vadduhs;
765 ppc_opc_table_gen_groupv[289] = ppc_opc_gen_vminuh;
766 ppc_opc_table_gen_groupv[290] = ppc_opc_gen_vsrh;
767 ppc_opc_table_gen_groupv[292] = ppc_opc_gen_vmuleuh;
768 ppc_opc_table_gen_groupv[293] = ppc_opc_gen_vrfiz;
769 ppc_opc_table_gen_groupv[294] = ppc_opc_gen_vsplth;
770 ppc_opc_table_gen_groupv[295] = ppc_opc_gen_vupkhsh;
771 ppc_opc_table_gen_groupv[320] = ppc_opc_gen_vadduws;
772 ppc_opc_table_gen_groupv[321] = ppc_opc_gen_vminuw;
773 ppc_opc_table_gen_groupv[322] = ppc_opc_gen_vsrw;
774 ppc_opc_table_gen_groupv[325] = ppc_opc_gen_vrfip;
775 ppc_opc_table_gen_groupv[326] = ppc_opc_gen_vspltw;
776 ppc_opc_table_gen_groupv[327] = ppc_opc_gen_vupklsb;
777 ppc_opc_table_gen_groupv[354] = ppc_opc_gen_vsr;
778 ppc_opc_table_gen_groupv[357] = ppc_opc_gen_vrfim;
779 ppc_opc_table_gen_groupv[359] = ppc_opc_gen_vupklsh;
780 ppc_opc_table_gen_groupv[384] = ppc_opc_gen_vaddsbs;
781 ppc_opc_table_gen_groupv[385] = ppc_opc_gen_vminsb;
782 ppc_opc_table_gen_groupv[386] = ppc_opc_gen_vsrab;
783 ppc_opc_table_gen_groupv[388] = ppc_opc_gen_vmulesb;
784 ppc_opc_table_gen_groupv[389] = ppc_opc_gen_vcfux;
785 ppc_opc_table_gen_groupv[390] = ppc_opc_gen_vspltisb;
786 ppc_opc_table_gen_groupv[391] = ppc_opc_gen_vpkpx;
787 ppc_opc_table_gen_groupv[416] = ppc_opc_gen_vaddshs;
788 ppc_opc_table_gen_groupv[417] = ppc_opc_gen_vminsh;
789 ppc_opc_table_gen_groupv[418] = ppc_opc_gen_vsrah;
790 ppc_opc_table_gen_groupv[420] = ppc_opc_gen_vmulesh;
791 ppc_opc_table_gen_groupv[421] = ppc_opc_gen_vcfsx;
792 ppc_opc_table_gen_groupv[422] = ppc_opc_gen_vspltish;
793 ppc_opc_table_gen_groupv[423] = ppc_opc_gen_vupkhpx;
794 ppc_opc_table_gen_groupv[448] = ppc_opc_gen_vaddsws;
795 ppc_opc_table_gen_groupv[449] = ppc_opc_gen_vminsw;
796 ppc_opc_table_gen_groupv[450] = ppc_opc_gen_vsraw;
797 ppc_opc_table_gen_groupv[453] = ppc_opc_gen_vctuxs;
798 ppc_opc_table_gen_groupv[454] = ppc_opc_gen_vspltisw;
799 ppc_opc_table_gen_groupv[485] = ppc_opc_gen_vctsxs;
800 ppc_opc_table_gen_groupv[487] = ppc_opc_gen_vupklpx;
801 ppc_opc_table_gen_groupv[512] = ppc_opc_gen_vsububm;
802 ppc_opc_table_gen_groupv[513] = ppc_opc_gen_vavgub;
803 ppc_opc_table_gen_groupv[514] = ppc_opc_gen_vand;
804 ppc_opc_table_gen_groupv[517] = ppc_opc_gen_vmaxfp;
805 ppc_opc_table_gen_groupv[518] = ppc_opc_gen_vslo;
806 ppc_opc_table_gen_groupv[544] = ppc_opc_gen_vsubuhm;
807 ppc_opc_table_gen_groupv[545] = ppc_opc_gen_vavguh;
808 ppc_opc_table_gen_groupv[546] = ppc_opc_gen_vandc;
809 ppc_opc_table_gen_groupv[549] = ppc_opc_gen_vminfp;
810 ppc_opc_table_gen_groupv[550] = ppc_opc_gen_vsro;
811 ppc_opc_table_gen_groupv[576] = ppc_opc_gen_vsubuwm;
812 ppc_opc_table_gen_groupv[577] = ppc_opc_gen_vavguw;
813 ppc_opc_table_gen_groupv[578] = ppc_opc_gen_vor;
814 ppc_opc_table_gen_groupv[610] = ppc_opc_gen_vxor;
815 ppc_opc_table_gen_groupv[641] = ppc_opc_gen_vavgsb;
816 ppc_opc_table_gen_groupv[642] = ppc_opc_gen_vnor;
817 ppc_opc_table_gen_groupv[673] = ppc_opc_gen_vavgsh;
818 ppc_opc_table_gen_groupv[704] = ppc_opc_gen_vsubcuw;
819 ppc_opc_table_gen_groupv[705] = ppc_opc_gen_vavgsw;
820 ppc_opc_table_gen_groupv[768] = ppc_opc_gen_vsububs;
821 ppc_opc_table_gen_groupv[770] = ppc_opc_gen_mfvscr;
822 ppc_opc_table_gen_groupv[772] = ppc_opc_gen_vsum4ubs;
823 ppc_opc_table_gen_groupv[800] = ppc_opc_gen_vsubuhs;
824 ppc_opc_table_gen_groupv[802] = ppc_opc_gen_mtvscr;
825 ppc_opc_table_gen_groupv[804] = ppc_opc_gen_vsum4shs;
826 ppc_opc_table_gen_groupv[832] = ppc_opc_gen_vsubuws;
827 ppc_opc_table_gen_groupv[836] = ppc_opc_gen_vsum2sws;
828 ppc_opc_table_gen_groupv[896] = ppc_opc_gen_vsubsbs;
829 ppc_opc_table_gen_groupv[900] = ppc_opc_gen_vsum4sbs;
830 ppc_opc_table_gen_groupv[928] = ppc_opc_gen_vsubshs;
831 ppc_opc_table_gen_groupv[960] = ppc_opc_gen_vsubsws;
832 ppc_opc_table_gen_groupv[964] = ppc_opc_gen_vsumsws;
833
834 /* Put any MMX/SSE/SSE2 optimizations here under conditional
835 * of a CPU caps.
836 */
837 }
838
839 // main opcode 04
840 static void ppc_opc_group_v()
841 {
842 uint32 ext = PPC_OPC_EXT(gCPU.current_opc);
843 #ifndef __VEC_EXC_OFF__
844 if ((gCPU.msr & MSR_VEC) == 0) {
845 ppc_exception(PPC_EXC_NO_VEC);
846 return;
847 }
848 #endif
849 switch(ext & 0x1f) {
850 case 16:
851 if (gCPU.current_opc & PPC_OPC_Rc)
852 return ppc_opc_vmhraddshs();
853 else
854 return ppc_opc_vmhaddshs();
855 case 17: return ppc_opc_vmladduhm();
856 case 18:
857 if (gCPU.current_opc & PPC_OPC_Rc)
858 return ppc_opc_vmsummbm();
859 else
860 return ppc_opc_vmsumubm();
861 case 19:
862 if (gCPU.current_opc & PPC_OPC_Rc)
863 return ppc_opc_vmsumuhs();
864 else
865 return ppc_opc_vmsumuhm();
866 case 20:
867 if (gCPU.current_opc & PPC_OPC_Rc)
868 return ppc_opc_vmsumshs();
869 else
870 return ppc_opc_vmsumshm();
871 case 21:
872 if (gCPU.current_opc & PPC_OPC_Rc)
873 return ppc_opc_vperm();
874 else
875 return ppc_opc_vsel();
876 case 22: return ppc_opc_vsldoi();
877 case 23:
878 if (gCPU.current_opc & PPC_OPC_Rc)
879 return ppc_opc_vnmsubfp();
880 else
881 return ppc_opc_vmaddfp();
882 }
883 switch(ext & 0x1ff)
884 {
885 case 3: return ppc_opc_vcmpequbx();
886 case 35: return ppc_opc_vcmpequhx();
887 case 67: return ppc_opc_vcmpequwx();
888 case 99: return ppc_opc_vcmpeqfpx();
889 case 227: return ppc_opc_vcmpgefpx();
890 case 259: return ppc_opc_vcmpgtubx();
891 case 291: return ppc_opc_vcmpgtuhx();
892 case 323: return ppc_opc_vcmpgtuwx();
893 case 355: return ppc_opc_vcmpgtfpx();
894 case 387: return ppc_opc_vcmpgtsbx();
895 case 419: return ppc_opc_vcmpgtshx();
896 case 451: return ppc_opc_vcmpgtswx();
897 case 483: return ppc_opc_vcmpbfpx();
898 }
899
900 if (ext >= (sizeof ppc_opc_table_groupv / sizeof ppc_opc_table_groupv[0])) {
901 return ppc_opc_invalid();
902 }
903 return ppc_opc_table_groupv[ext]();
904 }
905
906 // main opcode 04
907 static JITCFlow ppc_opc_gen_group_v()
908 {
909 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
910 int vrS = (gJITC.current_opc >> 21) & 0x1f;
911
912 ppc_opc_gen_check_vec();
913
914 if (vrS == gJITC.nativeVectorReg) {
915 gJITC.nativeVectorReg = VECTREG_NO;
916 }
917
918 switch(ext & 0x1f) {
919 case 16:
920 if (gJITC.current_opc & PPC_OPC_Rc)
921 return ppc_opc_gen_vmhraddshs();
922 else
923 return ppc_opc_gen_vmhaddshs();
924 case 17: return ppc_opc_gen_vmladduhm();
925 case 18:
926 if (gJITC.current_opc & PPC_OPC_Rc)
927 return ppc_opc_gen_vmsummbm();
928 else
929 return ppc_opc_gen_vmsumubm();
930 case 19:
931 if (gJITC.current_opc & PPC_OPC_Rc)
932 return ppc_opc_gen_vmsumuhs();
933 else
934 return ppc_opc_gen_vmsumuhm();
935 case 20:
936 if (gJITC.current_opc & PPC_OPC_Rc)
937 return ppc_opc_gen_vmsumshs();
938 else
939 return ppc_opc_gen_vmsumshm();
940 case 21:
941 if (gJITC.current_opc & PPC_OPC_Rc)
942 return ppc_opc_gen_vperm();
943 else
944 return ppc_opc_gen_vsel();
945 case 22: return ppc_opc_gen_vsldoi();
946 case 23:
947 if (gJITC.current_opc & PPC_OPC_Rc)
948 return ppc_opc_gen_vnmsubfp();
949 else
950 return ppc_opc_gen_vmaddfp();
951 }
952 switch(ext & 0x1ff)
953 {
954 case 3: return ppc_opc_gen_vcmpequbx();
955 case 35: return ppc_opc_gen_vcmpequhx();
956 case 67: return ppc_opc_gen_vcmpequwx();
957 case 99: return ppc_opc_gen_vcmpeqfpx();
958 case 227: return ppc_opc_gen_vcmpgefpx();
959 case 259: return ppc_opc_gen_vcmpgtubx();
960 case 291: return ppc_opc_gen_vcmpgtuhx();
961 case 323: return ppc_opc_gen_vcmpgtuwx();
962 case 355: return ppc_opc_gen_vcmpgtfpx();
963 case 387: return ppc_opc_gen_vcmpgtsbx();
964 case 419: return ppc_opc_gen_vcmpgtshx();
965 case 451: return ppc_opc_gen_vcmpgtswx();
966 case 483: return ppc_opc_gen_vcmpbfpx();
967 }
968
969 if (ext >= (sizeof ppc_opc_table_gen_groupv / sizeof ppc_opc_table_gen_groupv[0])) {
970 return ppc_opc_gen_invalid();
971 }
972 return ppc_opc_table_gen_groupv[ext]();
973 }
974
975
976 static ppc_opc_function ppc_opc_table_main[64] = {
977 &ppc_opc_special, // 0
978 &ppc_opc_invalid, // 1
979 &ppc_opc_invalid, // 2 (tdi on 64 bit platforms)
980 &ppc_opc_twi, // 3
981 &ppc_opc_invalid, // 4 (altivec)
982 &ppc_opc_invalid, // 5
983 &ppc_opc_invalid, // 6
984 &ppc_opc_mulli, // 7
985 &ppc_opc_subfic, // 8
986 &ppc_opc_invalid, // 9
987 &ppc_opc_cmpli, // 10
988 &ppc_opc_cmpi, // 11
989 &ppc_opc_addic, // 12
990 &ppc_opc_addic_, // 13
991 &ppc_opc_addi, // 14
992 &ppc_opc_addis, // 15
993 &ppc_opc_bcx, // 16
994 &ppc_opc_sc, // 17
995 &ppc_opc_bx, // 18
996 &ppc_opc_group_1, // 19
997 &ppc_opc_rlwimix, // 20
998 &ppc_opc_rlwinmx, // 21
999 &ppc_opc_invalid, // 22
1000 &ppc_opc_rlwnmx, // 23
1001 &ppc_opc_ori, // 24
1002 &ppc_opc_oris, // 25
1003 &ppc_opc_xori, // 26
1004 &ppc_opc_xoris, // 27
1005 &ppc_opc_andi_, // 28
1006 &ppc_opc_andis_, // 29
1007 &ppc_opc_invalid, // 30 (group_rld on 64 bit platforms)
1008 &ppc_opc_group_2, // 31
1009 &ppc_opc_lwz, // 32
1010 &ppc_opc_lwzu, // 33
1011 &ppc_opc_lbz, // 34
1012 &ppc_opc_lbzu, // 35
1013 &ppc_opc_stw, // 36
1014 &ppc_opc_stwu, // 37
1015 &ppc_opc_stb, // 38
1016 &ppc_opc_stbu, // 39
1017 &ppc_opc_lhz, // 40
1018 &ppc_opc_lhzu, // 41
1019 &ppc_opc_lha, // 42
1020 &ppc_opc_lhau, // 43
1021 &ppc_opc_sth, // 44
1022 &ppc_opc_sthu, // 45
1023 &ppc_opc_lmw, // 46
1024 &ppc_opc_stmw, // 47
1025 &ppc_opc_lfs, // 48
1026 &ppc_opc_lfsu, // 49
1027 &ppc_opc_lfd, // 50
1028 &ppc_opc_lfdu, // 51
1029 &ppc_opc_stfs, // 52
1030 &ppc_opc_stfsu, // 53
1031 &ppc_opc_stfd, // 54
1032 &ppc_opc_stfdu, // 55
1033 &ppc_opc_invalid, // 56
1034 &ppc_opc_invalid, // 57
1035 &ppc_opc_invalid, // 58 (ld on 64 bit platforms)
1036 &ppc_opc_group_f1, // 59
1037 &ppc_opc_invalid, // 60
1038 &ppc_opc_invalid, // 61
1039 &ppc_opc_invalid, // 62
1040 &ppc_opc_group_f2, // 63
1041 };
1042 static ppc_opc_gen_function ppc_opc_table_gen_main[64] = {
1043 &ppc_opc_gen_special, // 0
1044 &ppc_opc_gen_invalid, // 1
1045 &ppc_opc_gen_invalid, // 2 (tdi on 64 bit platforms)
1046 &ppc_opc_gen_twi, // 3
1047 &ppc_opc_gen_invalid, // 4 (altivec)
1048 &ppc_opc_gen_invalid, // 5
1049 &ppc_opc_gen_invalid, // 6
1050 &ppc_opc_gen_mulli, // 7
1051 &ppc_opc_gen_subfic, // 8
1052 &ppc_opc_gen_invalid, // 9
1053 &ppc_opc_gen_cmpli, // 10
1054 &ppc_opc_gen_cmpi, // 11
1055 &ppc_opc_gen_addic, // 12
1056 &ppc_opc_gen_addic_, // 13
1057 &ppc_opc_gen_addi, // 14
1058 &ppc_opc_gen_addis, // 15
1059 &ppc_opc_gen_bcx, // 16
1060 &ppc_opc_gen_sc, // 17
1061 &ppc_opc_gen_bx, // 18
1062 &ppc_opc_gen_group_1, // 19
1063 &ppc_opc_gen_rlwimix, // 20
1064 &ppc_opc_gen_rlwinmx, // 21
1065 &ppc_opc_gen_invalid, // 22
1066 &ppc_opc_gen_rlwnmx, // 23
1067 &ppc_opc_gen_ori, // 24
1068 &ppc_opc_gen_oris, // 25
1069 &ppc_opc_gen_xori, // 26
1070 &ppc_opc_gen_xoris, // 27
1071 &ppc_opc_gen_andi_, // 28
1072 &ppc_opc_gen_andis_, // 29
1073 &ppc_opc_gen_invalid, // 30 (group_rld on 64 bit platforms)
1074 &ppc_opc_gen_group_2, // 31
1075 &ppc_opc_gen_lwz, // 32
1076 &ppc_opc_gen_lwzu, // 33
1077 &ppc_opc_gen_lbz, // 34
1078 &ppc_opc_gen_lbzu, // 35
1079 &ppc_opc_gen_stw, // 36
1080 &ppc_opc_gen_stwu, // 37
1081 &ppc_opc_gen_stb, // 38
1082 &ppc_opc_gen_stbu, // 39
1083 &ppc_opc_gen_lhz, // 40
1084 &ppc_opc_gen_lhzu, // 41
1085 &ppc_opc_gen_lha, // 42
1086 &ppc_opc_gen_lhau, // 43
1087 &ppc_opc_gen_sth, // 44
1088 &ppc_opc_gen_sthu, // 45
1089 &ppc_opc_gen_lmw, // 46
1090 &ppc_opc_gen_stmw, // 47
1091 &ppc_opc_gen_lfs, // 48
1092 &ppc_opc_gen_lfsu, // 49
1093 &ppc_opc_gen_lfd, // 50
1094 &ppc_opc_gen_lfdu, // 51
1095 &ppc_opc_gen_stfs, // 52
1096 &ppc_opc_gen_stfsu, // 53
1097 &ppc_opc_gen_stfd, // 54
1098 &ppc_opc_gen_stfdu, // 55
1099 &ppc_opc_gen_invalid, // 56
1100 &ppc_opc_gen_invalid, // 57
1101 &ppc_opc_gen_invalid, // 58 (ld on 64 bit platforms)
1102 &ppc_opc_gen_group_f1, // 59
1103 &ppc_opc_gen_invalid, // 60
1104 &ppc_opc_gen_invalid, // 61
1105 &ppc_opc_gen_invalid, // 62
1106 &ppc_opc_gen_group_f2, // 63
1107 };
1108
1109 void FASTCALL ppc_exec_opc()
1110 {
1111 uint32 mainopc = PPC_OPC_MAIN(gCPU.current_opc);
1112 ppc_opc_table_main[mainopc]();
1113 }
1114
1115 static uint32 last_instr = 0, instr_report = 0, instr_count = 0;
1116
1117 JITCFlow FASTCALL ppc_gen_opc()
1118 {
1119 uint32 mainopc = PPC_OPC_MAIN(gJITC.current_opc);
1120
1121 /*if (instr_report) {
1122 uint32 ext = PPC_OPC_EXT(gJITC.current_opc);
1123 uint32 rD, rA, rB, rC;
1124 PPC_OPC_TEMPL_A(gJITC.current_opc, rD, rA, rB, rC);
1125
1126 printf("*** (%08x) %08x (%i, %i) (%i, %i, %i, %i)\n", instr_count++, gJITC.current_opc, mainopc, ext, rD, rA, rB, rC);
1127 } else {
1128 if (last_instr == 0x7c00004c && gJITC.current_opc == 0x10e0038c) {
1129 instr_report = 1;
1130 }
1131
1132 last_instr = gJITC.current_opc;
1133 }*/
1134
1135 return ppc_opc_table_gen_main[mainopc]();
1136 }
1137
1138 void ppc_dec_init()
1139 {
1140 ppc_opc_init_group2();
1141 if ((ppc_cpu_get_pvr(0) & 0xffff0000) == 0x000c0000) {
1142 ht_printf("[PPC/VEC] Vector Address: %08x\n", (uint32)&gCPU.vr[0]);
1143 ppc_opc_table_main[4] = ppc_opc_group_v;
1144 ppc_opc_table_gen_main[4] = ppc_opc_gen_group_v;
1145 ppc_opc_init_groupv();
1146 }
1147 }

  ViewVC Help
Powered by ViewVC 1.1.26