ViewVC Help
View File | Revision Log | Show Annotations | Revision Graph | Root Listing
root/cebix/BasiliskII/src/uae_cpu/gencpu.c
Revision: 1.1.1.1 (vendor branch)
Committed: 1999-10-03T14:16:26Z (25 years, 1 month ago) by cebix
Content type: text/plain
Branch: cebix
CVS Tags: release-0_7-2, start
Changes since 1.1: +0 -0 lines
Log Message:
Imported sources

File Contents

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