ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/cebix/BasiliskII/src/uae_cpu/gencpu.c
Revision: 1.2
Committed: 1999-10-21T13:19:27Z (24 years, 8 months ago) by cebix
Content type: text/plain
Branch: MAIN
Changes since 1.1: +155 -2 lines
Log Message:
- added fbdev video code and SPARC assembly optimizations

File Contents

# Content
1 /*
2 * UAE - The Un*x Amiga Emulator
3 *
4 * MC68000 emulation generator
5 *
6 * This is a fairly stupid program that generates a lot of case labels that
7 * can be #included in a switch statement.
8 * As an alternative, it can generate functions that handle specific
9 * MC68000 instructions, plus a prototype header file and a function pointer
10 * array to look up the function for an opcode.
11 * Error checking is bad, an illegal table68k file will cause the program to
12 * call abort().
13 * The generated code is sometimes sub-optimal, an optimizing compiler should
14 * take care of this.
15 *
16 * Copyright 1995, 1996 Bernd Schmidt
17 */
18
19 #include <ctype.h>
20 #include <stdio.h>
21 #include <stdlib.h>
22 #include <string.h>
23
24 #include "sysdeps.h"
25 #include "readcpu.h"
26
27 #if defined(SPARC_V8_ASSEMBLY) || defined(SPARC_V9_ASSEMBLY)
28 #define SPARC_ASSEMBLY 0
29 #endif
30
31 #define BOOL_TYPE "int"
32
33 static FILE *headerfile;
34 static FILE *stblfile;
35
36 static int using_prefetch;
37 static int using_exception_3;
38 static int cpu_level;
39
40 /* For the current opcode, the next lower level that will have different code.
41 * Initialized to -1 for each opcode. If it remains unchanged, indicates we
42 * are done with that opcode. */
43 static int next_cpu_level;
44
45 static int *opcode_map;
46 static int *opcode_next_clev;
47 static int *opcode_last_postfix;
48 static unsigned long *counts;
49
50 static void read_counts (void)
51 {
52 FILE *file;
53 unsigned long opcode, count, total;
54 char name[20];
55 int nr = 0;
56 memset (counts, 0, 65536 * sizeof *counts);
57
58 file = fopen ("frequent.68k", "r");
59 if (file) {
60 fscanf (file, "Total: %lu\n", &total);
61 while (fscanf (file, "%lx: %lu %s\n", &opcode, &count, name) == 3) {
62 opcode_next_clev[nr] = 3;
63 opcode_last_postfix[nr] = -1;
64 opcode_map[nr++] = opcode;
65 counts[opcode] = count;
66 }
67 fclose (file);
68 }
69 if (nr == nr_cpuop_funcs)
70 return;
71 for (opcode = 0; opcode < 0x10000; opcode++) {
72 if (table68k[opcode].handler == -1 && table68k[opcode].mnemo != i_ILLG
73 && counts[opcode] == 0)
74 {
75 opcode_next_clev[nr] = 3;
76 opcode_last_postfix[nr] = -1;
77 opcode_map[nr++] = opcode;
78 counts[opcode] = count;
79 }
80 }
81 if (nr != nr_cpuop_funcs)
82 abort ();
83 }
84
85 static char endlabelstr[80];
86 static int endlabelno = 0;
87 static int need_endlabel;
88
89 static int n_braces = 0;
90 static int m68k_pc_offset = 0;
91 static int insn_n_cycles;
92
93 static void start_brace (void)
94 {
95 n_braces++;
96 printf ("{");
97 }
98
99 static void close_brace (void)
100 {
101 assert (n_braces > 0);
102 n_braces--;
103 printf ("}");
104 }
105
106 static void finish_braces (void)
107 {
108 while (n_braces > 0)
109 close_brace ();
110 }
111
112 static void pop_braces (int to)
113 {
114 while (n_braces > to)
115 close_brace ();
116 }
117
118 static int bit_size (int size)
119 {
120 switch (size) {
121 case sz_byte: return 8;
122 case sz_word: return 16;
123 case sz_long: return 32;
124 default: abort ();
125 }
126 return 0;
127 }
128
129 static const char *bit_mask (int size)
130 {
131 switch (size) {
132 case sz_byte: return "0xff";
133 case sz_word: return "0xffff";
134 case sz_long: return "0xffffffff";
135 default: abort ();
136 }
137 return 0;
138 }
139
140 static const char *gen_nextilong (void)
141 {
142 static char buffer[80];
143 int r = m68k_pc_offset;
144 m68k_pc_offset += 4;
145
146 insn_n_cycles += 4;
147
148 if (using_prefetch)
149 sprintf (buffer, "get_ilong_prefetch(%d)", r);
150 else
151 sprintf (buffer, "get_ilong(%d)", r);
152 return buffer;
153 }
154
155 static const char *gen_nextiword (void)
156 {
157 static char buffer[80];
158 int r = m68k_pc_offset;
159 m68k_pc_offset += 2;
160
161 insn_n_cycles += 2;
162
163 if (using_prefetch)
164 sprintf (buffer, "get_iword_prefetch(%d)", r);
165 else
166 sprintf (buffer, "get_iword(%d)", r);
167 return buffer;
168 }
169
170 static const char *gen_nextibyte (void)
171 {
172 static char buffer[80];
173 int r = m68k_pc_offset;
174 m68k_pc_offset += 2;
175
176 insn_n_cycles += 2;
177
178 if (using_prefetch)
179 sprintf (buffer, "get_ibyte_prefetch(%d)", r);
180 else
181 sprintf (buffer, "get_ibyte(%d)", r);
182 return buffer;
183 }
184
185 static void fill_prefetch_0 (void)
186 {
187 if (using_prefetch)
188 printf ("fill_prefetch_0 ();\n");
189 }
190
191 static void fill_prefetch_2 (void)
192 {
193 if (using_prefetch)
194 printf ("fill_prefetch_2 ();\n");
195 }
196
197 static void swap_opcode (void)
198 {
199 printf ("#ifdef HAVE_GET_WORD_UNSWAPPED\n");
200 printf ("\topcode = ((opcode << 8) & 0xFF00) | ((opcode >> 8) & 0xFF);\n");
201 printf ("#endif\n");
202 }
203
204 static void sync_m68k_pc (void)
205 {
206 if (m68k_pc_offset == 0)
207 return;
208 printf ("m68k_incpc(%d);\n", m68k_pc_offset);
209 switch (m68k_pc_offset) {
210 case 0:
211 /*fprintf (stderr, "refilling prefetch at 0\n"); */
212 break;
213 case 2:
214 fill_prefetch_2 ();
215 break;
216 default:
217 fill_prefetch_0 ();
218 break;
219 }
220 m68k_pc_offset = 0;
221 }
222
223 /* getv == 1: fetch data; getv != 0: check for odd address. If movem != 0,
224 * the calling routine handles Apdi and Aipi modes. */
225 static void genamode (amodes mode, char *reg, wordsizes size, char *name, int getv, int movem)
226 {
227 start_brace ();
228 switch (mode) {
229 case Dreg:
230 if (movem)
231 abort ();
232 if (getv == 1)
233 switch (size) {
234 case sz_byte:
235 #ifdef AMIGA
236 /* sam: I don't know why gcc.2.7.2.1 produces a code worse */
237 /* if it is not done like that: */
238 printf ("\tuae_s8 %s = ((uae_u8*)&m68k_dreg(regs, %s))[3];\n", name, reg);
239 #else
240 printf ("\tuae_s8 %s = m68k_dreg(regs, %s);\n", name, reg);
241 #endif
242 break;
243 case sz_word:
244 #ifdef AMIGA
245 printf ("\tuae_s16 %s = ((uae_s16*)&m68k_dreg(regs, %s))[1];\n", name, reg);
246 #else
247 printf ("\tuae_s16 %s = m68k_dreg(regs, %s);\n", name, reg);
248 #endif
249 break;
250 case sz_long:
251 printf ("\tuae_s32 %s = m68k_dreg(regs, %s);\n", name, reg);
252 break;
253 default:
254 abort ();
255 }
256 return;
257 case Areg:
258 if (movem)
259 abort ();
260 if (getv == 1)
261 switch (size) {
262 case sz_word:
263 printf ("\tuae_s16 %s = m68k_areg(regs, %s);\n", name, reg);
264 break;
265 case sz_long:
266 printf ("\tuae_s32 %s = m68k_areg(regs, %s);\n", name, reg);
267 break;
268 default:
269 abort ();
270 }
271 return;
272 case Aind:
273 printf ("\tuaecptr %sa = m68k_areg(regs, %s);\n", name, reg);
274 break;
275 case Aipi:
276 printf ("\tuaecptr %sa = m68k_areg(regs, %s);\n", name, reg);
277 break;
278 case Apdi:
279 switch (size) {
280 case sz_byte:
281 if (movem)
282 printf ("\tuaecptr %sa = m68k_areg(regs, %s);\n", name, reg);
283 else
284 printf ("\tuaecptr %sa = m68k_areg(regs, %s) - areg_byteinc[%s];\n", name, reg, reg);
285 break;
286 case sz_word:
287 printf ("\tuaecptr %sa = m68k_areg(regs, %s) - %d;\n", name, reg, movem ? 0 : 2);
288 break;
289 case sz_long:
290 printf ("\tuaecptr %sa = m68k_areg(regs, %s) - %d;\n", name, reg, movem ? 0 : 4);
291 break;
292 default:
293 abort ();
294 }
295 break;
296 case Ad16:
297 printf ("\tuaecptr %sa = m68k_areg(regs, %s) + (uae_s32)(uae_s16)%s;\n", name, reg, gen_nextiword ());
298 break;
299 case Ad8r:
300 if (cpu_level > 1) {
301 if (next_cpu_level < 1)
302 next_cpu_level = 1;
303 sync_m68k_pc ();
304 start_brace ();
305 printf ("\tuaecptr %sa = get_disp_ea_020(m68k_areg(regs, %s), next_iword());\n", name, reg);
306 } else
307 printf ("\tuaecptr %sa = get_disp_ea_000(m68k_areg(regs, %s), %s);\n", name, reg, gen_nextiword ());
308
309 break;
310 case PC16:
311 printf ("\tuaecptr %sa = m68k_getpc () + %d;\n", name, m68k_pc_offset);
312 printf ("\t%sa += (uae_s32)(uae_s16)%s;\n", name, gen_nextiword ());
313 break;
314 case PC8r:
315 if (cpu_level > 1) {
316 if (next_cpu_level < 1)
317 next_cpu_level = 1;
318 sync_m68k_pc ();
319 start_brace ();
320 printf ("\tuaecptr tmppc = m68k_getpc();\n");
321 printf ("\tuaecptr %sa = get_disp_ea_020(tmppc, next_iword());\n", name);
322 } else {
323 printf ("\tuaecptr tmppc = m68k_getpc() + %d;\n", m68k_pc_offset);
324 printf ("\tuaecptr %sa = get_disp_ea_000(tmppc, %s);\n", name, gen_nextiword ());
325 }
326
327 break;
328 case absw:
329 printf ("\tuaecptr %sa = (uae_s32)(uae_s16)%s;\n", name, gen_nextiword ());
330 break;
331 case absl:
332 printf ("\tuaecptr %sa = %s;\n", name, gen_nextilong ());
333 break;
334 case imm:
335 if (getv != 1)
336 abort ();
337 switch (size) {
338 case sz_byte:
339 printf ("\tuae_s8 %s = %s;\n", name, gen_nextibyte ());
340 break;
341 case sz_word:
342 printf ("\tuae_s16 %s = %s;\n", name, gen_nextiword ());
343 break;
344 case sz_long:
345 printf ("\tuae_s32 %s = %s;\n", name, gen_nextilong ());
346 break;
347 default:
348 abort ();
349 }
350 return;
351 case imm0:
352 if (getv != 1)
353 abort ();
354 printf ("\tuae_s8 %s = %s;\n", name, gen_nextibyte ());
355 return;
356 case imm1:
357 if (getv != 1)
358 abort ();
359 printf ("\tuae_s16 %s = %s;\n", name, gen_nextiword ());
360 return;
361 case imm2:
362 if (getv != 1)
363 abort ();
364 printf ("\tuae_s32 %s = %s;\n", name, gen_nextilong ());
365 return;
366 case immi:
367 if (getv != 1)
368 abort ();
369 printf ("\tuae_u32 %s = %s;\n", name, reg);
370 return;
371 default:
372 abort ();
373 }
374
375 /* We get here for all non-reg non-immediate addressing modes to
376 * actually fetch the value. */
377
378 if (using_exception_3 && getv != 0 && size != sz_byte) {
379 printf ("\tif ((%sa & 1) != 0) {\n", name);
380 printf ("\t\tlast_fault_for_exception_3 = %sa;\n", name);
381 printf ("\t\tlast_op_for_exception_3 = opcode;\n");
382 printf ("\t\tlast_addr_for_exception_3 = m68k_getpc() + %d;\n", m68k_pc_offset);
383 printf ("\t\tException(3, 0);\n");
384 printf ("\t\tgoto %s;\n", endlabelstr);
385 printf ("\t}\n");
386 need_endlabel = 1;
387 start_brace ();
388 }
389
390 if (getv == 1) {
391 switch (size) {
392 case sz_byte: insn_n_cycles += 2; break;
393 case sz_word: insn_n_cycles += 2; break;
394 case sz_long: insn_n_cycles += 4; break;
395 default: abort ();
396 }
397 start_brace ();
398 switch (size) {
399 case sz_byte: printf ("\tuae_s8 %s = get_byte(%sa);\n", name, name); break;
400 case sz_word: printf ("\tuae_s16 %s = get_word(%sa);\n", name, name); break;
401 case sz_long: printf ("\tuae_s32 %s = get_long(%sa);\n", name, name); break;
402 default: abort ();
403 }
404 }
405
406 /* We now might have to fix up the register for pre-dec or post-inc
407 * addressing modes. */
408 if (!movem)
409 switch (mode) {
410 case Aipi:
411 switch (size) {
412 case sz_byte:
413 printf ("\tm68k_areg(regs, %s) += areg_byteinc[%s];\n", reg, reg);
414 break;
415 case sz_word:
416 printf ("\tm68k_areg(regs, %s) += 2;\n", reg);
417 break;
418 case sz_long:
419 printf ("\tm68k_areg(regs, %s) += 4;\n", reg);
420 break;
421 default:
422 abort ();
423 }
424 break;
425 case Apdi:
426 printf ("\tm68k_areg (regs, %s) = %sa;\n", reg, name);
427 break;
428 default:
429 break;
430 }
431 }
432
433 static void genastore (char *from, amodes mode, char *reg, wordsizes size, char *to)
434 {
435 switch (mode) {
436 case Dreg:
437 switch (size) {
438 case sz_byte:
439 printf ("\tm68k_dreg(regs, %s) = (m68k_dreg(regs, %s) & ~0xff) | ((%s) & 0xff);\n", reg, reg, from);
440 break;
441 case sz_word:
442 printf ("\tm68k_dreg(regs, %s) = (m68k_dreg(regs, %s) & ~0xffff) | ((%s) & 0xffff);\n", reg, reg, from);
443 break;
444 case sz_long:
445 printf ("\tm68k_dreg(regs, %s) = (%s);\n", reg, from);
446 break;
447 default:
448 abort ();
449 }
450 break;
451 case Areg:
452 switch (size) {
453 case sz_word:
454 fprintf (stderr, "Foo\n");
455 printf ("\tm68k_areg(regs, %s) = (uae_s32)(uae_s16)(%s);\n", reg, from);
456 break;
457 case sz_long:
458 printf ("\tm68k_areg(regs, %s) = (%s);\n", reg, from);
459 break;
460 default:
461 abort ();
462 }
463 break;
464 case Aind:
465 case Aipi:
466 case Apdi:
467 case Ad16:
468 case Ad8r:
469 case absw:
470 case absl:
471 case PC16:
472 case PC8r:
473 if (using_prefetch)
474 sync_m68k_pc ();
475 switch (size) {
476 case sz_byte:
477 insn_n_cycles += 2;
478 printf ("\tput_byte(%sa,%s);\n", to, from);
479 break;
480 case sz_word:
481 insn_n_cycles += 2;
482 if (cpu_level < 2 && (mode == PC16 || mode == PC8r))
483 abort ();
484 printf ("\tput_word(%sa,%s);\n", to, from);
485 break;
486 case sz_long:
487 insn_n_cycles += 4;
488 if (cpu_level < 2 && (mode == PC16 || mode == PC8r))
489 abort ();
490 printf ("\tput_long(%sa,%s);\n", to, from);
491 break;
492 default:
493 abort ();
494 }
495 break;
496 case imm:
497 case imm0:
498 case imm1:
499 case imm2:
500 case immi:
501 abort ();
502 break;
503 default:
504 abort ();
505 }
506 }
507
508 static void genmovemel (uae_u16 opcode)
509 {
510 char getcode[100];
511 int size = table68k[opcode].size == sz_long ? 4 : 2;
512
513 if (table68k[opcode].size == sz_long) {
514 strcpy (getcode, "get_long(srca)");
515 } else {
516 strcpy (getcode, "(uae_s32)(uae_s16)get_word(srca)");
517 }
518
519 printf ("\tuae_u16 mask = %s;\n", gen_nextiword ());
520 printf ("\tunsigned int dmask = mask & 0xff, amask = (mask >> 8) & 0xff;\n");
521 genamode (table68k[opcode].dmode, "dstreg", table68k[opcode].size, "src", 2, 1);
522 start_brace ();
523 printf ("\twhile (dmask) { m68k_dreg(regs, movem_index1[dmask]) = %s; srca += %d; dmask = movem_next[dmask]; }\n",
524 getcode, size);
525 printf ("\twhile (amask) { m68k_areg(regs, movem_index1[amask]) = %s; srca += %d; amask = movem_next[amask]; }\n",
526 getcode, size);
527
528 if (table68k[opcode].dmode == Aipi)
529 printf ("\tm68k_areg(regs, dstreg) = srca;\n");
530 }
531
532 static void genmovemle (uae_u16 opcode)
533 {
534 char putcode[100];
535 int size = table68k[opcode].size == sz_long ? 4 : 2;
536 if (table68k[opcode].size == sz_long) {
537 strcpy (putcode, "put_long(srca,");
538 } else {
539 strcpy (putcode, "put_word(srca,");
540 }
541
542 printf ("\tuae_u16 mask = %s;\n", gen_nextiword ());
543 genamode (table68k[opcode].dmode, "dstreg", table68k[opcode].size, "src", 2, 1);
544 if (using_prefetch)
545 sync_m68k_pc ();
546
547 start_brace ();
548 if (table68k[opcode].dmode == Apdi) {
549 printf ("\tuae_u16 amask = mask & 0xff, dmask = (mask >> 8) & 0xff;\n");
550 printf ("\twhile (amask) { srca -= %d; %s m68k_areg(regs, movem_index2[amask])); amask = movem_next[amask]; }\n",
551 size, putcode);
552 printf ("\twhile (dmask) { srca -= %d; %s m68k_dreg(regs, movem_index2[dmask])); dmask = movem_next[dmask]; }\n",
553 size, putcode);
554 printf ("\tm68k_areg(regs, dstreg) = srca;\n");
555 } else {
556 printf ("\tuae_u16 dmask = mask & 0xff, amask = (mask >> 8) & 0xff;\n");
557 printf ("\twhile (dmask) { %s m68k_dreg(regs, movem_index1[dmask])); srca += %d; dmask = movem_next[dmask]; }\n",
558 putcode, size);
559 printf ("\twhile (amask) { %s m68k_areg(regs, movem_index1[amask])); srca += %d; amask = movem_next[amask]; }\n",
560 putcode, size);
561 }
562 }
563
564 static void duplicate_carry (void)
565 {
566 printf ("\tCOPY_CARRY;\n");
567 }
568
569 typedef enum {
570 flag_logical_noclobber, flag_logical, flag_add, flag_sub, flag_cmp, flag_addx, flag_subx, flag_zn,
571 flag_av, flag_sv
572 } flagtypes;
573
574 static void genflags_normal (flagtypes type, wordsizes size, char *value, char *src, char *dst)
575 {
576 char vstr[100], sstr[100], dstr[100];
577 char usstr[100], udstr[100];
578 char unsstr[100], undstr[100];
579
580 switch (size) {
581 case sz_byte:
582 strcpy (vstr, "((uae_s8)(");
583 strcpy (usstr, "((uae_u8)(");
584 break;
585 case sz_word:
586 strcpy (vstr, "((uae_s16)(");
587 strcpy (usstr, "((uae_u16)(");
588 break;
589 case sz_long:
590 strcpy (vstr, "((uae_s32)(");
591 strcpy (usstr, "((uae_u32)(");
592 break;
593 default:
594 abort ();
595 }
596 strcpy (unsstr, usstr);
597
598 strcpy (sstr, vstr);
599 strcpy (dstr, vstr);
600 strcat (vstr, value);
601 strcat (vstr, "))");
602 strcat (dstr, dst);
603 strcat (dstr, "))");
604 strcat (sstr, src);
605 strcat (sstr, "))");
606
607 strcpy (udstr, usstr);
608 strcat (udstr, dst);
609 strcat (udstr, "))");
610 strcat (usstr, src);
611 strcat (usstr, "))");
612
613 strcpy (undstr, unsstr);
614 strcat (unsstr, "-");
615 strcat (undstr, "~");
616 strcat (undstr, dst);
617 strcat (undstr, "))");
618 strcat (unsstr, src);
619 strcat (unsstr, "))");
620
621 switch (type) {
622 case flag_logical_noclobber:
623 case flag_logical:
624 case flag_zn:
625 case flag_av:
626 case flag_sv:
627 case flag_addx:
628 case flag_subx:
629 break;
630
631 case flag_add:
632 start_brace ();
633 printf ("uae_u32 %s = %s + %s;\n", value, dstr, sstr);
634 break;
635 case flag_sub:
636 case flag_cmp:
637 start_brace ();
638 printf ("uae_u32 %s = %s - %s;\n", value, dstr, sstr);
639 break;
640 }
641
642 switch (type) {
643 case flag_logical_noclobber:
644 case flag_logical:
645 case flag_zn:
646 break;
647
648 case flag_add:
649 case flag_sub:
650 case flag_addx:
651 case flag_subx:
652 case flag_cmp:
653 case flag_av:
654 case flag_sv:
655 start_brace ();
656 printf ("\t" BOOL_TYPE " flgs = %s < 0;\n", sstr);
657 printf ("\t" BOOL_TYPE " flgo = %s < 0;\n", dstr);
658 printf ("\t" BOOL_TYPE " flgn = %s < 0;\n", vstr);
659 break;
660 }
661
662 switch (type) {
663 case flag_logical:
664 printf ("\tCLEAR_CZNV;\n");
665 printf ("\tSET_ZFLG (%s == 0);\n", vstr);
666 printf ("\tSET_NFLG (%s < 0);\n", vstr);
667 break;
668 case flag_logical_noclobber:
669 printf ("\tSET_ZFLG (%s == 0);\n", vstr);
670 printf ("\tSET_NFLG (%s < 0);\n", vstr);
671 break;
672 case flag_av:
673 printf ("\tSET_VFLG ((flgs ^ flgn) & (flgo ^ flgn));\n");
674 break;
675 case flag_sv:
676 printf ("\tSET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));\n");
677 break;
678 case flag_zn:
679 printf ("\tSET_ZFLG (GET_ZFLG & (%s == 0));\n", vstr);
680 printf ("\tSET_NFLG (%s < 0);\n", vstr);
681 break;
682 case flag_add:
683 printf ("\tSET_ZFLG (%s == 0);\n", vstr);
684 printf ("\tSET_VFLG ((flgs ^ flgn) & (flgo ^ flgn));\n");
685 printf ("\tSET_CFLG (%s < %s);\n", undstr, usstr);
686 duplicate_carry ();
687 printf ("\tSET_NFLG (flgn != 0);\n");
688 break;
689 case flag_sub:
690 printf ("\tSET_ZFLG (%s == 0);\n", vstr);
691 printf ("\tSET_VFLG ((flgs ^ flgo) & (flgn ^ flgo));\n");
692 printf ("\tSET_CFLG (%s > %s);\n", usstr, udstr);
693 duplicate_carry ();
694 printf ("\tSET_NFLG (flgn != 0);\n");
695 break;
696 case flag_addx:
697 printf ("\tSET_VFLG ((flgs ^ flgn) & (flgo ^ flgn));\n"); /* minterm SON: 0x42 */
698 printf ("\tSET_CFLG (flgs ^ ((flgs ^ flgo) & (flgo ^ flgn)));\n"); /* minterm SON: 0xD4 */
699 duplicate_carry ();
700 break;
701 case flag_subx:
702 printf ("\tSET_VFLG ((flgs ^ flgo) & (flgo ^ flgn));\n"); /* minterm SON: 0x24 */
703 printf ("\tSET_CFLG (flgs ^ ((flgs ^ flgn) & (flgo ^ flgn)));\n"); /* minterm SON: 0xB2 */
704 duplicate_carry ();
705 break;
706 case flag_cmp:
707 printf ("\tSET_ZFLG (%s == 0);\n", vstr);
708 printf ("\tSET_VFLG ((flgs != flgo) && (flgn != flgo));\n");
709 printf ("\tSET_CFLG (%s > %s);\n", usstr, udstr);
710 printf ("\tSET_NFLG (flgn != 0);\n");
711 break;
712 }
713 }
714
715 static void genflags (flagtypes type, wordsizes size, char *value, char *src, char *dst)
716 {
717 #ifdef SPARC_V8_ASSEMBLY
718 switch(type)
719 {
720 case flag_add:
721 start_brace();
722 printf("\tuae_u32 %s;\n", value);
723 switch(size)
724 {
725 case sz_byte:
726 printf("\t%s = sparc_v8_flag_add_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
727 break;
728 case sz_word:
729 printf("\t%s = sparc_v8_flag_add_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
730 break;
731 case sz_long:
732 printf("\t%s = sparc_v8_flag_add_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
733 break;
734 }
735 return;
736
737 case flag_sub:
738 start_brace();
739 printf("\tuae_u32 %s;\n", value);
740 switch(size)
741 {
742 case sz_byte:
743 printf("\t%s = sparc_v8_flag_sub_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
744 break;
745 case sz_word:
746 printf("\t%s = sparc_v8_flag_sub_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
747 break;
748 case sz_long:
749 printf("\t%s = sparc_v8_flag_sub_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
750 break;
751 }
752 return;
753
754 case flag_cmp:
755 switch(size)
756 {
757 case sz_byte:
758 // printf("\tsparc_v8_flag_cmp_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
759 break;
760 case sz_word:
761 // printf("\tsparc_v8_flag_cmp_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
762 break;
763 case sz_long:
764 #if 1
765 printf("\tsparc_v8_flag_cmp_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
766 return;
767 #endif
768 break;
769 }
770 // return;
771 break;
772 }
773 #elif defined(SPARC_V9_ASSEMBLY)
774 switch(type)
775 {
776 case flag_add:
777 start_brace();
778 printf("\tuae_u32 %s;\n", value);
779 switch(size)
780 {
781 case sz_byte:
782 printf("\t%s = sparc_v9_flag_add_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
783 break;
784 case sz_word:
785 printf("\t%s = sparc_v9_flag_add_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
786 break;
787 case sz_long:
788 printf("\t%s = sparc_v9_flag_add_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
789 break;
790 }
791 return;
792
793 case flag_sub:
794 start_brace();
795 printf("\tuae_u32 %s;\n", value);
796 switch(size)
797 {
798 case sz_byte:
799 printf("\t%s = sparc_v9_flag_sub_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
800 break;
801 case sz_word:
802 printf("\t%s = sparc_v9_flag_sub_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
803 break;
804 case sz_long:
805 printf("\t%s = sparc_v9_flag_sub_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", value, src, dst);
806 break;
807 }
808 return;
809
810 case flag_cmp:
811 switch(size)
812 {
813 case sz_byte:
814 printf("\tsparc_v9_flag_cmp_8(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
815 break;
816 case sz_word:
817 printf("\tsparc_v9_flag_cmp_16(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
818 break;
819 case sz_long:
820 printf("\tsparc_v9_flag_cmp_32(&regflags, (uae_u32)(%s), (uae_u32)(%s));\n", src, dst);
821 break;
822 }
823 return;
824
825 case flag_logical:
826 if (strcmp(value, "0") == 0) {
827 printf("\tregflags.nzvc = 0x04;\n");
828 } else {
829 switch(size) {
830 case sz_byte:
831 printf("\tsparc_v9_flag_test_8(&regflags, (uae_u32)(%s));\n", value);
832 break;
833 case sz_word:
834 printf("\tsparc_v9_flag_test_16(&regflags, (uae_u32)(%s));\n", value);
835 break;
836 case sz_long:
837 printf("\tsparc_v9_flag_test_32(&regflags, (uae_u32)(%s));\n", value);
838 break;
839 }
840 }
841 return;
842
843 #if 0
844 case flag_logical_noclobber:
845 printf("\t{uae_u32 old_flags = regflags.nzvc & ~0x0C;\n");
846 if (strcmp(value, "0") == 0) {
847 printf("\tregflags.nzvc = old_flags | 0x04;\n");
848 } else {
849 switch(size) {
850 case sz_byte:
851 printf("\tsparc_v9_flag_test_8(&regflags, (uae_u32)(%s));\n", value);
852 break;
853 case sz_word:
854 printf("\tsparc_v9_flag_test_16(&regflags, (uae_u32)(%s));\n", value);
855 break;
856 case sz_long:
857 printf("\tsparc_v9_flag_test_32(&regflags, (uae_u32)(%s));\n", value);
858 break;
859 }
860 printf("\tregflags.nzvc |= old_flags;\n");
861 }
862 printf("\t}\n");
863 return;
864 #endif
865 }
866 #elif defined(X86_ASSEMBLY)
867 switch (type) {
868 case flag_add:
869 case flag_sub:
870 start_brace ();
871 printf ("\tuae_u32 %s;\n", value);
872 break;
873
874 default:
875 break;
876 }
877
878 /* At least some of those casts are fairly important! */
879 switch (type) {
880 case flag_logical_noclobber:
881 printf ("\t{uae_u32 oldcznv = regflags.cznv & ~0xC0;\n");
882 if (strcmp (value, "0") == 0) {
883 printf ("\tregflags.cznv = olcznv | 64;\n");
884 } else {
885 switch (size) {
886 case sz_byte: printf ("\tx86_flag_testb ((uae_s8)(%s));\n", value); break;
887 case sz_word: printf ("\tx86_flag_testw ((uae_s16)(%s));\n", value); break;
888 case sz_long: printf ("\tx86_flag_testl ((uae_s32)(%s));\n", value); break;
889 }
890 printf ("\tregflags.cznv |= oldcznv;\n");
891 }
892 printf ("\t}\n");
893 return;
894 case flag_logical:
895 if (strcmp (value, "0") == 0) {
896 printf ("\tregflags.cznv = 64;\n");
897 } else {
898 switch (size) {
899 case sz_byte: printf ("\tx86_flag_testb ((uae_s8)(%s));\n", value); break;
900 case sz_word: printf ("\tx86_flag_testw ((uae_s16)(%s));\n", value); break;
901 case sz_long: printf ("\tx86_flag_testl ((uae_s32)(%s));\n", value); break;
902 }
903 }
904 return;
905
906 case flag_add:
907 switch (size) {
908 case sz_byte: printf ("\tx86_flag_addb (%s, (uae_s8)(%s), (uae_s8)(%s));\n", value, src, dst); break;
909 case sz_word: printf ("\tx86_flag_addw (%s, (uae_s16)(%s), (uae_s16)(%s));\n", value, src, dst); break;
910 case sz_long: printf ("\tx86_flag_addl (%s, (uae_s32)(%s), (uae_s32)(%s));\n", value, src, dst); break;
911 }
912 return;
913
914 case flag_sub:
915 switch (size) {
916 case sz_byte: printf ("\tx86_flag_subb (%s, (uae_s8)(%s), (uae_s8)(%s));\n", value, src, dst); break;
917 case sz_word: printf ("\tx86_flag_subw (%s, (uae_s16)(%s), (uae_s16)(%s));\n", value, src, dst); break;
918 case sz_long: printf ("\tx86_flag_subl (%s, (uae_s32)(%s), (uae_s32)(%s));\n", value, src, dst); break;
919 }
920 return;
921
922 case flag_cmp:
923 switch (size) {
924 case sz_byte: printf ("\tx86_flag_cmpb ((uae_s8)(%s), (uae_s8)(%s));\n", src, dst); break;
925 case sz_word: printf ("\tx86_flag_cmpw ((uae_s16)(%s), (uae_s16)(%s));\n", src, dst); break;
926 case sz_long: printf ("\tx86_flag_cmpl ((uae_s32)(%s), (uae_s32)(%s));\n", src, dst); break;
927 }
928 return;
929
930 default:
931 break;
932 }
933 #elif defined(M68K_FLAG_OPT)
934 /* sam: here I'm cloning what X86_ASSEMBLY does */
935 #define EXT(size) (size==sz_byte?"b":(size==sz_word?"w":"l"))
936 #define CAST(size) (size==sz_byte?"uae_s8":(size==sz_word?"uae_s16":"uae_s32"))
937 switch (type) {
938 case flag_add:
939 case flag_sub:
940 start_brace ();
941 printf ("\tuae_u32 %s;\n", value);
942 break;
943
944 default:
945 break;
946 }
947
948 switch (type) {
949 case flag_logical:
950 if (strcmp (value, "0") == 0) {
951 printf ("\t*(uae_u16 *)&regflags = 4;\n"); /* Z = 1 */
952 } else {
953 printf ("\tm68k_flag_tst (%s, (%s)(%s));\n",
954 EXT (size), CAST (size), value);
955 }
956 return;
957
958 case flag_add:
959 printf ("\t{uae_u16 ccr;\n");
960 printf ("\tm68k_flag_add (%s, (%s)%s, (%s)(%s), (%s)(%s));\n",
961 EXT (size), CAST (size), value, CAST (size), src, CAST (size), dst);
962 printf ("\t((uae_u16*)&regflags)[1]=((uae_u16*)&regflags)[0]=ccr;}\n");
963 return;
964
965 case flag_sub:
966 printf ("\t{uae_u16 ccr;\n");
967 printf ("\tm68k_flag_sub (%s, (%s)%s, (%s)(%s), (%s)(%s));\n",
968 EXT (size), CAST (size), value, CAST (size), src, CAST (size), dst);
969 printf ("\t((uae_u16*)&regflags)[1]=((uae_u16*)&regflags)[0]=ccr;}\n");
970 return;
971
972 case flag_cmp:
973 printf ("\tm68k_flag_cmp (%s, (%s)(%s), (%s)(%s));\n",
974 EXT (size), CAST (size), src, CAST (size), dst);
975 return;
976
977 default:
978 break;
979 }
980 #elif defined(ACORN_FLAG_OPT) && defined(__GNUC_MINOR__)
981 /*
982 * This is new. Might be quite buggy.
983 */
984 switch (type) {
985 case flag_av:
986 case flag_sv:
987 case flag_zn:
988 case flag_addx:
989 case flag_subx:
990 break;
991
992 case flag_logical:
993 if (strcmp (value, "0") == 0) {
994 /* v=c=n=0 z=1 */
995 printf ("\t*(ULONG*)&regflags = 0x40000000;\n");
996 return;
997 } else {
998 start_brace ();
999 switch (size) {
1000 case sz_byte:
1001 printf ("\tUBYTE ccr;\n");
1002 printf ("\tULONG shift;\n");
1003 printf ("\t__asm__(\"mov %%2,%%1,lsl#24\n\ttst %%2,%%2\n\tmov %%0,r15,lsr#24\n\tbic %%0,%%0,#0x30\"\n"
1004 "\t: \"=r\" (ccr) : \"r\" (%s), \"r\" (shift) : \"cc\" );\n", value);
1005 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1006 return;
1007 case sz_word:
1008 printf ("\tUBYTE ccr;\n");
1009 printf ("\tULONG shift;\n");
1010 printf ("\t__asm__(\"mov %%2,%%1,lsl#16\n\ttst %%2,%%2\n\tmov %%0,r15,lsr#24\n\tbic %%0,%%0,#0x30\"\n"
1011 "\t: \"=r\" (ccr) : \"r\" ((WORD)%s), \"r\" (shift) : \"cc\" );\n", value);
1012 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1013 return;
1014 case sz_long:
1015 printf ("\tUBYTE ccr;\n");
1016 printf ("\t__asm__(\"tst %%1,%%1\n\tmov %%0,r15,lsr#24\n\tbic %%0,%%0,#0x30\"\n"
1017 "\t: \"=r\" (ccr) : \"r\" ((LONG)%s) : \"cc\" );\n", value);
1018 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1019 return;
1020 }
1021 }
1022 break;
1023 case flag_add:
1024 if (strcmp (dst, "0") == 0) {
1025 printf ("/* Error! Hier muss Peter noch was machen !!! (ADD-Flags) */");
1026 } else {
1027 start_brace ();
1028 switch (size) {
1029 case sz_byte:
1030 printf ("\tULONG ccr, shift, %s;\n", value);
1031 printf ("\t__asm__(\"mov %%4,%%3,lsl#24\n\tadds %%0,%%4,%%2,lsl#24\n\tmov %%0,%%0,asr#24\n\tmov %%1,r15\n\torr %%1,%%1,%%1,lsr#29\"\n"
1032 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" (%s), \"r\" (%s), \"r\" (shift) : \"cc\" );\n", value, src, dst);
1033 printf ("\t*(ULONG*)&regflags = ccr;\n");
1034 return;
1035 case sz_word:
1036 printf ("\tULONG ccr, shift, %s;\n", value);
1037 printf ("\t__asm__(\"mov %%4,%%3,lsl#16\n\tadds %%0,%%4,%%2,lsl#16\n\tmov %%0,%%0,asr#16\n\tmov %%1,r15\n\torr %%1,%%1,%%1,lsr#29\"\n"
1038 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" ((WORD)%s), \"r\" ((WORD)%s), \"r\" (shift) : \"cc\" );\n", value, src, dst);
1039 printf ("\t*(ULONG*)&regflags = ccr;\n");
1040 return;
1041 case sz_long:
1042 printf ("\tULONG ccr, %s;\n", value);
1043 printf ("\t__asm__(\"adds %%0,%%3,%%2\n\tmov %%1,r15\n\torr %%1,%%1,%%1,lsr#29\"\n"
1044 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" ((LONG)%s), \"r\" ((LONG)%s) : \"cc\" );\n", value, src, dst);
1045 printf ("\t*(ULONG*)&regflags = ccr;\n");
1046 return;
1047 }
1048 }
1049 break;
1050 case flag_sub:
1051 if (strcmp (dst, "0") == 0) {
1052 printf ("/* Error! Hier muss Peter noch was machen !!! (SUB-Flags) */");
1053 } else {
1054 start_brace ();
1055 switch (size) {
1056 case sz_byte:
1057 printf ("\tULONG ccr, shift, %s;\n", value);
1058 printf ("\t__asm__(\"mov %%4,%%3,lsl#24\n\tsubs %%0,%%4,%%2,lsl#24\n\tmov %%0,%%0,asr#24\n\tmov %%1,r15\n\teor %%1,%%1,#0x20000000\n\torr %%1,%%1,%%1,lsr#29\"\n"
1059 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" (%s), \"r\" (%s), \"r\" (shift) : \"cc\" );\n", value, src, dst);
1060 printf ("\t*(ULONG*)&regflags = ccr;\n");
1061 return;
1062 case sz_word:
1063 printf ("\tULONG ccr, shift, %s;\n", value);
1064 printf ("\t__asm__(\"mov %%4,%%3,lsl#16\n\tsubs %%0,%%4,%%2,lsl#16\n\tmov %%0,%%0,asr#16\n\tmov %%1,r15\n\teor %%1,%%1,#0x20000000\n\torr %%1,%%1,%%1,lsr#29\"\n"
1065 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" ((WORD)%s), \"r\" ((WORD)%s), \"r\" (shift) : \"cc\" );\n", value, src, dst);
1066 printf ("\t*(ULONG*)&regflags = ccr;\n");
1067 return;
1068 case sz_long:
1069 printf ("\tULONG ccr, %s;\n", value);
1070 printf ("\t__asm__(\"subs %%0,%%3,%%2\n\tmov %%1,r15\n\teor %%1,%%1,#0x20000000\n\torr %%1,%%1,%%1,lsr#29\"\n"
1071 "\t: \"=r\" (%s), \"=r\" (ccr) : \"r\" ((LONG)%s), \"r\" ((LONG)%s) : \"cc\" );\n", value, src, dst);
1072 printf ("\t*(ULONG*)&regflags = ccr;\n");
1073 return;
1074 }
1075 }
1076 break;
1077 case flag_cmp:
1078 if (strcmp (dst, "0") == 0) {
1079 printf ("/*Error! Hier muss Peter noch was machen !!! (CMP-Flags)*/");
1080 } else {
1081 start_brace ();
1082 switch (size) {
1083 case sz_byte:
1084 printf ("\tULONG shift, ccr;\n");
1085 printf ("\t__asm__(\"mov %%3,%%2,lsl#24\n\tcmp %%3,%%1,lsl#24\n\tmov %%0,r15,lsr#24\n\teor %%0,%%0,#0x20\"\n"
1086 "\t: \"=r\" (ccr) : \"r\" (%s), \"r\" (%s), \"r\" (shift) : \"cc\" );\n", src, dst);
1087 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1088 return;
1089 case sz_word:
1090 printf ("\tULONG shift, ccr;\n");
1091 printf ("\t__asm__(\"mov %%3,%%2,lsl#16\n\tcmp %%3,%%1,lsl#16\n\tmov %%0,r15,lsr#24\n\teor %%0,%%0,#0x20\"\n"
1092 "\t: \"=r\" (ccr) : \"r\" ((WORD)%s), \"r\" ((WORD)%s), \"r\" (shift) : \"cc\" );\n", src, dst);
1093 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1094 return;
1095 case sz_long:
1096 printf ("\tULONG ccr;\n");
1097 printf ("\t__asm__(\"cmp %%2,%%1\n\tmov %%0,r15,lsr#24\n\teor %%0,%%0,#0x20\"\n"
1098 "\t: \"=r\" (ccr) : \"r\" ((LONG)%s), \"r\" ((LONG)%s) : \"cc\" );\n", src, dst);
1099 printf ("\t*((UBYTE*)&regflags+3) = ccr;\n");
1100 /*printf ("\tprintf (\"%%08x %%08x %%08x\\n\", %s, %s, *((ULONG*)&regflags));\n", src, dst); */
1101 return;
1102 }
1103 }
1104 break;
1105 }
1106 #endif
1107 genflags_normal (type, size, value, src, dst);
1108 }
1109
1110 static void force_range_for_rox (const char *var, wordsizes size)
1111 {
1112 /* Could do a modulo operation here... which one is faster? */
1113 switch (size) {
1114 case sz_long:
1115 printf ("\tif (%s >= 33) %s -= 33;\n", var, var);
1116 break;
1117 case sz_word:
1118 printf ("\tif (%s >= 34) %s -= 34;\n", var, var);
1119 printf ("\tif (%s >= 17) %s -= 17;\n", var, var);
1120 break;
1121 case sz_byte:
1122 printf ("\tif (%s >= 36) %s -= 36;\n", var, var);
1123 printf ("\tif (%s >= 18) %s -= 18;\n", var, var);
1124 printf ("\tif (%s >= 9) %s -= 9;\n", var, var);
1125 break;
1126 }
1127 }
1128
1129 static const char *cmask (wordsizes size)
1130 {
1131 switch (size) {
1132 case sz_byte: return "0x80";
1133 case sz_word: return "0x8000";
1134 case sz_long: return "0x80000000";
1135 default: abort ();
1136 }
1137 }
1138
1139 static int source_is_imm1_8 (struct instr *i)
1140 {
1141 return i->stype == 3;
1142 }
1143
1144 static void gen_opcode (unsigned long int opcode)
1145 {
1146 struct instr *curi = table68k + opcode;
1147 insn_n_cycles = 2;
1148
1149 start_brace ();
1150 #if 0
1151 printf ("uae_u8 *m68k_pc = regs.pc_p;\n");
1152 #endif
1153 m68k_pc_offset = 2;
1154 switch (curi->plev) {
1155 case 0: /* not privileged */
1156 break;
1157 case 1: /* unprivileged only on 68000 */
1158 if (cpu_level == 0)
1159 break;
1160 if (next_cpu_level < 0)
1161 next_cpu_level = 0;
1162
1163 /* fall through */
1164 case 2: /* priviledged */
1165 printf ("if (!regs.s) { Exception(8,0); goto %s; }\n", endlabelstr);
1166 need_endlabel = 1;
1167 start_brace ();
1168 break;
1169 case 3: /* privileged if size == word */
1170 if (curi->size == sz_byte)
1171 break;
1172 printf ("if (!regs.s) { Exception(8,0); goto %s; }\n", endlabelstr);
1173 need_endlabel = 1;
1174 start_brace ();
1175 break;
1176 }
1177 switch (curi->mnemo) {
1178 case i_OR:
1179 case i_AND:
1180 case i_EOR:
1181 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1182 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1183 printf ("\tsrc %c= dst;\n", curi->mnemo == i_OR ? '|' : curi->mnemo == i_AND ? '&' : '^');
1184 genflags (flag_logical, curi->size, "src", "", "");
1185 genastore ("src", curi->dmode, "dstreg", curi->size, "dst");
1186 break;
1187 case i_ORSR:
1188 case i_EORSR:
1189 printf ("\tMakeSR();\n");
1190 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1191 if (curi->size == sz_byte) {
1192 printf ("\tsrc &= 0xFF;\n");
1193 }
1194 printf ("\tregs.sr %c= src;\n", curi->mnemo == i_EORSR ? '^' : '|');
1195 printf ("\tMakeFromSR();\n");
1196 break;
1197 case i_ANDSR:
1198 printf ("\tMakeSR();\n");
1199 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1200 if (curi->size == sz_byte) {
1201 printf ("\tsrc |= 0xFF00;\n");
1202 }
1203 printf ("\tregs.sr &= src;\n");
1204 printf ("\tMakeFromSR();\n");
1205 break;
1206 case i_SUB:
1207 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1208 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1209 start_brace ();
1210 genflags (flag_sub, curi->size, "newv", "src", "dst");
1211 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1212 break;
1213 case i_SUBA:
1214 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1215 genamode (curi->dmode, "dstreg", sz_long, "dst", 1, 0);
1216 start_brace ();
1217 printf ("\tuae_u32 newv = dst - src;\n");
1218 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1219 break;
1220 case i_SUBX:
1221 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1222 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1223 start_brace ();
1224 printf ("\tuae_u32 newv = dst - src - (GET_XFLG ? 1 : 0);\n");
1225 genflags (flag_subx, curi->size, "newv", "src", "dst");
1226 genflags (flag_zn, curi->size, "newv", "", "");
1227 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1228 break;
1229 case i_SBCD:
1230 /* Let's hope this works... */
1231 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1232 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1233 start_brace ();
1234 printf ("\tuae_u16 newv_lo = (dst & 0xF) - (src & 0xF) - (GET_XFLG ? 1 : 0);\n");
1235 printf ("\tuae_u16 newv_hi = (dst & 0xF0) - (src & 0xF0);\n");
1236 printf ("\tuae_u16 newv;\n");
1237 printf ("\tint cflg;\n");
1238 printf ("\tif (newv_lo > 9) { newv_lo-=6; newv_hi-=0x10; }\n");
1239 printf ("\tnewv = newv_hi + (newv_lo & 0xF);");
1240 printf ("\tSET_CFLG (cflg = (newv_hi & 0x1F0) > 0x90);\n");
1241 duplicate_carry ();
1242 printf ("\tif (cflg) newv -= 0x60;\n");
1243 genflags (flag_zn, curi->size, "newv", "", "");
1244 genflags (flag_sv, curi->size, "newv", "src", "dst");
1245 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1246 break;
1247 case i_ADD:
1248 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1249 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1250 start_brace ();
1251 genflags (flag_add, curi->size, "newv", "src", "dst");
1252 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1253 break;
1254 case i_ADDA:
1255 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1256 genamode (curi->dmode, "dstreg", sz_long, "dst", 1, 0);
1257 start_brace ();
1258 printf ("\tuae_u32 newv = dst + src;\n");
1259 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1260 break;
1261 case i_ADDX:
1262 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1263 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1264 start_brace ();
1265 printf ("\tuae_u32 newv = dst + src + (GET_XFLG ? 1 : 0);\n");
1266 genflags (flag_addx, curi->size, "newv", "src", "dst");
1267 genflags (flag_zn, curi->size, "newv", "", "");
1268 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1269 break;
1270 case i_ABCD:
1271 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1272 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1273 start_brace ();
1274 printf ("\tuae_u16 newv_lo = (src & 0xF) + (dst & 0xF) + (GET_XFLG ? 1 : 0);\n");
1275 printf ("\tuae_u16 newv_hi = (src & 0xF0) + (dst & 0xF0);\n");
1276 printf ("\tuae_u16 newv;\n");
1277 printf ("\tint cflg;\n");
1278 printf ("\tif (newv_lo > 9) { newv_lo +=6; }\n");
1279 printf ("\tnewv = newv_hi + newv_lo;");
1280 printf ("\tSET_CFLG (cflg = (newv & 0x1F0) > 0x90);\n");
1281 duplicate_carry ();
1282 printf ("\tif (cflg) newv += 0x60;\n");
1283 genflags (flag_zn, curi->size, "newv", "", "");
1284 genflags (flag_sv, curi->size, "newv", "src", "dst");
1285 genastore ("newv", curi->dmode, "dstreg", curi->size, "dst");
1286 break;
1287 case i_NEG:
1288 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1289 start_brace ();
1290 genflags (flag_sub, curi->size, "dst", "src", "0");
1291 genastore ("dst", curi->smode, "srcreg", curi->size, "src");
1292 break;
1293 case i_NEGX:
1294 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1295 start_brace ();
1296 printf ("\tuae_u32 newv = 0 - src - (GET_XFLG ? 1 : 0);\n");
1297 genflags (flag_subx, curi->size, "newv", "src", "0");
1298 genflags (flag_zn, curi->size, "newv", "", "");
1299 genastore ("newv", curi->smode, "srcreg", curi->size, "src");
1300 break;
1301 case i_NBCD:
1302 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1303 start_brace ();
1304 printf ("\tuae_u16 newv_lo = - (src & 0xF) - (GET_XFLG ? 1 : 0);\n");
1305 printf ("\tuae_u16 newv_hi = - (src & 0xF0);\n");
1306 printf ("\tuae_u16 newv;\n");
1307 printf ("\tint cflg;\n");
1308 printf ("\tif (newv_lo > 9) { newv_lo-=6; newv_hi-=0x10; }\n");
1309 printf ("\tnewv = newv_hi + (newv_lo & 0xF);");
1310 printf ("\tSET_CFLG (cflg = (newv_hi & 0x1F0) > 0x90);\n");
1311 duplicate_carry();
1312 printf ("\tif (cflg) newv -= 0x60;\n");
1313 genflags (flag_zn, curi->size, "newv", "", "");
1314 genastore ("newv", curi->smode, "srcreg", curi->size, "src");
1315 break;
1316 case i_CLR:
1317 genamode (curi->smode, "srcreg", curi->size, "src", 2, 0);
1318 genflags (flag_logical, curi->size, "0", "", "");
1319 genastore ("0", curi->smode, "srcreg", curi->size, "src");
1320 break;
1321 case i_NOT:
1322 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1323 start_brace ();
1324 printf ("\tuae_u32 dst = ~src;\n");
1325 genflags (flag_logical, curi->size, "dst", "", "");
1326 genastore ("dst", curi->smode, "srcreg", curi->size, "src");
1327 break;
1328 case i_TST:
1329 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1330 genflags (flag_logical, curi->size, "src", "", "");
1331 break;
1332 case i_BTST:
1333 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1334 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1335 if (curi->size == sz_byte)
1336 printf ("\tsrc &= 7;\n");
1337 else
1338 printf ("\tsrc &= 31;\n");
1339 printf ("\tSET_ZFLG (1 ^ ((dst >> src) & 1));\n");
1340 break;
1341 case i_BCHG:
1342 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1343 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1344 if (curi->size == sz_byte)
1345 printf ("\tsrc &= 7;\n");
1346 else
1347 printf ("\tsrc &= 31;\n");
1348 printf ("\tdst ^= (1 << src);\n");
1349 printf ("\tSET_ZFLG ((dst & (1 << src)) >> src);\n");
1350 genastore ("dst", curi->dmode, "dstreg", curi->size, "dst");
1351 break;
1352 case i_BCLR:
1353 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1354 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1355 if (curi->size == sz_byte)
1356 printf ("\tsrc &= 7;\n");
1357 else
1358 printf ("\tsrc &= 31;\n");
1359 printf ("\tSET_ZFLG (1 ^ ((dst >> src) & 1));\n");
1360 printf ("\tdst &= ~(1 << src);\n");
1361 genastore ("dst", curi->dmode, "dstreg", curi->size, "dst");
1362 break;
1363 case i_BSET:
1364 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1365 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1366 if (curi->size == sz_byte)
1367 printf ("\tsrc &= 7;\n");
1368 else
1369 printf ("\tsrc &= 31;\n");
1370 printf ("\tSET_ZFLG (1 ^ ((dst >> src) & 1));\n");
1371 printf ("\tdst |= (1 << src);\n");
1372 genastore ("dst", curi->dmode, "dstreg", curi->size, "dst");
1373 break;
1374 case i_CMPM:
1375 case i_CMP:
1376 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1377 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1378 start_brace ();
1379 genflags (flag_cmp, curi->size, "newv", "src", "dst");
1380 break;
1381 case i_CMPA:
1382 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1383 genamode (curi->dmode, "dstreg", sz_long, "dst", 1, 0);
1384 start_brace ();
1385 genflags (flag_cmp, sz_long, "newv", "src", "dst");
1386 break;
1387 /* The next two are coded a little unconventional, but they are doing
1388 * weird things... */
1389 case i_MVPRM:
1390 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1391
1392 printf ("\tuaecptr memp = m68k_areg(regs, dstreg) + (uae_s32)(uae_s16)%s;\n", gen_nextiword ());
1393 if (curi->size == sz_word) {
1394 printf ("\tput_byte(memp, src >> 8); put_byte(memp + 2, src);\n");
1395 } else {
1396 printf ("\tput_byte(memp, src >> 24); put_byte(memp + 2, src >> 16);\n");
1397 printf ("\tput_byte(memp + 4, src >> 8); put_byte(memp + 6, src);\n");
1398 }
1399 break;
1400 case i_MVPMR:
1401 printf ("\tuaecptr memp = m68k_areg(regs, srcreg) + (uae_s32)(uae_s16)%s;\n", gen_nextiword ());
1402 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
1403 if (curi->size == sz_word) {
1404 printf ("\tuae_u16 val = (get_byte(memp) << 8) + get_byte(memp + 2);\n");
1405 } else {
1406 printf ("\tuae_u32 val = (get_byte(memp) << 24) + (get_byte(memp + 2) << 16)\n");
1407 printf (" + (get_byte(memp + 4) << 8) + get_byte(memp + 6);\n");
1408 }
1409 genastore ("val", curi->dmode, "dstreg", curi->size, "dst");
1410 break;
1411 case i_MOVE:
1412 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1413 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
1414 genflags (flag_logical, curi->size, "src", "", "");
1415 genastore ("src", curi->dmode, "dstreg", curi->size, "dst");
1416 break;
1417 case i_MOVEA:
1418 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1419 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
1420 if (curi->size == sz_word) {
1421 printf ("\tuae_u32 val = (uae_s32)(uae_s16)src;\n");
1422 } else {
1423 printf ("\tuae_u32 val = src;\n");
1424 }
1425 genastore ("val", curi->dmode, "dstreg", sz_long, "dst");
1426 break;
1427 case i_MVSR2:
1428 genamode (curi->smode, "srcreg", sz_word, "src", 2, 0);
1429 printf ("\tMakeSR();\n");
1430 if (curi->size == sz_byte)
1431 genastore ("regs.sr & 0xff", curi->smode, "srcreg", sz_word, "src");
1432 else
1433 genastore ("regs.sr", curi->smode, "srcreg", sz_word, "src");
1434 break;
1435 case i_MV2SR:
1436 genamode (curi->smode, "srcreg", sz_word, "src", 1, 0);
1437 if (curi->size == sz_byte)
1438 printf ("\tMakeSR();\n\tregs.sr &= 0xFF00;\n\tregs.sr |= src & 0xFF;\n");
1439 else {
1440 printf ("\tregs.sr = src;\n");
1441 }
1442 printf ("\tMakeFromSR();\n");
1443 break;
1444 case i_SWAP:
1445 genamode (curi->smode, "srcreg", sz_long, "src", 1, 0);
1446 start_brace ();
1447 printf ("\tuae_u32 dst = ((src >> 16)&0xFFFF) | ((src&0xFFFF)<<16);\n");
1448 genflags (flag_logical, sz_long, "dst", "", "");
1449 genastore ("dst", curi->smode, "srcreg", sz_long, "src");
1450 break;
1451 case i_EXG:
1452 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1453 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1454 genastore ("dst", curi->smode, "srcreg", curi->size, "src");
1455 genastore ("src", curi->dmode, "dstreg", curi->size, "dst");
1456 break;
1457 case i_EXT:
1458 genamode (curi->smode, "srcreg", sz_long, "src", 1, 0);
1459 start_brace ();
1460 switch (curi->size) {
1461 case sz_byte: printf ("\tuae_u32 dst = (uae_s32)(uae_s8)src;\n"); break;
1462 case sz_word: printf ("\tuae_u16 dst = (uae_s16)(uae_s8)src;\n"); break;
1463 case sz_long: printf ("\tuae_u32 dst = (uae_s32)(uae_s16)src;\n"); break;
1464 default: abort ();
1465 }
1466 genflags (flag_logical,
1467 curi->size == sz_word ? sz_word : sz_long, "dst", "", "");
1468 genastore ("dst", curi->smode, "srcreg",
1469 curi->size == sz_word ? sz_word : sz_long, "src");
1470 break;
1471 case i_MVMEL:
1472 genmovemel (opcode);
1473 break;
1474 case i_MVMLE:
1475 genmovemle (opcode);
1476 break;
1477 case i_TRAP:
1478 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1479 sync_m68k_pc ();
1480 printf ("\tException(src+32,0);\n");
1481 m68k_pc_offset = 0;
1482 break;
1483 case i_MVR2USP:
1484 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1485 printf ("\tregs.usp = src;\n");
1486 break;
1487 case i_MVUSP2R:
1488 genamode (curi->smode, "srcreg", curi->size, "src", 2, 0);
1489 genastore ("regs.usp", curi->smode, "srcreg", curi->size, "src");
1490 break;
1491 case i_RESET:
1492 break;
1493 case i_NOP:
1494 break;
1495 case i_STOP:
1496 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1497 printf ("\tregs.sr = src;\n");
1498 printf ("\tMakeFromSR();\n");
1499 printf ("\tm68k_setstopped(1);\n");
1500 break;
1501 case i_RTE:
1502 if (cpu_level == 0) {
1503 genamode (Aipi, "7", sz_word, "sr", 1, 0);
1504 genamode (Aipi, "7", sz_long, "pc", 1, 0);
1505 printf ("\tregs.sr = sr; m68k_setpc_rte(pc);\n");
1506 fill_prefetch_0 ();
1507 printf ("\tMakeFromSR();\n");
1508 } else {
1509 int old_brace_level = n_braces;
1510 if (next_cpu_level < 0)
1511 next_cpu_level = 0;
1512 printf ("\tuae_u16 newsr; uae_u32 newpc; for (;;) {\n");
1513 genamode (Aipi, "7", sz_word, "sr", 1, 0);
1514 genamode (Aipi, "7", sz_long, "pc", 1, 0);
1515 genamode (Aipi, "7", sz_word, "format", 1, 0);
1516 printf ("\tnewsr = sr; newpc = pc;\n");
1517 printf ("\tif ((format & 0xF000) == 0x0000) { break; }\n");
1518 printf ("\telse if ((format & 0xF000) == 0x1000) { ; }\n");
1519 printf ("\telse if ((format & 0xF000) == 0x2000) { m68k_areg(regs, 7) += 4; break; }\n");
1520 printf ("\telse if ((format & 0xF000) == 0x8000) { m68k_areg(regs, 7) += 50; break; }\n");
1521 printf ("\telse if ((format & 0xF000) == 0x9000) { m68k_areg(regs, 7) += 12; break; }\n");
1522 printf ("\telse if ((format & 0xF000) == 0xa000) { m68k_areg(regs, 7) += 24; break; }\n");
1523 printf ("\telse if ((format & 0xF000) == 0xb000) { m68k_areg(regs, 7) += 84; break; }\n");
1524 printf ("\telse { Exception(14,0); goto %s; }\n", endlabelstr);
1525 printf ("\tregs.sr = newsr; MakeFromSR();\n}\n");
1526 pop_braces (old_brace_level);
1527 printf ("\tregs.sr = newsr; MakeFromSR();\n");
1528 printf ("\tm68k_setpc_rte(newpc);\n");
1529 fill_prefetch_0 ();
1530 need_endlabel = 1;
1531 }
1532 /* PC is set and prefetch filled. */
1533 m68k_pc_offset = 0;
1534 break;
1535 case i_RTD:
1536 printf ("\tcompiler_flush_jsr_stack();\n");
1537 genamode (Aipi, "7", sz_long, "pc", 1, 0);
1538 genamode (curi->smode, "srcreg", curi->size, "offs", 1, 0);
1539 printf ("\tm68k_areg(regs, 7) += offs;\n");
1540 printf ("\tm68k_setpc_rte(pc);\n");
1541 fill_prefetch_0 ();
1542 /* PC is set and prefetch filled. */
1543 m68k_pc_offset = 0;
1544 break;
1545 case i_LINK:
1546 genamode (Apdi, "7", sz_long, "old", 2, 0);
1547 genamode (curi->smode, "srcreg", sz_long, "src", 1, 0);
1548 genastore ("src", Apdi, "7", sz_long, "old");
1549 genastore ("m68k_areg(regs, 7)", curi->smode, "srcreg", sz_long, "src");
1550 genamode (curi->dmode, "dstreg", curi->size, "offs", 1, 0);
1551 printf ("\tm68k_areg(regs, 7) += offs;\n");
1552 break;
1553 case i_UNLK:
1554 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1555 printf ("\tm68k_areg(regs, 7) = src;\n");
1556 genamode (Aipi, "7", sz_long, "old", 1, 0);
1557 genastore ("old", curi->smode, "srcreg", curi->size, "src");
1558 break;
1559 case i_RTS:
1560 printf ("\tm68k_do_rts();\n");
1561 fill_prefetch_0 ();
1562 m68k_pc_offset = 0;
1563 break;
1564 case i_TRAPV:
1565 sync_m68k_pc ();
1566 printf ("\tif (GET_VFLG) { Exception(7,m68k_getpc()); goto %s; }\n", endlabelstr);
1567 need_endlabel = 1;
1568 break;
1569 case i_RTR:
1570 printf ("\tcompiler_flush_jsr_stack();\n");
1571 printf ("\tMakeSR();\n");
1572 genamode (Aipi, "7", sz_word, "sr", 1, 0);
1573 genamode (Aipi, "7", sz_long, "pc", 1, 0);
1574 printf ("\tregs.sr &= 0xFF00; sr &= 0xFF;\n");
1575 printf ("\tregs.sr |= sr; m68k_setpc(pc);\n");
1576 fill_prefetch_0 ();
1577 printf ("\tMakeFromSR();\n");
1578 m68k_pc_offset = 0;
1579 break;
1580 case i_JSR:
1581 genamode (curi->smode, "srcreg", curi->size, "src", 0, 0);
1582 printf ("\tm68k_do_jsr(m68k_getpc() + %d, srca);\n", m68k_pc_offset);
1583 fill_prefetch_0 ();
1584 m68k_pc_offset = 0;
1585 break;
1586 case i_JMP:
1587 genamode (curi->smode, "srcreg", curi->size, "src", 0, 0);
1588 printf ("\tm68k_setpc(srca);\n");
1589 fill_prefetch_0 ();
1590 m68k_pc_offset = 0;
1591 break;
1592 case i_BSR:
1593 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1594 printf ("\tuae_s32 s = (uae_s32)src + 2;\n");
1595 if (using_exception_3) {
1596 printf ("\tif (src & 1) {\n");
1597 printf ("\tlast_addr_for_exception_3 = m68k_getpc() + 2;\n");
1598 printf ("\t\tlast_fault_for_exception_3 = m68k_getpc() + s;\n");
1599 printf ("\t\tlast_op_for_exception_3 = opcode; Exception(3,0); goto %s;\n", endlabelstr);
1600 printf ("\t}\n");
1601 need_endlabel = 1;
1602 }
1603 printf ("\tm68k_do_bsr(m68k_getpc() + %d, s);\n", m68k_pc_offset);
1604 fill_prefetch_0 ();
1605 m68k_pc_offset = 0;
1606 break;
1607 case i_Bcc:
1608 if (curi->size == sz_long) {
1609 if (cpu_level < 2) {
1610 printf ("\tm68k_incpc(2);\n");
1611 printf ("\tif (!cctrue(%d)) goto %s;\n", curi->cc, endlabelstr);
1612 printf ("\t\tlast_addr_for_exception_3 = m68k_getpc() + 2;\n");
1613 printf ("\t\tlast_fault_for_exception_3 = m68k_getpc() + 1;\n");
1614 printf ("\t\tlast_op_for_exception_3 = opcode; Exception(3,0); goto %s;\n", endlabelstr);
1615 need_endlabel = 1;
1616 } else {
1617 if (next_cpu_level < 1)
1618 next_cpu_level = 1;
1619 }
1620 }
1621 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1622 printf ("\tif (!cctrue(%d)) goto didnt_jump;\n", curi->cc);
1623 if (using_exception_3) {
1624 printf ("\tif (src & 1) {\n");
1625 printf ("\t\tlast_addr_for_exception_3 = m68k_getpc() + 2;\n");
1626 printf ("\t\tlast_fault_for_exception_3 = m68k_getpc() + 2 + (uae_s32)src;\n");
1627 printf ("\t\tlast_op_for_exception_3 = opcode; Exception(3,0); goto %s;\n", endlabelstr);
1628 printf ("\t}\n");
1629 need_endlabel = 1;
1630 }
1631 #ifdef USE_COMPILER
1632 printf ("\tm68k_setpc_bcc(m68k_getpc() + 2 + (uae_s32)src);\n");
1633 #else
1634 printf ("\tm68k_incpc ((uae_s32)src + 2);\n");
1635 #endif
1636 fill_prefetch_0 ();
1637 printf ("\tgoto %s;\n", endlabelstr);
1638 printf ("didnt_jump:;\n");
1639 need_endlabel = 1;
1640 break;
1641 case i_LEA:
1642 genamode (curi->smode, "srcreg", curi->size, "src", 0, 0);
1643 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
1644 genastore ("srca", curi->dmode, "dstreg", curi->size, "dst");
1645 break;
1646 case i_PEA:
1647 genamode (curi->smode, "srcreg", curi->size, "src", 0, 0);
1648 genamode (Apdi, "7", sz_long, "dst", 2, 0);
1649 genastore ("srca", Apdi, "7", sz_long, "dst");
1650 break;
1651 case i_DBcc:
1652 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1653 genamode (curi->dmode, "dstreg", curi->size, "offs", 1, 0);
1654
1655 printf ("\tif (!cctrue(%d)) {\n", curi->cc);
1656 genastore ("(src-1)", curi->smode, "srcreg", curi->size, "src");
1657
1658 printf ("\t\tif (src) {\n");
1659 if (using_exception_3) {
1660 printf ("\t\t\tif (offs & 1) {\n");
1661 printf ("\t\t\tlast_addr_for_exception_3 = m68k_getpc() + 2;\n");
1662 printf ("\t\t\tlast_fault_for_exception_3 = m68k_getpc() + 2 + (uae_s32)offs + 2;\n");
1663 printf ("\t\t\tlast_op_for_exception_3 = opcode; Exception(3,0); goto %s;\n", endlabelstr);
1664 printf ("\t\t}\n");
1665 need_endlabel = 1;
1666 }
1667 #ifdef USE_COMPILER
1668 printf ("\t\t\tm68k_setpc_bcc(m68k_getpc() + (uae_s32)offs + 2);\n");
1669 #else
1670 printf ("\t\t\tm68k_incpc((uae_s32)offs + 2);\n");
1671 #endif
1672 fill_prefetch_0 ();
1673 printf ("\t\tgoto %s;\n", endlabelstr);
1674 printf ("\t\t}\n");
1675 printf ("\t}\n");
1676 need_endlabel = 1;
1677 break;
1678 case i_Scc:
1679 genamode (curi->smode, "srcreg", curi->size, "src", 2, 0);
1680 start_brace ();
1681 printf ("\tint val = cctrue(%d) ? 0xff : 0;\n", curi->cc);
1682 genastore ("val", curi->smode, "srcreg", curi->size, "src");
1683 break;
1684 case i_DIVU:
1685 printf ("\tuaecptr oldpc = m68k_getpc();\n");
1686 genamode (curi->smode, "srcreg", sz_word, "src", 1, 0);
1687 genamode (curi->dmode, "dstreg", sz_long, "dst", 1, 0);
1688 printf ("\tif(src == 0) { Exception(5,oldpc); goto %s; } else {\n", endlabelstr);
1689 printf ("\tuae_u32 newv = (uae_u32)dst / (uae_u32)(uae_u16)src;\n");
1690 printf ("\tuae_u32 rem = (uae_u32)dst %% (uae_u32)(uae_u16)src;\n");
1691 /* The N flag appears to be set each time there is an overflow.
1692 * Weird. */
1693 printf ("\tif (newv > 0xffff) { SET_VFLG (1); SET_NFLG (1); SET_CFLG (0); } else\n\t{\n");
1694 genflags (flag_logical, sz_word, "newv", "", "");
1695 printf ("\tnewv = (newv & 0xffff) | ((uae_u32)rem << 16);\n");
1696 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1697 printf ("\t}\n");
1698 printf ("\t}\n");
1699 insn_n_cycles += 68;
1700 need_endlabel = 1;
1701 break;
1702 case i_DIVS:
1703 printf ("\tuaecptr oldpc = m68k_getpc();\n");
1704 genamode (curi->smode, "srcreg", sz_word, "src", 1, 0);
1705 genamode (curi->dmode, "dstreg", sz_long, "dst", 1, 0);
1706 printf ("\tif(src == 0) { Exception(5,oldpc); goto %s; } else {\n", endlabelstr);
1707 printf ("\tuae_s32 newv = (uae_s32)dst / (uae_s32)(uae_s16)src;\n");
1708 printf ("\tuae_u16 rem = (uae_s32)dst %% (uae_s32)(uae_s16)src;\n");
1709 printf ("\tif ((newv & 0xffff8000) != 0 && (newv & 0xffff8000) != 0xffff8000) { SET_VFLG (1); SET_NFLG (1); SET_CFLG (0); } else\n\t{\n");
1710 printf ("\tif (((uae_s16)rem < 0) != ((uae_s32)dst < 0)) rem = -rem;\n");
1711 genflags (flag_logical, sz_word, "newv", "", "");
1712 printf ("\tnewv = (newv & 0xffff) | ((uae_u32)rem << 16);\n");
1713 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1714 printf ("\t}\n");
1715 printf ("\t}\n");
1716 insn_n_cycles += 72;
1717 need_endlabel = 1;
1718 break;
1719 case i_MULU:
1720 genamode (curi->smode, "srcreg", sz_word, "src", 1, 0);
1721 genamode (curi->dmode, "dstreg", sz_word, "dst", 1, 0);
1722 start_brace ();
1723 printf ("\tuae_u32 newv = (uae_u32)(uae_u16)dst * (uae_u32)(uae_u16)src;\n");
1724 genflags (flag_logical, sz_long, "newv", "", "");
1725 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1726 insn_n_cycles += 32;
1727 break;
1728 case i_MULS:
1729 genamode (curi->smode, "srcreg", sz_word, "src", 1, 0);
1730 genamode (curi->dmode, "dstreg", sz_word, "dst", 1, 0);
1731 start_brace ();
1732 printf ("\tuae_u32 newv = (uae_s32)(uae_s16)dst * (uae_s32)(uae_s16)src;\n");
1733 genflags (flag_logical, sz_long, "newv", "", "");
1734 genastore ("newv", curi->dmode, "dstreg", sz_long, "dst");
1735 insn_n_cycles += 32;
1736 break;
1737 case i_CHK:
1738 printf ("\tuaecptr oldpc = m68k_getpc();\n");
1739 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
1740 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
1741 printf ("\tif ((uae_s32)dst < 0) { SET_NFLG (1); Exception(6,oldpc); goto %s; }\n", endlabelstr);
1742 printf ("\telse if (dst > src) { SET_NFLG (0); Exception(6,oldpc); goto %s; }\n", endlabelstr);
1743 need_endlabel = 1;
1744 break;
1745
1746 case i_CHK2:
1747 printf ("\tuaecptr oldpc = m68k_getpc();\n");
1748 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
1749 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
1750 printf ("\t{uae_s32 upper,lower,reg = regs.regs[(extra >> 12) & 15];\n");
1751 switch (curi->size) {
1752 case sz_byte:
1753 printf ("\tlower=(uae_s32)(uae_s8)get_byte(dsta); upper = (uae_s32)(uae_s8)get_byte(dsta+1);\n");
1754 printf ("\tif ((extra & 0x8000) == 0) reg = (uae_s32)(uae_s8)reg;\n");
1755 break;
1756 case sz_word:
1757 printf ("\tlower=(uae_s32)(uae_s16)get_word(dsta); upper = (uae_s32)(uae_s16)get_word(dsta+2);\n");
1758 printf ("\tif ((extra & 0x8000) == 0) reg = (uae_s32)(uae_s16)reg;\n");
1759 break;
1760 case sz_long:
1761 printf ("\tlower=get_long(dsta); upper = get_long(dsta+4);\n");
1762 break;
1763 default:
1764 abort ();
1765 }
1766 printf ("\tSET_ZFLG (upper == reg || lower == reg);\n");
1767 printf ("\tSET_CFLG (lower <= upper ? reg < lower || reg > upper : reg > upper || reg < lower);\n");
1768 printf ("\tif ((extra & 0x800) && GET_CFLG) { Exception(6,oldpc); goto %s; }\n}\n", endlabelstr);
1769 need_endlabel = 1;
1770 break;
1771
1772 case i_ASR:
1773 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1774 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1775 start_brace ();
1776 switch (curi->size) {
1777 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1778 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1779 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1780 default: abort ();
1781 }
1782 printf ("\tuae_u32 sign = (%s & val) >> %d;\n", cmask (curi->size), bit_size (curi->size) - 1);
1783 printf ("\tcnt &= 63;\n");
1784 printf ("\tCLEAR_CZNV;\n");
1785 printf ("\tif (cnt >= %d) {\n", bit_size (curi->size));
1786 printf ("\t\tval = %s & (uae_u32)-sign;\n", bit_mask (curi->size));
1787 printf ("\t\tSET_CFLG (sign);\n");
1788 duplicate_carry ();
1789 if (source_is_imm1_8 (curi))
1790 printf ("\t} else {\n");
1791 else
1792 printf ("\t} else if (cnt > 0) {\n");
1793 printf ("\t\tval >>= cnt - 1;\n");
1794 printf ("\t\tSET_CFLG (val & 1);\n");
1795 duplicate_carry ();
1796 printf ("\t\tval >>= 1;\n");
1797 printf ("\t\tval |= (%s << (%d - cnt)) & (uae_u32)-sign;\n",
1798 bit_mask (curi->size),
1799 bit_size (curi->size));
1800 printf ("\t\tval &= %s;\n", bit_mask (curi->size));
1801 printf ("\t}\n");
1802 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1803 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1804 break;
1805 case i_ASL:
1806 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1807 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1808 start_brace ();
1809 switch (curi->size) {
1810 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1811 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1812 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1813 default: abort ();
1814 }
1815 printf ("\tcnt &= 63;\n");
1816 printf ("\tCLEAR_CZNV;\n");
1817 printf ("\tif (cnt >= %d) {\n", bit_size (curi->size));
1818 printf ("\t\tSET_VFLG (val != 0);\n");
1819 printf ("\t\tSET_CFLG (cnt == %d ? val & 1 : 0);\n",
1820 bit_size (curi->size));
1821 duplicate_carry ();
1822 printf ("\t\tval = 0;\n");
1823 if (source_is_imm1_8 (curi))
1824 printf ("\t} else {\n");
1825 else
1826 printf ("\t} else if (cnt > 0) {\n");
1827 printf ("\t\tuae_u32 mask = (%s << (%d - cnt)) & %s;\n",
1828 bit_mask (curi->size),
1829 bit_size (curi->size) - 1,
1830 bit_mask (curi->size));
1831 printf ("\t\tSET_VFLG ((val & mask) != mask && (val & mask) != 0);\n");
1832 printf ("\t\tval <<= cnt - 1;\n");
1833 printf ("\t\tSET_CFLG ((val & %s) >> %d);\n", cmask (curi->size), bit_size (curi->size) - 1);
1834 duplicate_carry ();
1835 printf ("\t\tval <<= 1;\n");
1836 printf ("\t\tval &= %s;\n", bit_mask (curi->size));
1837 printf ("\t}\n");
1838 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1839 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1840 break;
1841 case i_LSR:
1842 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1843 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1844 start_brace ();
1845 switch (curi->size) {
1846 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1847 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1848 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1849 default: abort ();
1850 }
1851 printf ("\tcnt &= 63;\n");
1852 printf ("\tCLEAR_CZNV;\n");
1853 printf ("\tif (cnt >= %d) {\n", bit_size (curi->size));
1854 printf ("\t\tSET_CFLG ((cnt == %d) & (val >> %d));\n",
1855 bit_size (curi->size), bit_size (curi->size) - 1);
1856 duplicate_carry ();
1857 printf ("\t\tval = 0;\n");
1858 if (source_is_imm1_8 (curi))
1859 printf ("\t} else {\n");
1860 else
1861 printf ("\t} else if (cnt > 0) {\n");
1862 printf ("\t\tval >>= cnt - 1;\n");
1863 printf ("\t\tSET_CFLG (val & 1);\n");
1864 duplicate_carry ();
1865 printf ("\t\tval >>= 1;\n");
1866 printf ("\t}\n");
1867 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1868 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1869 break;
1870 case i_LSL:
1871 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1872 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1873 start_brace ();
1874 switch (curi->size) {
1875 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1876 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1877 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1878 default: abort ();
1879 }
1880 printf ("\tcnt &= 63;\n");
1881 printf ("\tCLEAR_CZNV;\n");
1882 printf ("\tif (cnt >= %d) {\n", bit_size (curi->size));
1883 printf ("\t\tSET_CFLG (cnt == %d ? val & 1 : 0);\n",
1884 bit_size (curi->size));
1885 duplicate_carry ();
1886 printf ("\t\tval = 0;\n");
1887 if (source_is_imm1_8 (curi))
1888 printf ("\t} else {\n");
1889 else
1890 printf ("\t} else if (cnt > 0) {\n");
1891 printf ("\t\tval <<= (cnt - 1);\n");
1892 printf ("\t\tSET_CFLG ((val & %s) >> %d);\n", cmask (curi->size), bit_size (curi->size) - 1);
1893 duplicate_carry ();
1894 printf ("\t\tval <<= 1;\n");
1895 printf ("\tval &= %s;\n", bit_mask (curi->size));
1896 printf ("\t}\n");
1897 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1898 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1899 break;
1900 case i_ROL:
1901 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1902 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1903 start_brace ();
1904 switch (curi->size) {
1905 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1906 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1907 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1908 default: abort ();
1909 }
1910 printf ("\tcnt &= 63;\n");
1911 printf ("\tCLEAR_CZNV;\n");
1912 if (source_is_imm1_8 (curi))
1913 printf ("{");
1914 else
1915 printf ("\tif (cnt > 0) {\n");
1916 printf ("\tuae_u32 loval;\n");
1917 printf ("\tcnt &= %d;\n", bit_size (curi->size) - 1);
1918 printf ("\tloval = val >> (%d - cnt);\n", bit_size (curi->size));
1919 printf ("\tval <<= cnt;\n");
1920 printf ("\tval |= loval;\n");
1921 printf ("\tval &= %s;\n", bit_mask (curi->size));
1922 printf ("\tSET_CFLG (val & 1);\n");
1923 printf ("}\n");
1924 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1925 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1926 break;
1927 case i_ROR:
1928 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1929 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1930 start_brace ();
1931 switch (curi->size) {
1932 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1933 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1934 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1935 default: abort ();
1936 }
1937 printf ("\tcnt &= 63;\n");
1938 printf ("\tCLEAR_CZNV;\n");
1939 if (source_is_imm1_8 (curi))
1940 printf ("{");
1941 else
1942 printf ("\tif (cnt > 0) {");
1943 printf ("\tuae_u32 hival;\n");
1944 printf ("\tcnt &= %d;\n", bit_size (curi->size) - 1);
1945 printf ("\thival = val << (%d - cnt);\n", bit_size (curi->size));
1946 printf ("\tval >>= cnt;\n");
1947 printf ("\tval |= hival;\n");
1948 printf ("\tval &= %s;\n", bit_mask (curi->size));
1949 printf ("\tSET_CFLG ((val & %s) >> %d);\n", cmask (curi->size), bit_size (curi->size) - 1);
1950 printf ("\t}\n");
1951 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1952 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1953 break;
1954 case i_ROXL:
1955 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1956 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1957 start_brace ();
1958 switch (curi->size) {
1959 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1960 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1961 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1962 default: abort ();
1963 }
1964 printf ("\tcnt &= 63;\n");
1965 printf ("\tCLEAR_CZNV;\n");
1966 if (! source_is_imm1_8 (curi))
1967 force_range_for_rox ("cnt", curi->size);
1968 if (source_is_imm1_8 (curi))
1969 printf ("{");
1970 else
1971 printf ("\tif (cnt > 0) {\n");
1972 printf ("\tcnt--;\n");
1973 printf ("\t{\n\tuae_u32 carry;\n");
1974 printf ("\tuae_u32 loval = val >> (%d - cnt);\n", bit_size (curi->size) - 1);
1975 printf ("\tcarry = loval & 1;\n");
1976 printf ("\tval = (((val << 1) | GET_XFLG) << cnt) | (loval >> 1);\n");
1977 printf ("\tSET_XFLG (carry);\n");
1978 printf ("\tval &= %s;\n", bit_mask (curi->size));
1979 printf ("\t} }\n");
1980 printf ("\tSET_CFLG (GET_XFLG);\n");
1981 genflags (flag_logical_noclobber, curi->size, "val", "", "");
1982 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
1983 break;
1984 case i_ROXR:
1985 genamode (curi->smode, "srcreg", curi->size, "cnt", 1, 0);
1986 genamode (curi->dmode, "dstreg", curi->size, "data", 1, 0);
1987 start_brace ();
1988 switch (curi->size) {
1989 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
1990 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
1991 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
1992 default: abort ();
1993 }
1994 printf ("\tcnt &= 63;\n");
1995 printf ("\tCLEAR_CZNV;\n");
1996 if (! source_is_imm1_8 (curi))
1997 force_range_for_rox ("cnt", curi->size);
1998 if (source_is_imm1_8 (curi))
1999 printf ("{");
2000 else
2001 printf ("\tif (cnt > 0) {\n");
2002 printf ("\tcnt--;\n");
2003 printf ("\t{\n\tuae_u32 carry;\n");
2004 printf ("\tuae_u32 hival = (val << 1) | GET_XFLG;\n");
2005 printf ("\thival <<= (%d - cnt);\n", bit_size (curi->size) - 1);
2006 printf ("\tval >>= cnt;\n");
2007 printf ("\tcarry = val & 1;\n");
2008 printf ("\tval >>= 1;\n");
2009 printf ("\tval |= hival;\n");
2010 printf ("\tSET_XFLG (carry);\n");
2011 printf ("\tval &= %s;\n", bit_mask (curi->size));
2012 printf ("\t} }\n");
2013 printf ("\tSET_CFLG (GET_XFLG);\n");
2014 genflags (flag_logical_noclobber, curi->size, "val", "", "");
2015 genastore ("val", curi->dmode, "dstreg", curi->size, "data");
2016 break;
2017 case i_ASRW:
2018 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2019 start_brace ();
2020 switch (curi->size) {
2021 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
2022 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
2023 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2024 default: abort ();
2025 }
2026 printf ("\tuae_u32 sign = %s & val;\n", cmask (curi->size));
2027 printf ("\tuae_u32 cflg = val & 1;\n");
2028 printf ("\tval = (val >> 1) | sign;\n");
2029 genflags (flag_logical, curi->size, "val", "", "");
2030 printf ("\tSET_CFLG (cflg);\n");
2031 duplicate_carry ();
2032 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2033 break;
2034 case i_ASLW:
2035 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2036 start_brace ();
2037 switch (curi->size) {
2038 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
2039 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
2040 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2041 default: abort ();
2042 }
2043 printf ("\tuae_u32 sign = %s & val;\n", cmask (curi->size));
2044 printf ("\tuae_u32 sign2;\n");
2045 printf ("\tval <<= 1;\n");
2046 genflags (flag_logical, curi->size, "val", "", "");
2047 printf ("\tsign2 = %s & val;\n", cmask (curi->size));
2048 printf ("\tSET_CFLG (sign != 0);\n");
2049 duplicate_carry ();
2050
2051 printf ("\tSET_VFLG (GET_VFLG | (sign2 != sign));\n");
2052 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2053 break;
2054 case i_LSRW:
2055 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2056 start_brace ();
2057 switch (curi->size) {
2058 case sz_byte: printf ("\tuae_u32 val = (uae_u8)data;\n"); break;
2059 case sz_word: printf ("\tuae_u32 val = (uae_u16)data;\n"); break;
2060 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2061 default: abort ();
2062 }
2063 printf ("\tuae_u32 carry = val & 1;\n");
2064 printf ("\tval >>= 1;\n");
2065 genflags (flag_logical, curi->size, "val", "", "");
2066 printf ("SET_CFLG (carry);\n");
2067 duplicate_carry ();
2068 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2069 break;
2070 case i_LSLW:
2071 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2072 start_brace ();
2073 switch (curi->size) {
2074 case sz_byte: printf ("\tuae_u8 val = data;\n"); break;
2075 case sz_word: printf ("\tuae_u16 val = data;\n"); break;
2076 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2077 default: abort ();
2078 }
2079 printf ("\tuae_u32 carry = val & %s;\n", cmask (curi->size));
2080 printf ("\tval <<= 1;\n");
2081 genflags (flag_logical, curi->size, "val", "", "");
2082 printf ("SET_CFLG (carry >> %d);\n", bit_size (curi->size) - 1);
2083 duplicate_carry ();
2084 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2085 break;
2086 case i_ROLW:
2087 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2088 start_brace ();
2089 switch (curi->size) {
2090 case sz_byte: printf ("\tuae_u8 val = data;\n"); break;
2091 case sz_word: printf ("\tuae_u16 val = data;\n"); break;
2092 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2093 default: abort ();
2094 }
2095 printf ("\tuae_u32 carry = val & %s;\n", cmask (curi->size));
2096 printf ("\tval <<= 1;\n");
2097 printf ("\tif (carry) val |= 1;\n");
2098 genflags (flag_logical, curi->size, "val", "", "");
2099 printf ("SET_CFLG (carry >> %d);\n", bit_size (curi->size) - 1);
2100 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2101 break;
2102 case i_RORW:
2103 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2104 start_brace ();
2105 switch (curi->size) {
2106 case sz_byte: printf ("\tuae_u8 val = data;\n"); break;
2107 case sz_word: printf ("\tuae_u16 val = data;\n"); break;
2108 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2109 default: abort ();
2110 }
2111 printf ("\tuae_u32 carry = val & 1;\n");
2112 printf ("\tval >>= 1;\n");
2113 printf ("\tif (carry) val |= %s;\n", cmask (curi->size));
2114 genflags (flag_logical, curi->size, "val", "", "");
2115 printf ("SET_CFLG (carry);\n");
2116 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2117 break;
2118 case i_ROXLW:
2119 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2120 start_brace ();
2121 switch (curi->size) {
2122 case sz_byte: printf ("\tuae_u8 val = data;\n"); break;
2123 case sz_word: printf ("\tuae_u16 val = data;\n"); break;
2124 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2125 default: abort ();
2126 }
2127 printf ("\tuae_u32 carry = val & %s;\n", cmask (curi->size));
2128 printf ("\tval <<= 1;\n");
2129 printf ("\tif (GET_XFLG) val |= 1;\n");
2130 genflags (flag_logical, curi->size, "val", "", "");
2131 printf ("SET_CFLG (carry >> %d);\n", bit_size (curi->size) - 1);
2132 duplicate_carry ();
2133 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2134 break;
2135 case i_ROXRW:
2136 genamode (curi->smode, "srcreg", curi->size, "data", 1, 0);
2137 start_brace ();
2138 switch (curi->size) {
2139 case sz_byte: printf ("\tuae_u8 val = data;\n"); break;
2140 case sz_word: printf ("\tuae_u16 val = data;\n"); break;
2141 case sz_long: printf ("\tuae_u32 val = data;\n"); break;
2142 default: abort ();
2143 }
2144 printf ("\tuae_u32 carry = val & 1;\n");
2145 printf ("\tval >>= 1;\n");
2146 printf ("\tif (GET_XFLG) val |= %s;\n", cmask (curi->size));
2147 genflags (flag_logical, curi->size, "val", "", "");
2148 printf ("SET_CFLG (carry);\n");
2149 duplicate_carry ();
2150 genastore ("val", curi->smode, "srcreg", curi->size, "data");
2151 break;
2152 case i_MOVEC2:
2153 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
2154 start_brace ();
2155 printf ("\tint regno = (src >> 12) & 15;\n");
2156 printf ("\tuae_u32 *regp = regs.regs + regno;\n");
2157 printf ("\tm68k_movec2(src & 0xFFF, regp);\n");
2158 break;
2159 case i_MOVE2C:
2160 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
2161 start_brace ();
2162 printf ("\tint regno = (src >> 12) & 15;\n");
2163 printf ("\tuae_u32 *regp = regs.regs + regno;\n");
2164 printf ("\tm68k_move2c(src & 0xFFF, regp);\n");
2165 break;
2166 case i_CAS:
2167 {
2168 int old_brace_level;
2169 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
2170 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
2171 start_brace ();
2172 printf ("\tint ru = (src >> 6) & 7;\n");
2173 printf ("\tint rc = src & 7;\n");
2174 genflags (flag_cmp, curi->size, "newv", "m68k_dreg(regs, rc)", "dst");
2175 printf ("\tif (GET_ZFLG)");
2176 old_brace_level = n_braces;
2177 start_brace ();
2178 genastore ("(m68k_dreg(regs, ru))", curi->dmode, "dstreg", curi->size, "dst");
2179 pop_braces (old_brace_level);
2180 printf ("else");
2181 start_brace ();
2182 printf ("m68k_dreg(regs, rc) = dst;\n");
2183 pop_braces (old_brace_level);
2184 }
2185 break;
2186 case i_CAS2:
2187 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2188 printf ("\tuae_u32 rn1 = regs.regs[(extra >> 28) & 15];\n");
2189 printf ("\tuae_u32 rn2 = regs.regs[(extra >> 12) & 15];\n");
2190 if (curi->size == sz_word) {
2191 int old_brace_level = n_braces;
2192 printf ("\tuae_u16 dst1 = get_word(rn1), dst2 = get_word(rn2);\n");
2193 genflags (flag_cmp, curi->size, "newv", "m68k_dreg(regs, (extra >> 16) & 7)", "dst1");
2194 printf ("\tif (GET_ZFLG) {\n");
2195 genflags (flag_cmp, curi->size, "newv", "m68k_dreg(regs, extra & 7)", "dst2");
2196 printf ("\tif (GET_ZFLG) {\n");
2197 printf ("\tput_word(rn1, m68k_dreg(regs, (extra >> 22) & 7));\n");
2198 printf ("\tput_word(rn1, m68k_dreg(regs, (extra >> 6) & 7));\n");
2199 printf ("\t}}\n");
2200 pop_braces (old_brace_level);
2201 printf ("\tif (! GET_ZFLG) {\n");
2202 printf ("\tm68k_dreg(regs, (extra >> 22) & 7) = (m68k_dreg(regs, (extra >> 22) & 7) & ~0xffff) | (dst1 & 0xffff);\n");
2203 printf ("\tm68k_dreg(regs, (extra >> 6) & 7) = (m68k_dreg(regs, (extra >> 6) & 7) & ~0xffff) | (dst2 & 0xffff);\n");
2204 printf ("\t}\n");
2205 } else {
2206 int old_brace_level = n_braces;
2207 printf ("\tuae_u32 dst1 = get_long(rn1), dst2 = get_long(rn2);\n");
2208 genflags (flag_cmp, curi->size, "newv", "m68k_dreg(regs, (extra >> 16) & 7)", "dst1");
2209 printf ("\tif (GET_ZFLG) {\n");
2210 genflags (flag_cmp, curi->size, "newv", "m68k_dreg(regs, extra & 7)", "dst2");
2211 printf ("\tif (GET_ZFLG) {\n");
2212 printf ("\tput_long(rn1, m68k_dreg(regs, (extra >> 22) & 7));\n");
2213 printf ("\tput_long(rn1, m68k_dreg(regs, (extra >> 6) & 7));\n");
2214 printf ("\t}}\n");
2215 pop_braces (old_brace_level);
2216 printf ("\tif (! GET_ZFLG) {\n");
2217 printf ("\tm68k_dreg(regs, (extra >> 22) & 7) = dst1;\n");
2218 printf ("\tm68k_dreg(regs, (extra >> 6) & 7) = dst2;\n");
2219 printf ("\t}\n");
2220 }
2221 break;
2222 case i_MOVES: /* ignore DFC and SFC because we have no MMU */
2223 {
2224 int old_brace_level;
2225 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2226 printf ("\tif (extra & 0x800)\n");
2227 old_brace_level = n_braces;
2228 start_brace ();
2229 printf ("\tuae_u32 src = regs.regs[(extra >> 12) & 15];\n");
2230 genamode (curi->dmode, "dstreg", curi->size, "dst", 2, 0);
2231 genastore ("src", curi->dmode, "dstreg", curi->size, "dst");
2232 pop_braces (old_brace_level);
2233 printf ("else");
2234 start_brace ();
2235 genamode (curi->dmode, "dstreg", curi->size, "src", 1, 0);
2236 printf ("\tif (extra & 0x8000) {\n");
2237 switch (curi->size) {
2238 case sz_byte: printf ("\tm68k_areg(regs, (extra >> 12) & 7) = (uae_s32)(uae_s8)src;\n"); break;
2239 case sz_word: printf ("\tm68k_areg(regs, (extra >> 12) & 7) = (uae_s32)(uae_s16)src;\n"); break;
2240 case sz_long: printf ("\tm68k_areg(regs, (extra >> 12) & 7) = src;\n"); break;
2241 default: abort ();
2242 }
2243 printf ("\t} else {\n");
2244 genastore ("src", Dreg, "(extra >> 12) & 7", curi->size, "");
2245 printf ("\t}\n");
2246 pop_braces (old_brace_level);
2247 }
2248 break;
2249 case i_BKPT: /* only needed for hardware emulators */
2250 sync_m68k_pc ();
2251 printf ("\top_illg(opcode);\n");
2252 break;
2253 case i_CALLM: /* not present in 68030 */
2254 sync_m68k_pc ();
2255 printf ("\top_illg(opcode);\n");
2256 break;
2257 case i_RTM: /* not present in 68030 */
2258 sync_m68k_pc ();
2259 printf ("\top_illg(opcode);\n");
2260 break;
2261 case i_TRAPcc:
2262 if (curi->smode != am_unknown && curi->smode != am_illg)
2263 genamode (curi->smode, "srcreg", curi->size, "dummy", 1, 0);
2264 printf ("\tif (cctrue(%d)) { Exception(7,m68k_getpc()); goto %s; }\n", curi->cc, endlabelstr);
2265 need_endlabel = 1;
2266 break;
2267 case i_DIVL:
2268 sync_m68k_pc ();
2269 start_brace ();
2270 printf ("\tuaecptr oldpc = m68k_getpc();\n");
2271 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2272 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
2273 sync_m68k_pc ();
2274 printf ("\tm68k_divl(opcode, dst, extra, oldpc);\n");
2275 break;
2276 case i_MULL:
2277 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2278 genamode (curi->dmode, "dstreg", curi->size, "dst", 1, 0);
2279 sync_m68k_pc ();
2280 printf ("\tm68k_mull(opcode, dst, extra);\n");
2281 break;
2282 case i_BFTST:
2283 case i_BFEXTU:
2284 case i_BFCHG:
2285 case i_BFEXTS:
2286 case i_BFCLR:
2287 case i_BFFFO:
2288 case i_BFSET:
2289 case i_BFINS:
2290 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2291 genamode (curi->dmode, "dstreg", sz_long, "dst", 2, 0);
2292 start_brace ();
2293 printf ("\tuae_s32 offset = extra & 0x800 ? m68k_dreg(regs, (extra >> 6) & 7) : (extra >> 6) & 0x1f;\n");
2294 printf ("\tint width = (((extra & 0x20 ? m68k_dreg(regs, extra & 7) : extra) -1) & 0x1f) +1;\n");
2295 if (curi->dmode == Dreg) {
2296 printf ("\tuae_u32 tmp = m68k_dreg(regs, dstreg) << (offset & 0x1f);\n");
2297 } else {
2298 printf ("\tuae_u32 tmp,bf0,bf1;\n");
2299 printf ("\tdsta += (offset >> 3) | (offset & 0x80000000 ? ~0x1fffffff : 0);\n");
2300 printf ("\tbf0 = get_long(dsta);bf1 = get_byte(dsta+4) & 0xff;\n");
2301 printf ("\ttmp = (bf0 << (offset & 7)) | (bf1 >> (8 - (offset & 7)));\n");
2302 }
2303 printf ("\ttmp >>= (32 - width);\n");
2304 printf ("\tSET_NFLG (tmp & (1 << (width-1)) ? 1 : 0);\n");
2305 printf ("\tSET_ZFLG (tmp == 0); SET_VFLG (0); SET_CFLG (0);\n");
2306 switch (curi->mnemo) {
2307 case i_BFTST:
2308 break;
2309 case i_BFEXTU:
2310 printf ("\tm68k_dreg(regs, (extra >> 12) & 7) = tmp;\n");
2311 break;
2312 case i_BFCHG:
2313 printf ("\ttmp = ~tmp;\n");
2314 break;
2315 case i_BFEXTS:
2316 printf ("\tif (GET_NFLG) tmp |= width == 32 ? 0 : (-1 << width);\n");
2317 printf ("\tm68k_dreg(regs, (extra >> 12) & 7) = tmp;\n");
2318 break;
2319 case i_BFCLR:
2320 printf ("\ttmp = 0;\n");
2321 break;
2322 case i_BFFFO:
2323 printf ("\t{ uae_u32 mask = 1 << (width-1);\n");
2324 printf ("\twhile (mask) { if (tmp & mask) break; mask >>= 1; offset++; }}\n");
2325 printf ("\tm68k_dreg(regs, (extra >> 12) & 7) = offset;\n");
2326 break;
2327 case i_BFSET:
2328 printf ("\ttmp = 0xffffffff;\n");
2329 break;
2330 case i_BFINS:
2331 printf ("\ttmp = m68k_dreg(regs, (extra >> 12) & 7);\n");
2332 break;
2333 default:
2334 break;
2335 }
2336 if (curi->mnemo == i_BFCHG
2337 || curi->mnemo == i_BFCLR
2338 || curi->mnemo == i_BFSET
2339 || curi->mnemo == i_BFINS)
2340 {
2341 printf ("\ttmp <<= (32 - width);\n");
2342 if (curi->dmode == Dreg) {
2343 printf ("\tm68k_dreg(regs, dstreg) = (m68k_dreg(regs, dstreg) & ((offset & 0x1f) == 0 ? 0 :\n");
2344 printf ("\t\t(0xffffffff << (32 - (offset & 0x1f))))) |\n");
2345 printf ("\t\t(tmp >> (offset & 0x1f)) |\n");
2346 printf ("\t\t(((offset & 0x1f) + width) >= 32 ? 0 :\n");
2347 printf (" (m68k_dreg(regs, dstreg) & ((uae_u32)0xffffffff >> ((offset & 0x1f) + width))));\n");
2348 } else {
2349 printf ("\tbf0 = (bf0 & (0xff000000 << (8 - (offset & 7)))) |\n");
2350 printf ("\t\t(tmp >> (offset & 7)) |\n");
2351 printf ("\t\t(((offset & 7) + width) >= 32 ? 0 :\n");
2352 printf ("\t\t (bf0 & ((uae_u32)0xffffffff >> ((offset & 7) + width))));\n");
2353 printf ("\tput_long(dsta,bf0 );\n");
2354 printf ("\tif (((offset & 7) + width) > 32) {\n");
2355 printf ("\t\tbf1 = (bf1 & (0xff >> (width - 32 + (offset & 7)))) |\n");
2356 printf ("\t\t\t(tmp << (8 - (offset & 7)));\n");
2357 printf ("\t\tput_byte(dsta+4,bf1);\n");
2358 printf ("\t}\n");
2359 }
2360 }
2361 break;
2362 case i_PACK:
2363 if (curi->smode == Dreg) {
2364 printf ("\tuae_u16 val = m68k_dreg(regs, srcreg) + %s;\n", gen_nextiword ());
2365 printf ("\tm68k_dreg(regs, dstreg) = (m68k_dreg(regs, dstreg) & 0xffffff00) | ((val >> 4) & 0xf0) | (val & 0xf);\n");
2366 } else {
2367 printf ("\tuae_u16 val;\n");
2368 printf ("\tm68k_areg(regs, srcreg) -= areg_byteinc[srcreg];\n");
2369 printf ("\tval = (uae_u16)get_byte(m68k_areg(regs, srcreg));\n");
2370 printf ("\tm68k_areg(regs, srcreg) -= areg_byteinc[srcreg];\n");
2371 printf ("\tval = (val | ((uae_u16)get_byte(m68k_areg(regs, srcreg)) << 8)) + %s;\n", gen_nextiword ());
2372 printf ("\tm68k_areg(regs, dstreg) -= areg_byteinc[dstreg];\n");
2373 printf ("\tput_byte(m68k_areg(regs, dstreg),((val >> 4) & 0xf0) | (val & 0xf));\n");
2374 }
2375 break;
2376 case i_UNPK:
2377 if (curi->smode == Dreg) {
2378 printf ("\tuae_u16 val = m68k_dreg(regs, srcreg);\n");
2379 printf ("\tval = (((val << 4) & 0xf00) | (val & 0xf)) + %s;\n", gen_nextiword ());
2380 printf ("\tm68k_dreg(regs, dstreg) = (m68k_dreg(regs, dstreg) & 0xffff0000) | (val & 0xffff);\n");
2381 } else {
2382 printf ("\tuae_u16 val;\n");
2383 printf ("\tm68k_areg(regs, srcreg) -= areg_byteinc[srcreg];\n");
2384 printf ("\tval = (uae_u16)get_byte(m68k_areg(regs, srcreg));\n");
2385 printf ("\tval = (((val << 4) & 0xf00) | (val & 0xf)) + %s;\n", gen_nextiword ());
2386 printf ("\tm68k_areg(regs, dstreg) -= areg_byteinc[dstreg];\n");
2387 printf ("\tput_byte(m68k_areg(regs, dstreg),val);\n");
2388 printf ("\tm68k_areg(regs, dstreg) -= areg_byteinc[dstreg];\n");
2389 printf ("\tput_byte(m68k_areg(regs, dstreg),val >> 8);\n");
2390 }
2391 break;
2392 case i_TAS:
2393 genamode (curi->smode, "srcreg", curi->size, "src", 1, 0);
2394 genflags (flag_logical, curi->size, "src", "", "");
2395 printf ("\tsrc |= 0x80;\n");
2396 genastore ("src", curi->smode, "srcreg", curi->size, "src");
2397 break;
2398 case i_FPP:
2399 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2400 sync_m68k_pc ();
2401 swap_opcode ();
2402 printf ("\tfpp_opp(opcode,extra);\n");
2403 break;
2404 case i_FDBcc:
2405 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2406 sync_m68k_pc ();
2407 swap_opcode ();
2408 printf ("\tfdbcc_opp(opcode,extra);\n");
2409 break;
2410 case i_FScc:
2411 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2412 sync_m68k_pc ();
2413 swap_opcode ();
2414 printf ("\tfscc_opp(opcode,extra);\n");
2415 break;
2416 case i_FTRAPcc:
2417 sync_m68k_pc ();
2418 start_brace ();
2419 printf ("\tuaecptr oldpc = m68k_getpc();\n");
2420 if (curi->smode != am_unknown && curi->smode != am_illg)
2421 genamode (curi->smode, "srcreg", curi->size, "dummy", 1, 0);
2422 sync_m68k_pc ();
2423 swap_opcode ();
2424 printf ("\tftrapcc_opp(opcode,oldpc);\n");
2425 break;
2426 case i_FBcc:
2427 sync_m68k_pc ();
2428 start_brace ();
2429 printf ("\tuaecptr pc = m68k_getpc();\n");
2430 genamode (curi->dmode, "srcreg", curi->size, "extra", 1, 0);
2431 sync_m68k_pc ();
2432 swap_opcode ();
2433 printf ("\tfbcc_opp(opcode,pc,extra);\n");
2434 break;
2435 case i_FSAVE:
2436 sync_m68k_pc ();
2437 swap_opcode ();
2438 printf ("\tfsave_opp(opcode);\n");
2439 break;
2440 case i_FRESTORE:
2441 sync_m68k_pc ();
2442 swap_opcode ();
2443 printf ("\tfrestore_opp(opcode);\n");
2444 break;
2445 case i_MMUOP:
2446 genamode (curi->smode, "srcreg", curi->size, "extra", 1, 0);
2447 sync_m68k_pc ();
2448 swap_opcode ();
2449 printf ("\tmmu_op(opcode,extra);\n");
2450 break;
2451 default:
2452 abort ();
2453 break;
2454 }
2455 finish_braces ();
2456 sync_m68k_pc ();
2457 }
2458
2459 static void generate_includes (FILE * f)
2460 {
2461 fprintf (f, "#include \"sysdeps.h\"\n");
2462 fprintf (f, "#include \"m68k.h\"\n");
2463 fprintf (f, "#include \"memory.h\"\n");
2464 fprintf (f, "#include \"readcpu.h\"\n");
2465 fprintf (f, "#include \"newcpu.h\"\n");
2466 fprintf (f, "#include \"compiler.h\"\n");
2467 fprintf (f, "#include \"cputbl.h\"\n");
2468 }
2469
2470 static int postfix;
2471
2472 static void generate_one_opcode (int rp)
2473 {
2474 int i;
2475 uae_u16 smsk, dmsk;
2476 long int opcode = opcode_map[rp];
2477
2478 if (table68k[opcode].mnemo == i_ILLG
2479 || table68k[opcode].clev > cpu_level)
2480 return;
2481
2482 for (i = 0; lookuptab[i].name[0]; i++) {
2483 if (table68k[opcode].mnemo == lookuptab[i].mnemo)
2484 break;
2485 }
2486
2487 if (table68k[opcode].handler != -1)
2488 return;
2489
2490 if (opcode_next_clev[rp] != cpu_level) {
2491 fprintf (stblfile, "{ op_%lx_%d, 0, %ld }, /* %s */\n", opcode, opcode_last_postfix[rp],
2492 opcode, lookuptab[i].name);
2493 return;
2494 }
2495 fprintf (stblfile, "{ op_%lx_%d, 0, %ld }, /* %s */\n", opcode, postfix, opcode, lookuptab[i].name);
2496 fprintf (headerfile, "extern cpuop_func op_%lx_%d;\n", opcode, postfix);
2497 /* fprintf (headerfile, "extern unsigned long REGPARAM2 op_%lx_%d(uae_u32);\n", opcode, postfix); */
2498 printf ("unsigned long REGPARAM2 op_%lx_%d(uae_u32 opcode) /* %s */\n{\n", opcode, postfix, lookuptab[i].name);
2499
2500 switch (table68k[opcode].stype) {
2501 case 0: smsk = 7; break;
2502 case 1: smsk = 255; break;
2503 case 2: smsk = 15; break;
2504 case 3: smsk = 7; break;
2505 case 4: smsk = 7; break;
2506 case 5: smsk = 63; break;
2507 default: abort ();
2508 }
2509 dmsk = 7;
2510
2511 next_cpu_level = -1;
2512 if (table68k[opcode].suse
2513 && table68k[opcode].smode != imm && table68k[opcode].smode != imm0
2514 && table68k[opcode].smode != imm1 && table68k[opcode].smode != imm2
2515 && table68k[opcode].smode != absw && table68k[opcode].smode != absl
2516 && table68k[opcode].smode != PC8r && table68k[opcode].smode != PC16)
2517 {
2518 if (table68k[opcode].spos == -1) {
2519 if (((int) table68k[opcode].sreg) >= 128)
2520 printf ("\tuae_u32 srcreg = (uae_s32)(uae_s8)%d;\n", (int) table68k[opcode].sreg);
2521 else
2522 printf ("\tuae_u32 srcreg = %d;\n", (int) table68k[opcode].sreg);
2523 } else {
2524 char source[100];
2525 int pos = table68k[opcode].spos;
2526
2527 #if 0
2528 /* Check that we can do the little endian optimization safely. */
2529 if (pos < 8 && (smsk >> (8 - pos)) != 0)
2530 abort ();
2531 #endif
2532 printf ("#ifdef HAVE_GET_WORD_UNSWAPPED\n");
2533
2534 if (pos < 8 && (smsk >> (8 - pos)) != 0)
2535 sprintf (source, "(((opcode >> %d) | (opcode << %d)) & %d)",
2536 pos ^ 8, 8 - pos, dmsk);
2537 else if (pos != 8)
2538 sprintf (source, "((opcode >> %d) & %d)", pos ^ 8, smsk);
2539 else
2540 sprintf (source, "(opcode & %d)", smsk);
2541
2542 if (table68k[opcode].stype == 3)
2543 printf ("\tuae_u32 srcreg = imm8_table[%s];\n", source);
2544 else if (table68k[opcode].stype == 1)
2545 printf ("\tuae_u32 srcreg = (uae_s32)(uae_s8)%s;\n", source);
2546 else
2547 printf ("\tuae_u32 srcreg = %s;\n", source);
2548
2549 printf ("#else\n");
2550
2551 if (pos)
2552 sprintf (source, "((opcode >> %d) & %d)", pos, smsk);
2553 else
2554 sprintf (source, "(opcode & %d)", smsk);
2555
2556 if (table68k[opcode].stype == 3)
2557 printf ("\tuae_u32 srcreg = imm8_table[%s];\n", source);
2558 else if (table68k[opcode].stype == 1)
2559 printf ("\tuae_u32 srcreg = (uae_s32)(uae_s8)%s;\n", source);
2560 else
2561 printf ("\tuae_u32 srcreg = %s;\n", source);
2562
2563 printf ("#endif\n");
2564 }
2565 }
2566 if (table68k[opcode].duse
2567 /* Yes, the dmode can be imm, in case of LINK or DBcc */
2568 && table68k[opcode].dmode != imm && table68k[opcode].dmode != imm0
2569 && table68k[opcode].dmode != imm1 && table68k[opcode].dmode != imm2
2570 && table68k[opcode].dmode != absw && table68k[opcode].dmode != absl)
2571 {
2572 if (table68k[opcode].dpos == -1) {
2573 if (((int) table68k[opcode].dreg) >= 128)
2574 printf ("\tuae_u32 dstreg = (uae_s32)(uae_s8)%d;\n", (int) table68k[opcode].dreg);
2575 else
2576 printf ("\tuae_u32 dstreg = %d;\n", (int) table68k[opcode].dreg);
2577 } else {
2578 int pos = table68k[opcode].dpos;
2579 #if 0
2580 /* Check that we can do the little endian optimization safely. */
2581 if (pos < 8 && (dmsk >> (8 - pos)) != 0)
2582 abort ();
2583 #endif
2584 printf ("#ifdef HAVE_GET_WORD_UNSWAPPED\n");
2585
2586 if (pos < 8 && (dmsk >> (8 - pos)) != 0)
2587 printf ("\tuae_u32 dstreg = ((opcode >> %d) | (opcode << %d)) & %d;\n",
2588 pos ^ 8, 8 - pos, dmsk);
2589 else if (pos != 8)
2590 printf ("\tuae_u32 dstreg = (opcode >> %d) & %d;\n",
2591 pos ^ 8, dmsk);
2592 else
2593 printf ("\tuae_u32 dstreg = opcode & %d;\n", dmsk);
2594
2595 printf ("#else\n");
2596
2597 if (pos)
2598 printf ("\tuae_u32 dstreg = (opcode >> %d) & %d;\n",
2599 pos, dmsk);
2600 else
2601 printf ("\tuae_u32 dstreg = opcode & %d;\n", dmsk);
2602
2603 printf ("#endif\n");
2604 }
2605 }
2606 need_endlabel = 0;
2607 endlabelno++;
2608 sprintf (endlabelstr, "endlabel%d", endlabelno);
2609 gen_opcode (opcode);
2610 if (need_endlabel)
2611 printf ("%s: ;\n", endlabelstr);
2612 printf ("return %d;\n", insn_n_cycles);
2613 printf ("}\n");
2614 opcode_next_clev[rp] = next_cpu_level;
2615 opcode_last_postfix[rp] = postfix;
2616 }
2617
2618 static void generate_func (void)
2619 {
2620 int i, j, rp;
2621
2622 using_prefetch = 0;
2623 using_exception_3 = 0;
2624 for (i = 0; i < 5; i++) {
2625 cpu_level = 3 - i;
2626 if (i == 4) {
2627 cpu_level = 0;
2628 using_prefetch = 1;
2629 using_exception_3 = 1;
2630 for (rp = 0; rp < nr_cpuop_funcs; rp++)
2631 opcode_next_clev[rp] = 0;
2632 }
2633 postfix = i;
2634 fprintf (stblfile, "struct cputbl op_smalltbl_%d[] = {\n", postfix);
2635
2636 /* sam: this is for people with low memory (eg. me :)) */
2637 printf ("\n"
2638 "#if !defined(PART_1) && !defined(PART_2) && "
2639 "!defined(PART_3) && !defined(PART_4) && "
2640 "!defined(PART_5) && !defined(PART_6) && "
2641 "!defined(PART_7) && !defined(PART_8)"
2642 "\n"
2643 "#define PART_1 1\n"
2644 "#define PART_2 1\n"
2645 "#define PART_3 1\n"
2646 "#define PART_4 1\n"
2647 "#define PART_5 1\n"
2648 "#define PART_6 1\n"
2649 "#define PART_7 1\n"
2650 "#define PART_8 1\n"
2651 "#endif\n\n");
2652
2653 rp = 0;
2654 for(j=1;j<=8;++j) {
2655 int k = (j*nr_cpuop_funcs)/8;
2656 printf ("#ifdef PART_%d\n",j);
2657 for (; rp < k; rp++)
2658 generate_one_opcode (rp);
2659 printf ("#endif\n\n");
2660 }
2661
2662 fprintf (stblfile, "{ 0, 0, 0 }};\n");
2663 }
2664 }
2665
2666 int main (int argc, char **argv)
2667 {
2668 read_table68k ();
2669 do_merges ();
2670
2671 opcode_map = (int *) malloc (sizeof (int) * nr_cpuop_funcs);
2672 opcode_last_postfix = (int *) malloc (sizeof (int) * nr_cpuop_funcs);
2673 opcode_next_clev = (int *) malloc (sizeof (int) * nr_cpuop_funcs);
2674 counts = (unsigned long *) malloc (65536 * sizeof (unsigned long));
2675 read_counts ();
2676
2677 /* It would be a lot nicer to put all in one file (we'd also get rid of
2678 * cputbl.h that way), but cpuopti can't cope. That could be fixed, but
2679 * I don't dare to touch the 68k version. */
2680
2681 headerfile = fopen ("cputbl.h", "wb");
2682 stblfile = fopen ("cpustbl.cpp", "wb");
2683 freopen ("cpuemu.cpp", "wb", stdout);
2684
2685 generate_includes (stdout);
2686 generate_includes (stblfile);
2687
2688 generate_func ();
2689
2690 free (table68k);
2691 return 0;
2692 }