home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 6 / AACD06.ISO / AACD / Emulation / BasiliskII / src / uae_cpu / gencpu.c < prev    next >
C/C++ Source or Header  |  1999-11-03  |  90KB  |  2,711 lines

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