]> git.unchartedbackwaters.co.uk Git - francis/winuae.git/commitdiff
No more forced inlining.
authorToni Wilen <twilen@winuae.net>
Mon, 21 May 2018 19:13:39 +0000 (22:13 +0300)
committerToni Wilen <twilen@winuae.net>
Mon, 21 May 2018 19:13:39 +0000 (22:13 +0300)
od-win32/machdep/m68k.cpp [new file with mode: 0644]
od-win32/machdep/m68k.h

diff --git a/od-win32/machdep/m68k.cpp b/od-win32/machdep/m68k.cpp
new file mode 100644 (file)
index 0000000..b8198b6
--- /dev/null
@@ -0,0 +1,37 @@
+
+#include "sysconfig.h"
+#include "sysdeps.h"
+#include "m68k.h"
+
+/*
+ * Test CCR condition
+ */
+int cctrue (int cc)
+{
+    uae_u32 cznv = regflags.cznv;
+
+    switch (cc) {
+       case 0:  return 1;                                                                                      /*                                      T  */
+       case 1:  return 0;                                                                                      /*                                      F  */
+       case 2:  return (cznv & (FLAGVAL_C | FLAGVAL_Z)) == 0;          /* !CFLG && !ZFLG       HI */
+       case 3:  return (cznv & (FLAGVAL_C | FLAGVAL_Z)) != 0;          /*  CFLG || ZFLG        LS */
+       case 4:  return (cznv & FLAGVAL_C) == 0;                                        /* !CFLG                        CC */
+       case 5:  return (cznv & FLAGVAL_C) != 0;                                        /*  CFLG                        CS */
+       case 6:  return (cznv & FLAGVAL_Z) == 0;                                        /* !ZFLG                        NE */
+       case 7:  return (cznv & FLAGVAL_Z) != 0;                                        /*  ZFLG                        EQ */
+       case 8:  return (cznv & FLAGVAL_V) == 0;                                        /* !VFLG                        VC */
+       case 9:  return (cznv & FLAGVAL_V) != 0;                                        /*  VFLG                        VS */
+       case 10: return (cznv & FLAGVAL_N) == 0;                                        /* !NFLG                        PL */
+       case 11: return (cznv & FLAGVAL_N) != 0;                                        /*  NFLG                        MI */
+
+       case 12: /*  NFLG == VFLG               GE */
+               return ((cznv >> FLAGBIT_N) & 1) == ((cznv >> FLAGBIT_V) & 1);
+       case 13: /*  NFLG != VFLG               LT */
+               return ((cznv >> FLAGBIT_N) & 1) != ((cznv >> FLAGBIT_V) & 1);
+       case 14: /* !GET_ZFLG && (GET_NFLG == GET_VFLG);  GT */
+               return !(cznv & FLAGVAL_Z) && (((cznv >> FLAGBIT_N) & 1) == ((cznv >> FLAGBIT_V) & 1));
+       case 15: /* GET_ZFLG || (GET_NFLG != GET_VFLG);   LE */
+               return (cznv & FLAGVAL_Z) || (((cznv >> FLAGBIT_N) & 1) != ((cznv >> FLAGBIT_V) & 1));
+       }
+    return 0;
+}
index 8d120d62d75b8aa96b379a82160f39565439bdc8..be00e9a5eb64d47ca0f8f76899d5f46fe715a92e 100644 (file)
@@ -17,25 +17,19 @@ struct flag_struct {
 
 extern struct flag_struct regflags;
 
-/*
- * The bits in the cznv field in the above structure are assigned to
- * allow the easy mirroring of the x86 condition flags. (For example,
- * from the AX register - the x86 overflow flag can be copied to AL
- * with a setto %AL instr and the other flags copied to AH with an
- * lahf instr).
- *
- * The 68k CZNV flags are thus assinged in cznv as:
- *
- * <--AL-->  <--AH-->
- * 76543210  FEDCBA98 --------- ---------
- * xxxxxxxV  NZxxxxxC xxxxxxxxx xxxxxxxxx
- */
-
+#if 1
 #define FLAGBIT_N      15
 #define FLAGBIT_Z      14
 #define FLAGBIT_C      8
 #define FLAGBIT_V      0
 #define FLAGBIT_X      8
+#else
+#define FLAGBIT_N      7
+#define FLAGBIT_Z      6
+#define FLAGBIT_C      0
+#define FLAGBIT_V      11
+#define FLAGBIT_X      0
+#endif
 
 #define FLAGVAL_N      (1 << FLAGBIT_N)
 #define FLAGVAL_Z      (1 << FLAGBIT_Z)
@@ -62,33 +56,4 @@ extern struct flag_struct regflags;
 
 #define COPY_CARRY() (regflags.x = regflags.cznv)
 
-
-/*
- * Test CCR condition
- */
-STATIC_INLINE int cctrue (int cc)
-{
-    uae_u32 cznv = regflags.cznv;
-
-    switch (cc) {
-       case 0:  return 1;                                                              /*                              T  */
-       case 1:  return 0;                                                              /*                              F  */
-       case 2:  return (cznv & (FLAGVAL_C | FLAGVAL_Z)) == 0;                          /* !CFLG && !ZFLG               HI */
-       case 3:  return (cznv & (FLAGVAL_C | FLAGVAL_Z)) != 0;                          /*  CFLG || ZFLG                LS */
-       case 4:  return (cznv & FLAGVAL_C) == 0;                                        /* !CFLG                        CC */
-       case 5:  return (cznv & FLAGVAL_C) != 0;                                        /*  CFLG                        CS */
-       case 6:  return (cznv & FLAGVAL_Z) == 0;                                        /* !ZFLG                        NE */
-       case 7:  return (cznv & FLAGVAL_Z) != 0;                                        /*  ZFLG                        EQ */
-       case 8:  return (cznv & FLAGVAL_V) == 0;                                        /* !VFLG                        VC */
-       case 9:  return (cznv & FLAGVAL_V) != 0;                                        /*  VFLG                        VS */
-       case 10: return (cznv & FLAGVAL_N) == 0;                                        /* !NFLG                        PL */
-       case 11: return (cznv & FLAGVAL_N) != 0;                                        /*  NFLG                        MI */
-       case 12: return (((cznv << (FLAGBIT_N - FLAGBIT_V)) ^ cznv) & FLAGVAL_N) == 0;  /*  NFLG == VFLG                GE */
-       case 13: return (((cznv << (FLAGBIT_N - FLAGBIT_V)) ^ cznv) & FLAGVAL_N) != 0;  /*  NFLG != VFLG                LT */
-       case 14: cznv &= (FLAGVAL_N | FLAGVAL_Z | FLAGVAL_V);                           /* ZFLG && (NFLG == VFLG)       GT */
-                return (((cznv << (FLAGBIT_N - FLAGBIT_V)) ^ cznv) & (FLAGVAL_N | FLAGVAL_Z)) == 0;
-       case 15: cznv &= (FLAGVAL_N | FLAGVAL_Z | FLAGVAL_V);                           /* ZFLG && (NFLG != VFLG)       LE */
-                return (((cznv << (FLAGBIT_N - FLAGBIT_V)) ^ cznv) & (FLAGVAL_N | FLAGVAL_Z)) != 0;
-    }
-    return 0;
-}
+extern int cctrue(int cc);