]> Shamusworld >> Repos - rmac/blobdiff - mach.c
Get rid of some old and deprecated macros
[rmac] / mach.c
diff --git a/mach.c b/mach.c
index 7c1ab8ea6ae7e1d750f1233ec36875c97721cadb..3c7a30c17fc319a74fc978960ad879e1becaf87a 100644 (file)
--- a/mach.c
+++ b/mach.c
@@ -1,7 +1,7 @@
 //
-// RMAC - Reboot's Macro Assembler for all Atari computers
+// RMAC - Renamed Macro Assembler for all Atari computers
 // MACH.C - Code Generation
-// Copyright (C) 199x Landon Dyer, 2011-2017 Reboot and Friends
+// Copyright (C) 199x Landon Dyer, 2011-2021 Reboot and Friends
 // RMAC derived from MADMAC v1.07 Written by Landon Dyer, 1986
 // Source utilised with the kind permission of Landon Dyer
 //
@@ -60,7 +60,7 @@ int m_cas2(WORD inst, WORD siz);
 int m_chk2(WORD inst, WORD siz);
 int m_cmp2(WORD inst, WORD siz);
 int m_bkpt(WORD inst, WORD siz);
-int m_cpbr(WORD inst, WORD siz);
+int m_cpbcc(WORD inst, WORD siz);
 int m_cpdbr(WORD inst, WORD siz);
 int m_muls(WORD inst, WORD siz);
 int m_move16a(WORD inst, WORD siz);
@@ -85,13 +85,16 @@ int m_pflushan(WORD inst, WORD siz);
 int m_pload(WORD inst, WORD siz, WORD extension);
 int m_pmove(WORD inst, WORD siz);
 int m_pmovefd(WORD inst, WORD siz);
-int m_ptest(WORD inst, WORD siz);
+int m_ptest(WORD inst, WORD siz, WORD extension);
+int m_ptestr(WORD inste, WORD siz);
+int m_ptestw(WORD inste, WORD siz);
 int m_ptrapcc(WORD inst, WORD siz);
 int m_ploadr(WORD inst, WORD siz);
 int m_ploadw(WORD inst, WORD siz);
 
 // FPU
 int m_fabs(WORD inst, WORD siz);
+int m_fbcc(WORD inst, WORD siz);
 int m_facos(WORD inst, WORD siz);
 int m_fadd(WORD inst, WORD siz);
 int m_fasin(WORD inst, WORD siz);
@@ -349,9 +352,12 @@ int m_lea(WORD inst, WORD siz)
                && ((am0 == ADISP) && (a0reg == a1reg) && (a0exattr & DEFINED))
                && ((a0exval > 0) && (a0exval <= 8)))
        {
-               inst = B16(01010000, 01001000) | (((uint16_t)a0exval & 7) << 9) | (a0reg);
+               inst = 0b0101000001001000 | (((uint16_t)a0exval & 7) << 9) | (a0reg);
                D_word(inst);
-               warn("lea size(An),An converted to addq #size,An");
+
+               if (optim_warn_flag)
+                       warn("o4: lea size(An),An converted to addq #size,An");
+
                return OK;
        }
 
@@ -455,19 +461,45 @@ int m_abcd(WORD inst, WORD siz)
 //
 int m_adda(WORD inst, WORD siz)
 {
-       if (a0exattr & DEFINED)
+       if ((a0exattr & DEFINED) && (am0 == IMMED))
        {
-               if (CHECK_OPTS(OPT_ADDA_ADDQ))
-                       if (a0exval > 1 && a0exval <= 8)
+               if (CHECK_OPTS(OPT_ADDA_ADDQ))
+               {
+                       if ((a0exval > 1) && (a0exval <= 8))
+                       {
                                // Immediate is between 1 and 8 so let's convert to addq
-                               return m_addq(B16(01010000, 00000000), siz);
-       if (CHECK_OPTS(OPT_ADDA_LEA))
-               if (a0exval > 8)
-               {
-                       // Immediate is larger than 8 so let's convert to lea
-                       am0 = ADISP;    // Change addressing mode
-                       a0reg = a1reg;  // In ADISP a0reg is used instead of a1reg!
-                       return m_lea(B16(01000001, 11011000), SIZW);
+                               return m_addq(0b0101000000000000, siz);
+
+                               if (optim_warn_flag)
+                                       warn("o8: adda/suba size(An),An converted to addq/subq #size,An");
+                       }
+               }
+
+               if (CHECK_OPTS(OPT_ADDA_LEA))
+               {
+                       if ((a0exval > 8) && ((a0exval + 0x8000) < 0x10000))
+                       {
+                               // Immediate is larger than 8 and word size so let's convert to lea
+                               am0 = ADISP;    // Change addressing mode
+                               a0reg = a1reg;  // In ADISP a0reg is used instead of a1reg!
+
+                               if (!(inst & (1 << 14)))
+                               {
+                                       // We have a suba #x,AREG so let's negate the value
+                                       a0exval = -a0exval;
+                               }
+
+                               // We're going to rely on +o4 for this, so let's ensure that
+                               // it's on, even just for this instruction
+                               int return_value;
+                               int temp_flag = optim_flags[OPT_LEA_ADDQ];
+                               optim_flags[OPT_LEA_ADDQ] = 1;                          // Temporarily save switch state
+                               return_value = m_lea(0b0100000111011000, SIZW);
+                               optim_flags[OPT_LEA_ADDQ] = temp_flag;          // Restore switch state
+                               if (optim_warn_flag)
+                                       warn("o9: adda.w/l #x,Ay converted to lea x(Dy),Ay");
+                               return return_value;
+                       }
                }
        }
 
@@ -724,8 +756,8 @@ int m_move(WORD inst, WORD size)
        {
                m_moveq((WORD)0x7000, (WORD)0);
 
-               if (sbra_flag)
-                       warn("move.l #size,dx converted to moveq");
+               if (optim_warn_flag)
+                       warn("o1: move.l #size,dx converted to moveq");
        }
        else
        {
@@ -766,7 +798,11 @@ int m_move(WORD inst, WORD size)
 int m_move30(WORD inst, WORD size)
 {
        int siz = (int)size;
-       inst |= siz_12[siz] | reg_9[a1reg & 7] | a0reg | extra_addressing[am0 - ABASE];
+
+       if (am0 > ABASE)
+               inst |= siz_12[siz] | reg_9[a1reg & 7] | a0reg | extra_addressing[am0 - ABASE];
+       else
+               inst |= siz_12[siz] | reg_9[a1reg & 7] | a0reg | extra_addressing[am1 - ABASE] << 3;
 
        D_word(inst);
 
@@ -882,8 +918,8 @@ int m_br(WORD inst, WORD siz)
                                inst |= v & 0xFF;
                                D_word(inst);
 
-                               if (sbra_flag)
-                                       warn("Bcc.w/BSR.w converted to .s");
+                               if (optim_warn_flag)
+                                       warn("o2: Bcc.w/BSR.w converted to .s");
 
                                return OK;
                        }
@@ -925,7 +961,21 @@ int m_br(WORD inst, WORD siz)
        {
                // .B
                AddFixup(FU_BBRA | FU_PCREL | FU_SEXT, sloc, a0expr);
-               D_word(inst);
+               // So here we have a small issue: this bra.s could be zero offset, but
+               // we can never know. Because unless we know beforehand that the
+               // offset will be zero (i.e. "bra.s +0"), it's going to be a label
+               // below this instruction! We do have an optimisation flag that can
+               // check against this during fixups, but we cannot rely on the state
+               // of the flag after all the file(s) have been processed because its
+               // state might have changed multiple times during file parsing. (Yes,
+               // there's a very low chance that this will ever happen but it's not
+               // zero!). So, we can use the byte that is going to be filled during
+               // fixups to store the state of the optimisation flag and read it
+               // during that stage so each bra.s will have its state stored neatly.
+               // Sleazy? Eh, who cares, like this will ever happen ;)
+               // One final note: we'd better be damn sure that the flag's value is
+               // less than 256 or magical stuff will happen!
+               D_word(inst | optim_flags[OPT_NULL_BRA]);
                return OK;
        }
        else
@@ -1113,7 +1163,11 @@ int m_clrd(WORD inst, WORD siz)
        if (!CHECK_OPTS(OPT_CLR_DX))
                inst |= a0reg;
        else
-               inst = (a0reg << 9) | B16(01110000, 00000000);
+       {
+               inst = (a0reg << 9) | 0b0111000000000000;
+               if (optim_warn_flag)
+                       warn("o7: clr.l Dx converted to moveq #0,Dx");
+       }
 
        D_word(inst);
 
@@ -1185,7 +1239,7 @@ int m_bfop(WORD inst, WORD siz)
                bfparam1 = bfval1 << 12;
 
        //D_word((inst | am0 | a0reg | am1 | a1reg));
-       if (inst == B16(11101111, 11000000))
+       if (inst == 0b1110111111000000)
        {
                // bfins special case
                D_word((inst | am1 | a1reg));
@@ -1198,7 +1252,7 @@ int m_bfop(WORD inst, WORD siz)
        ea0gen(siz);    // Generate EA
 
        // Second instruction word - Dest register (if exists), Do, Offset, Dw, Width
-       if (inst == B16(11101111, 11000000))
+       if (inst == 0b1110111111000000)
        {
                // bfins special case
                inst = bfparam1 | bfparam2;
@@ -1542,13 +1596,10 @@ int m_chk2(WORD inst, WORD siz)
 
 
 //
-// cpbcc(68020, 68030, 68040 (FBcc), 68060 (FBcc))
-// TODO: Better checks for different instructions?
+// cpbcc(68020, 68030, 68040 (FBcc), 68060 (FBcc)), pbcc (68851)
 //
-int m_cpbr(WORD inst, WORD siz)
+int m_fpbr(WORD inst, WORD siz)
 {
-       if ((activecpu & (CPU_68020 | CPU_68030)) && (!activefpu == 0))
-               return error(unsupport);
 
        if (a0exattr & DEFINED)
        {
@@ -1602,6 +1653,38 @@ int m_cpbr(WORD inst, WORD siz)
 }
 
 
+//
+// cpbcc(68020, 68030, 68040 (FBcc), 68060 (FBcc))
+//
+int m_cpbcc(WORD inst, WORD siz)
+{
+       if (!(activecpu & (CPU_68020 | CPU_68030)))
+               return error(unsupport);
+
+       return m_fpbr(inst, siz);
+}
+
+
+//
+// fbcc(6808X, 68040, 68060)
+//
+int m_fbcc(WORD inst, WORD siz)
+{
+       CHECKNOFPU;
+       return m_fpbr(inst, siz);
+}
+
+
+//
+// pbcc(68851 but let's assume 68020 only)
+//
+int m_pbcc(WORD inst, WORD siz)
+{
+       CHECKNO20;
+       return m_fpbr(inst, siz);
+}
+
+
 //
 // cpdbcc(68020, 68030)
 //
@@ -2109,16 +2192,6 @@ int m_moves(WORD inst, WORD siz)
 }
 
 
-//
-// PBcc (MC68851)
-//
-int m_pbcc(WORD inst, WORD siz)
-{
-       CHECKNO20;
-       return error("Not implemented yet.");
-}
-
-
 //
 // pflusha (68030, 68040)
 //
@@ -2133,7 +2206,7 @@ int m_pflusha(WORD inst, WORD siz)
        }
        else if (activecpu == CPU_68040)
        {
-               inst = B16(11110101, 00011000);
+               inst = 0b1111010100011000;
                D_word(inst);
                return OK;
        }
@@ -2344,7 +2417,7 @@ int m_pflushr(WORD inst, WORD siz)
                        ea1gen(siz);
        }
 
-       D_word(B16(10100000, 00000000));
+       D_word(0b1010000000000000);
        return OK;
 }
 
@@ -2371,7 +2444,6 @@ int m_pload(WORD inst, WORD siz, WORD extension)
                        inst = 1;
                else
                        return error("illegal control register specified");
-
                break;
        case DREG:
                inst = (1 << 3) | a0reg;
@@ -2380,6 +2452,9 @@ int m_pload(WORD inst, WORD siz, WORD extension)
                if ((a0exattr & DEFINED) == 0)
                        return error("constant value must be defined");
 
+               if (a0exval>7)
+               return error("constant value must be between 0 and 7");
+
                inst = (2 << 3) | (uint16_t)a0exval;
                break;
        }
@@ -2543,20 +2618,103 @@ int m_ptrapcc(WORD inst, WORD siz)
 
 
 //
-// ptestr, ptestw (68030)
+// ptestr, ptestw (68030, 68040)
+// TODO See comment on m_pmove about 68851 support
+// TODO quite a good chunk of the 030 code is copied from m_pload, perhaps merge these somehow?
 //
-int m_ptest(WORD inst, WORD siz)
+int m_ptest(WORD inst, WORD siz, WORD extension)
 {
-       CHECKNO30;
+       uint64_t eval;
+
+       if (activecpu != CPU_68030 && activecpu != CPU_68040)
+               return error(unsupport);
 
        if (activecpu == CPU_68030)
-               return error("Not implemented yet.");
-       else if (activecpu == CPU_68040)
+       {
+               inst |= am1;
+               D_word(inst);
+
+               switch (am0)
+               {
+               case CREG:
+                       if (a0reg == KW_SFC - KW_SFC)
+                               extension |= 0;
+                       else if (a0reg == KW_DFC - KW_SFC)
+                               extension |= 1;
+                       else
+                               return error("illegal control register specified");
+                       break;
+               case DREG:
+                       extension |= (1 << 3) | a0reg;
+                       break;
+               case IMMED:
+                       if ((a0exattr & DEFINED) == 0)
+                               return error("constant value must be defined");
+
+                       if (a0exval > 7)
+                               return error("constant value must be between 0 and 7");
+
+                       extension |= (2 << 3) | (uint16_t)a0exval;
+                       break;
+               }
+
+               // Operand 3 must be an immediate
+               CHECK_COMMA
+
+               if (*tok++ != '#')
+                       return error("ptest level must be immediate");
+
+               // Let's be a bit inflexible here and demand that this
+               // is fully defined at this stage. Otherwise we'd have
+               // to arrange for a bitfield fixup, which would mean
+               // polluting the bitfields and codebase with special
+               // cases that might most likely never be used.
+               // So if anyone gets bit by this: sorry for being a butt!
+               if (abs_expr(&eval) != OK)
+                       return OK;      // We're returning OK because error() has already been called and error count has been increased
+
+               if (eval > 7)
+                       return error("ptest level must be between 0 and 7");
+
+               extension |= eval << 10;
+
+               // Operand 4 is optional and must be an address register
+
+               if (*tok != EOL)
+               {
+                       CHECK_COMMA
+
+                       if ((*tok >= KW_A0) && (*tok <= KW_A7))
+                       {
+                               extension |= (1 << 8) | ((*tok++ & 7) << 4);
+                       }
+                       else
+                       {
+                               return error("fourth parameter must be an address register");
+                       }
+               }
+
+               ErrorIfNotAtEOL();
+
+               D_word(extension);
+               return OK;
+       }
+       else
                return error("Not implemented yet.");
 
        return ERROR;
 }
 
+int m_ptestr(WORD inst, WORD siz)
+{
+       return m_ptest(inst, siz, (1 << 15) | (0 << 9));
+}
+
+int m_ptestw(WORD inst, WORD siz)
+{
+       return m_ptest(inst, siz, (1 << 15) | (1 << 9));
+}
+
 //////////////////////////////////////////////////////////////////////////////
 //
 // 68020/30/40/60 instructions
@@ -2637,7 +2795,7 @@ static inline int gen_fpu(WORD inst, WORD siz, WORD opmode, WORD emul)
 int m_fabs(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011000), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00011000, FPU_NOWARN);
 }
 
 
@@ -2648,7 +2806,7 @@ int m_fsabs(WORD inst, WORD siz)
 {
        CHECKNO40;
        if (activefpu == FPU_68040)
-               return gen_fpu(inst, siz, B8(01011000), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01011000, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2660,7 +2818,7 @@ int m_fsabs(WORD inst, WORD siz)
 int m_fdabs(WORD inst, WORD siz)
 {
        if (activefpu == FPU_68040)
-               return gen_fpu(inst, siz, B8(01011100), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01011100, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2672,7 +2830,7 @@ int m_fdabs(WORD inst, WORD siz)
 int m_facos(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011100), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00011100, FPU_FPSP);
 }
 
 
@@ -2682,7 +2840,7 @@ int m_facos(WORD inst, WORD siz)
 int m_fadd(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100010), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00100010, FPU_NOWARN);
 }
 
 
@@ -2692,7 +2850,7 @@ int m_fadd(WORD inst, WORD siz)
 int m_fsadd(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100010), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100010, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2704,7 +2862,7 @@ int m_fsadd(WORD inst, WORD siz)
 int m_fdadd(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100110), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100110, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2716,7 +2874,7 @@ int m_fdadd(WORD inst, WORD siz)
 int m_fasin(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001100), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001100, FPU_FPSP);
 }
 
 
@@ -2726,7 +2884,7 @@ int m_fasin(WORD inst, WORD siz)
 int m_fatan(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001010), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001010, FPU_FPSP);
 }
 
 
@@ -2736,7 +2894,7 @@ int m_fatan(WORD inst, WORD siz)
 int m_fatanh(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001101), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001101, FPU_FPSP);
 }
 
 
@@ -2746,7 +2904,7 @@ int m_fatanh(WORD inst, WORD siz)
 int m_fcmp(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00111000), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00111000, FPU_FPSP);
 }
 
 
@@ -2756,7 +2914,7 @@ int m_fcmp(WORD inst, WORD siz)
 int m_fcos(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011101), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00011101, FPU_FPSP);
 }
 
 
@@ -2766,7 +2924,7 @@ int m_fcos(WORD inst, WORD siz)
 int m_fcosh(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011001), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00011001, FPU_FPSP);
 }
 
 
@@ -2817,7 +2975,7 @@ int m_fdbcc(WORD inst, WORD siz)
 int m_fdiv(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100000), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00100000, FPU_NOWARN);
 }
 
 
@@ -2827,7 +2985,7 @@ int m_fdiv(WORD inst, WORD siz)
 int m_fsdiv(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100000), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100000, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2839,7 +2997,7 @@ int m_fsdiv(WORD inst, WORD siz)
 int m_fddiv(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100100), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100100, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -2851,7 +3009,7 @@ int m_fddiv(WORD inst, WORD siz)
 int m_fetox(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010000), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010000, FPU_FPSP);
 }
 
 
@@ -2861,7 +3019,7 @@ int m_fetox(WORD inst, WORD siz)
 int m_fetoxm1(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001000), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001000, FPU_FPSP);
 }
 
 
@@ -2871,7 +3029,7 @@ int m_fetoxm1(WORD inst, WORD siz)
 int m_fgetexp(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011110), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00011110, FPU_FPSP);
 }
 
 
@@ -2881,7 +3039,7 @@ int m_fgetexp(WORD inst, WORD siz)
 int m_fgetman(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00011111), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00011111, FPU_FPSP);
 }
 
 
@@ -2897,7 +3055,7 @@ int m_fint(WORD inst, WORD siz)
        if (activefpu == FPU_68040)
                warn("Instruction is emulated in 68040");
 
-       return gen_fpu(inst, siz, B8(00000001), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00000001, FPU_NOWARN);
 }
 
 
@@ -2913,7 +3071,7 @@ int m_fintrz(WORD inst, WORD siz)
        if (activefpu == FPU_68040)
                warn("Instruction is emulated in 68040");
 
-       return gen_fpu(inst, siz, B8(00000011), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00000011, FPU_NOWARN);
 }
 
 
@@ -2923,7 +3081,7 @@ int m_fintrz(WORD inst, WORD siz)
 int m_flog10(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010101), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010101, FPU_FPSP);
 }
 
 
@@ -2933,7 +3091,7 @@ int m_flog10(WORD inst, WORD siz)
 int m_flog2(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010110), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010110, FPU_FPSP);
 }
 
 
@@ -2943,19 +3101,17 @@ int m_flog2(WORD inst, WORD siz)
 int m_flogn(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010100), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010100, FPU_FPSP);
 }
 
 
 //
-// flognp1 (68040FPSP, 68060FPSP)
+// flognp1 (6888X, 68040FPSP, 68060FPSP)
 //
 int m_flognp1(WORD inst, WORD siz)
 {
-       if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(00000110), FPU_FPSP);
-
-       return error("Unsupported in current FPU");
+       CHECKNOFPU;
+       return gen_fpu(inst, siz, 0b00000110, FPU_FPSP);
 }
 
 
@@ -2965,7 +3121,7 @@ int m_flognp1(WORD inst, WORD siz)
 int m_fmod(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100001), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00100001, FPU_FPSP);
 }
 
 
@@ -3137,14 +3293,7 @@ int m_fsmove(WORD inst, WORD siz)
        if (!(activefpu & (FPU_68040 | FPU_68060)))
                return error("Unsupported in current FPU");
 
-       return error("Not implemented yet.");
-
-#if 0
-       if (activefpu == FPU_68040)
-               return gen_fpu(inst, siz, B8(01100100), FPU_P_EMUL);
-       else
-               return error("Unsupported in current FPU");
-#endif
+       return gen_fpu(inst, siz, 0b01100100, FPU_FPSP);
 }
 
 
@@ -3153,14 +3302,7 @@ int m_fdmove(WORD inst, WORD siz)
        if (!(activefpu & (FPU_68040 | FPU_68060)))
                return error("Unsupported in current FPU");
 
-       return error("Not implemented yet.");
-
-#if 0
-       if (activefpu == FPU_68040)
-               return gen_fpu(inst, siz, B8(01100100), FPU_P_EMUL);
-       else
-               return error("Unsupported in current FPU");
-#endif
+       return gen_fpu(inst, siz, 0b01100100, FPU_FPSP);
 }
 
 
@@ -3408,7 +3550,7 @@ fmovem_loop_2:
 int m_fmul(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100011), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00100011, FPU_NOWARN);
 }
 
 
@@ -3418,7 +3560,7 @@ int m_fmul(WORD inst, WORD siz)
 int m_fsmul(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100011), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100011, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3430,7 +3572,7 @@ int m_fsmul(WORD inst, WORD siz)
 int m_fdmul(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01100111), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01100111, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3446,10 +3588,10 @@ int m_fneg(WORD inst, WORD siz)
        if (am1 == AM_NONE)
        {
                a1reg = a0reg;
-               return gen_fpu(inst, siz, B8(00011010), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b00011010, FPU_NOWARN);
        }
 
-       return gen_fpu(inst, siz, B8(00011010), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00011010, FPU_NOWARN);
 }
 
 
@@ -3463,10 +3605,10 @@ int m_fsneg(WORD inst, WORD siz)
                if (am1 == AM_NONE)
                {
                        a1reg = a0reg;
-                       return gen_fpu(inst, siz, B8(01011010), FPU_NOWARN);
+                       return gen_fpu(inst, siz, 0b01011010, FPU_NOWARN);
                }
 
-               return gen_fpu(inst, siz, B8(01011010), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01011010, FPU_NOWARN);
        }
 
        return error("Unsupported in current FPU");
@@ -3483,10 +3625,10 @@ int m_fdneg(WORD inst, WORD siz)
                if (am1 == AM_NONE)
                {
                                a1reg = a0reg;
-                               return gen_fpu(inst, siz, B8(01011110), FPU_NOWARN);
+                               return gen_fpu(inst, siz, 0b01011110, FPU_NOWARN);
                }
 
-               return gen_fpu(inst, siz, B8(01011110), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01011110, FPU_NOWARN);
        }
 
        return error("Unsupported in current FPU");
@@ -3499,7 +3641,7 @@ int m_fdneg(WORD inst, WORD siz)
 int m_fnop(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00000000), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00000000, FPU_NOWARN);
 }
 
 
@@ -3509,7 +3651,7 @@ int m_fnop(WORD inst, WORD siz)
 int m_frem(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100101), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00100101, FPU_FPSP);
 }
 
 
@@ -3519,7 +3661,7 @@ int m_frem(WORD inst, WORD siz)
 int m_fscale(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100110), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00100110, FPU_FPSP);
 }
 
 
@@ -3552,7 +3694,7 @@ int m_fscc(WORD inst, WORD siz)
 int m_fsgldiv(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100100), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00100100, FPU_FPSP);
 }
 
 
@@ -3562,7 +3704,7 @@ int m_fsgldiv(WORD inst, WORD siz)
 int m_fsglmul(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00100111), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00100111, FPU_FPSP);
 }
 
 
@@ -3572,7 +3714,7 @@ int m_fsglmul(WORD inst, WORD siz)
 int m_fsin(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001110), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001110, FPU_FPSP);
 }
 
 
@@ -3590,7 +3732,7 @@ int m_fsincos(WORD inst, WORD siz)
        a2reg = a1reg;
        a1reg = temp;
 
-       if (gen_fpu(inst, siz, B8(00110000), FPU_FPSP) == OK)
+       if (gen_fpu(inst, siz, 0b00110000, FPU_FPSP) == OK)
        {
                chptr[-1] |= a2reg;
                return OK;
@@ -3606,7 +3748,7 @@ int m_fsincos(WORD inst, WORD siz)
 int m_fsinh(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00000010), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00000010, FPU_FPSP);
 }
 
 
@@ -3616,7 +3758,7 @@ int m_fsinh(WORD inst, WORD siz)
 int m_fsqrt(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00000100), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00000100, FPU_NOWARN);
 }
 
 
@@ -3626,7 +3768,7 @@ int m_fsqrt(WORD inst, WORD siz)
 int m_fsfsqrt(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01000001), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01000001, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3638,7 +3780,7 @@ int m_fsfsqrt(WORD inst, WORD siz)
 int m_fdfsqrt(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01000101), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01000101, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3650,7 +3792,7 @@ int m_fdfsqrt(WORD inst, WORD siz)
 int m_fsub(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00101000), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00101000, FPU_NOWARN);
 }
 
 
@@ -3660,7 +3802,7 @@ int m_fsub(WORD inst, WORD siz)
 int m_fsfsub(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01101000), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01101000, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3672,7 +3814,7 @@ int m_fsfsub(WORD inst, WORD siz)
 int m_fdsub(WORD inst, WORD siz)
 {
        if (activefpu & (FPU_68040 | FPU_68060))
-               return gen_fpu(inst, siz, B8(01101100), FPU_NOWARN);
+               return gen_fpu(inst, siz, 0b01101100, FPU_NOWARN);
 
        return error("Unsupported in current FPU");
 }
@@ -3684,7 +3826,7 @@ int m_fdsub(WORD inst, WORD siz)
 int m_ftan(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001111), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001111, FPU_FPSP);
 }
 
 
@@ -3694,7 +3836,7 @@ int m_ftan(WORD inst, WORD siz)
 int m_ftanh(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00001001), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00001001, FPU_FPSP);
 }
 
 
@@ -3704,7 +3846,7 @@ int m_ftanh(WORD inst, WORD siz)
 int m_ftentox(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010010), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010010, FPU_FPSP);
 }
 
 
@@ -3755,7 +3897,7 @@ int m_ftrapcc(WORD inst, WORD siz)
 int m_ftst(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00111010), FPU_NOWARN);
+       return gen_fpu(inst, siz, 0b00111010, FPU_NOWARN);
 }
 
 
@@ -3765,7 +3907,7 @@ int m_ftst(WORD inst, WORD siz)
 int m_ftwotox(WORD inst, WORD siz)
 {
        CHECKNOFPU;
-       return gen_fpu(inst, siz, B8(00010001), FPU_FPSP);
+       return gen_fpu(inst, siz, 0b00010001, FPU_FPSP);
 }
 
 
@@ -3782,7 +3924,7 @@ int m_ftwotox(WORD inst, WORD siz)
 int m_lpstop(WORD inst, WORD siz)
 {
        CHECKNO60;
-       D_word(B16(00000001, 11000000));
+       D_word(0b0000000111000000);
 
        if (a0exattr & DEFINED)
        {