diff --git a/src/sim65/cpucore.c b/src/sim65/cpucore.c
index c88269b7d..b469b95c9 100644
--- a/src/sim65/cpucore.c
+++ b/src/sim65/cpucore.c
@@ -37,6 +37,7 @@
 
 /* common */
 #include "abend.h"
+#include "attrib.h"
 #include "print.h"
 
 /* sim65 */
@@ -88,7 +89,7 @@ int CPUHalted;
 
 
 
-/* Return the flags as a boolean value */
+/* Return the flags as a boolean value (0/1) */
 #define GET_CF()        ((SR & CF) != 0)
 #define GET_ZF()        ((SR & ZF) != 0)
 #define GET_IF()        ((SR & IF) != 0)
@@ -111,17 +112,17 @@ int CPUHalted;
 /* Special test and set macros. The meaning of the parameter depends on the
  * actual flag that should be set or reset.
  */
-#define TEST_ZF(v)      SET_ZF (((v) & 0xFF) == 0)
-#define TEST_SF(v)      SET_SF (((v) & 0x80) != 0)
-#define TEST_CF(v)      SET_CF (((v) & 0xFF00) != 0)
+#define TEST_ZF(v)              SET_ZF (((v) & 0xFF) == 0)
+#define TEST_SF(v)              SET_SF (((v) & 0x80) != 0)
+#define TEST_CF(v)              SET_CF (((v) & 0xFF00) != 0)
 
 /* Program counter halves */
 #define PCL		(PC & 0xFF)
 #define PCH		((PC >> 8) & 0xFF)
 
 /* Stack operations */
-#define PUSH(Val)       WriteMem (StackPage + SP--, Val)
-#define POP()           ReadMem (StackPage + ++SP)
+#define PUSH(Val)       MemWriteByte (StackPage + SP--, Val)
+#define POP()           MemReadByte (StackPage + ++SP)
 
 /* Test for page cross */
 #define PAGE_CROSS(addr,offs)   ((((addr) & 0xFF) + offs) >= 0x100)
@@ -129,7 +130,7 @@ int CPUHalted;
 /* #imm */
 #define AC_OP_IMM(op)                           \
     Cycles = 2;                                 \
-    AC = AC op ReadMem (PC+1);                  \
+    AC = AC op MemReadByte (PC+1);              \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
@@ -137,7 +138,7 @@ int CPUHalted;
 /* zp */
 #define AC_OP_ZP(op)                            \
     Cycles = 3;                                 \
-    AC = AC op ReadMem (ReadMem (PC+1));        \
+    AC = AC op MemReadByte (MemReadByte (PC+1));\
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
@@ -146,8 +147,8 @@ int CPUHalted;
 #define AC_OP_ZPX(op)                           \
     unsigned char ZPAddr;                       \
     Cycles = 4;                                 \
-    ZPAddr = ReadMem (PC+1) + XR;               \
-    AC = AC op ReadMem (ZPAddr);                \
+    ZPAddr = MemReadByte (PC+1) + XR;           \
+    AC = AC op MemReadByte (ZPAddr);            \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
@@ -156,8 +157,8 @@ int CPUHalted;
 #define AC_OP_ZPY(op)                           \
     unsigned char ZPAddr;                       \
     Cycles = 4;                                 \
-    ZPAddr = ReadMem (PC+1) + YR;               \
-    AC = AC op ReadMem (ZPAddr);                \
+    ZPAddr = MemReadByte (PC+1) + YR;           \
+    AC = AC op MemReadByte (ZPAddr);            \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
@@ -166,8 +167,8 @@ int CPUHalted;
 #define AC_OP_ABS(op)                           \
     unsigned Addr;                              \
     Cycles = 4;                                 \
-    Addr = ReadMemW (PC+1);                     \
-    AC = AC op ReadMem (Addr);                  \
+    Addr = MemReadWord (PC+1);                  \
+    AC = AC op MemReadByte (Addr);              \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 3
@@ -176,11 +177,11 @@ int CPUHalted;
 #define AC_OP_ABSX(op)                          \
     unsigned Addr;                              \
     Cycles = 4;                                 \
-    Addr = ReadMemW (PC+1);                     \
+    Addr = MemReadWord (PC+1);                  \
     if (PAGE_CROSS (Addr, XR)) {                \
         ++Cycles;                               \
     }                                           \
-    AC = AC | ReadMem (Addr + XR);              \
+    AC = AC | MemReadByte (Addr + XR);          \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 3
@@ -189,11 +190,11 @@ int CPUHalted;
 #define AC_OP_ABSY(op)                          \
     unsigned Addr;                              \
     Cycles = 4;                                 \
-    Addr = ReadMemW (PC+1);                     \
+    Addr = MemReadWord (PC+1);                  \
     if (PAGE_CROSS (Addr, YR)) {                \
         ++Cycles;                               \
     }                                           \
-    AC = AC | ReadMem (Addr + YR);              \
+    AC = AC | MemReadByte (Addr + YR);          \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 3
@@ -203,9 +204,9 @@ int CPUHalted;
     unsigned char ZPAddr;                       \
     unsigned Addr;                              \
     Cycles = 6;                                 \
-    ZPAddr = ReadMem (PC+1) + XR;               \
-    Addr = ReadZeroPageW (ZPAddr);              \
-    AC = AC op ReadMem (Addr);                  \
+    ZPAddr = MemReadByte (PC+1) + XR;           \
+    Addr = MemReadZPWord (ZPAddr);              \
+    AC = AC op MemReadByte (Addr);              \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
@@ -215,13 +216,29 @@ int CPUHalted;
     unsigned char ZPAddr;                       \
     unsigned Addr;                              \
     Cycles = 5;                                 \
-    ZPAddr = ReadMem (PC+1);                    \
-    Addr = ReadZeroPageW (ZPAddr) + YR;         \
-    AC = AC op ReadMem (Addr);                  \
+    ZPAddr = MemReadByte (PC+1);                \
+    Addr = MemReadZPWord (ZPAddr) + YR;         \
+    AC = AC op MemReadByte (Addr);              \
     TEST_ZF (AC);                               \
     TEST_SF (AC);                               \
     PC += 2
 
+/* ADC */
+#define ADC(v)                                  \
+    if (GET_DF ()) {                            \
+        NotImplemented ();                      \
+    } else {                                    \
+        unsigned Val;                           \
+        unsigned char rhs = v;                  \
+        Val = AC + rhs + GET_CF ();             \
+        AC = (unsigned char) Val;               \
+        TEST_ZF (AC);                           \
+        TEST_SF (AC);                           \
+        TEST_CF (Val);                          \
+        SET_OF (!((AC ^ rhs) & 0x80) &&         \
+                ((AC ^ Val) & 0x80));           \
+    }
+
 /* branches */
 #define BRANCH(cond)                            \
     Cycles = 2;                                 \
@@ -229,9 +246,9 @@ int CPUHalted;
         signed char Offs;                       \
         unsigned char OldPCH;                   \
         ++Cycles;                               \
-        Offs = (signed char) ReadMem (PC+1);    \
+        Offs = (signed char) MemReadByte (PC+1);\
         OldPCH = PCH;                           \
-        PC += (int) Offs;                       \
+        PC += 2 + (int) Offs;                   \
         if (PCH != OldPCH) {                    \
             ++Cycles;                           \
         }                                       \
@@ -249,6 +266,42 @@ int CPUHalted;
     }
 
 
+/* ROL */
+#define ROL(Val)                                \
+    Val <<= 1;                                  \
+    if (GET_CF ()) {                            \
+        Val |= 0x01;                            \
+    }                                           \
+    TEST_ZF (Val);                              \
+    TEST_SF (Val);                              \
+    TEST_CF (Val)
+
+/* ROR */
+#define ROR(Val)                                \
+    if (GET_CF ()) {                            \
+        Val |= 0x100;                           \
+    }                                           \
+    SET_CF (Val & 0x01);                        \
+    Val >>= 1;                                  \
+    TEST_ZF (Val);                              \
+    TEST_SF (Val)
+
+/* SBC */
+#define SBC(v)                                  \
+    if (GET_DF ()) {                            \
+        NotImplemented ();                      \
+    } else {                                    \
+        unsigned Val;                           \
+        unsigned char rhs = v;                  \
+        Val = AC - rhs - (!GET_CF ());          \
+        AC = (unsigned char) Val;               \
+        TEST_ZF (AC);                           \
+        TEST_SF (AC);                           \
+        SET_CF (Val <= 0xFF);                   \
+        SET_OF (((AC^rhs) & (AC^Val) & 0x80));  \
+    }
+
+
 
 /*****************************************************************************/
 /*                               Helper functions                            */
@@ -256,17 +309,19 @@ int CPUHalted;
 
 
 
-static void Illegal (void)
+static void OPC_Illegal (void) attribute ((noreturn));
+static void OPC_Illegal (void)
 {
-    fprintf (stderr, "Illegal: $%02X\n", ReadMem (PC));
+    fprintf (stderr, "Illegal: $%02X\n", MemReadByte (PC));
     exit (EXIT_FAILURE);
 }
 
 
 
+static void NotImplemented (void) attribute ((noreturn));
 static void NotImplemented (void)
 {
-    fprintf (stderr, "Not implemented: $%02X\n", ReadMem (PC));
+    fprintf (stderr, "Not implemented: $%02X\n", MemReadByte (PC));
     exit (EXIT_FAILURE);
 }
 
@@ -288,7 +343,7 @@ static void OPC_6502_00 (void)
     PUSH (PCL);
     PUSH (SR);
     SET_IF (1);
-    PC = ReadMemW (0xFFFE);
+    PC = MemReadWord (0xFFFE);
 }
 
 
@@ -301,30 +356,6 @@ static void OPC_6502_01 (void)
 
 
 
-static void OPC_6502_02 (void)
-/* Opcode $02 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_03 (void)
-/* Opcode $03 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_04 (void)
-/* Opcode $04 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_05 (void)
 /* Opcode $05: ORA zp */
 {
@@ -339,9 +370,9 @@ static void OPC_6502_06 (void)
     unsigned char ZPAddr;
     unsigned Val;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr) << 1;
-    WriteMem (ZPAddr, (unsigned char) Val);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr) << 1;
+    MemWriteByte (ZPAddr, (unsigned char) Val);
     TEST_ZF (Val & 0xFF);
     TEST_SF (Val);
     SET_CF (Val & 0x100);
@@ -350,14 +381,6 @@ static void OPC_6502_06 (void)
 
 
 
-static void OPC_6502_07 (void)
-/* Opcode $07 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_08 (void)
 /* Opcode $08: PHP */
 {
@@ -391,22 +414,6 @@ static void OPC_6502_0A (void)
 
 
 
-static void OPC_6502_0B (void)
-/* Opcode $0B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_0C (void)
-/* Opcode $0C */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_0D (void)
 /* Opcode $0D: ORA abs */
 {
@@ -421,9 +428,9 @@ static void OPC_6502_0E (void)
     unsigned Addr;
     unsigned Val;
     Cycles = 6;
-    Addr = ReadMemW (PC+1);
-    Val  = ReadMem (Addr) << 1;
-    WriteMem (Addr, (unsigned char) Val);
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr) << 1;
+    MemWriteByte (Addr, (unsigned char) Val);
     TEST_ZF (Val & 0xFF);
     TEST_SF (Val);
     SET_CF (Val & 0x100);
@@ -432,14 +439,6 @@ static void OPC_6502_0E (void)
 
 
 
-static void OPC_6502_0F (void)
-/* Opcode $0F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_10 (void)
 /* Opcode $10: BPL */
 {
@@ -456,30 +455,6 @@ static void OPC_6502_11 (void)
 
 
 
-static void OPC_6502_12 (void)
-/* Opcode $12 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_13 (void)
-/* Opcode $13 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_14 (void)
-/* Opcode $14 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_15 (void)
 /* Opcode $15: ORA zp,x */
 {
@@ -494,9 +469,9 @@ static void OPC_6502_16 (void)
     unsigned char ZPAddr;
     unsigned Val;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Val    = ReadMem (ZPAddr) << 1;
-    WriteMem (ZPAddr, (unsigned char) Val);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val    = MemReadByte (ZPAddr) << 1;
+    MemWriteByte (ZPAddr, (unsigned char) Val);
     TEST_ZF (Val & 0xFF);
     TEST_SF (Val);
     SET_CF (Val & 0x100);
@@ -505,14 +480,6 @@ static void OPC_6502_16 (void)
 
 
 
-static void OPC_6502_17 (void)
-/* Opcode $17 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_18 (void)
 /* Opcode $18: CLC */
 {
@@ -531,30 +498,6 @@ static void OPC_6502_19 (void)
 
 
 
-static void OPC_6502_1A (void)
-/* Opcode $1A */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_1B (void)
-/* Opcode $1B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_1C (void)
-/* Opcode $1C */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_1D (void)
 /* Opcode $1D: ORA abs,x */
 {
@@ -569,9 +512,9 @@ static void OPC_6502_1E (void)
     unsigned Addr;
     unsigned Val;
     Cycles = 7;
-    Addr = ReadMemW (PC+1) + XR;
-    Val  = ReadMem (Addr) << 1;
-    WriteMem (Addr, (unsigned char) Val);
+    Addr = MemReadWord (PC+1) + XR;
+    Val  = MemReadByte (Addr) << 1;
+    MemWriteByte (Addr, (unsigned char) Val);
     TEST_ZF (Val & 0xFF);
     TEST_SF (Val);
     SET_CF (Val & 0x100);
@@ -580,20 +523,12 @@ static void OPC_6502_1E (void)
 
 
 
-static void OPC_6502_1F (void)
-/* Opcode $1F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_20 (void)
 /* Opcode $20: JSR */
 {
     unsigned Addr;
     Cycles = 6;
-    Addr   = ReadMemW (PC+1);
+    Addr   = MemReadWord (PC+1);
     PC += 2;
     PUSH (PCH);
     PUSH (PCL);
@@ -610,30 +545,14 @@ static void OPC_6502_21 (void)
 
 
 
-static void OPC_6502_22 (void)
-/* Opcode $22 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_23 (void)
-/* Opcode $23 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_24 (void)
 /* Opcode $24: BIT zp */
 {
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr);
     SET_SF (Val & 0x80);
     SET_OF (Val & 0x40);
     SET_ZF ((Val & AC) == 0);
@@ -656,28 +575,15 @@ static void OPC_6502_26 (void)
     unsigned char ZPAddr;
     unsigned Val;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr) << 1;
-    if (GET_CF ()) {
-        Val |= 0x01;
-    }
-    AC = (unsigned char) Val;
-    TEST_ZF (AC);
-    TEST_SF (AC);
-    TEST_CF (Val);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr);
+    ROL (Val);
+    MemWriteByte (ZPAddr, Val);
     PC += 2;
 }
 
 
 
-static void OPC_6502_27 (void)
-/* Opcode $27 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_28 (void)
 /* Opcode $28: PLP */
 {
@@ -701,35 +607,22 @@ static void OPC_6502_2A (void)
 {
     unsigned Val;
     Cycles = 2;
-    Val    = AC << 1;
-    if (GET_CF ()) {
-        Val |= 0x01;
-    }
+    Val    = AC;
+    ROL (Val);
     AC = (unsigned char) Val;
-    TEST_ZF (AC);
-    TEST_SF (AC);
-    TEST_CF (Val);
     PC += 1;
 }
 
 
 
-static void OPC_6502_2B (void)
-/* Opcode $2B */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_2C (void)
 /* Opcode $2C: BIT abs */
 {
     unsigned Addr;
     unsigned char Val;
     Cycles = 4;
-    Addr = ReadMem (PC+1);
-    Val  = ReadMem (Addr);
+    Addr = MemReadByte (PC+1);
+    Val  = MemReadByte (Addr);
     SET_SF (Val & 0x80);
     SET_OF (Val & 0x40);
     SET_ZF ((Val & AC) == 0);
@@ -752,28 +645,15 @@ static void OPC_6502_2E (void)
     unsigned Addr;
     unsigned Val;
     Cycles = 6;
-    Addr = ReadMemW (PC+1);
-    Val  = ReadMem (Addr) << 1;
-    if (GET_CF ()) {
-        Val |= 0x01;
-    }
-    AC = (unsigned char) Val;
-    TEST_ZF (AC);
-    TEST_SF (AC);
-    TEST_CF (Val);
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr);
+    ROL (Val);
+    MemWriteByte (Addr, Val);
     PC += 3;
 }
 
 
 
-static void OPC_6502_2F (void)
-/* Opcode $2F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_30 (void)
 /* Opcode $30: BMI */
 {
@@ -790,30 +670,6 @@ static void OPC_6502_31 (void)
 
 
 
-static void OPC_6502_32 (void)
-/* Opcode $32 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_33 (void)
-/* Opcode $33 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_34 (void)
-/* Opcode $34 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_35 (void)
 /* Opcode $35: AND zp,x */
 {
@@ -828,28 +684,15 @@ static void OPC_6502_36 (void)
     unsigned char ZPAddr;
     unsigned Val;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Val    = ReadMem (ZPAddr) << 1;
-    if (GET_CF ()) {
-        Val |= 0x01;
-    }
-    AC = (unsigned char) Val;
-    TEST_ZF (AC);
-    TEST_SF (AC);
-    TEST_CF (Val);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val    = MemReadByte (ZPAddr);
+    ROL (Val);
+    MemWriteByte (ZPAddr, Val);
     PC += 2;
 }
 
 
 
-static void OPC_6502_37 (void)
-/* Opcode $37 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_38 (void)
 /* Opcode $38: SEC */
 {
@@ -868,30 +711,6 @@ static void OPC_6502_39 (void)
 
 
 
-static void OPC_6502_3A (void)
-/* Opcode $3A */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_3B (void)
-/* Opcode $3B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_3C (void)
-/* Opcode $3C */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_3D (void)
 /* Opcode $3D: AND abs,x */
 {
@@ -906,28 +725,15 @@ static void OPC_6502_3E (void)
     unsigned Addr;
     unsigned Val;
     Cycles = 7;
-    Addr = ReadMemW (PC+1) + XR;
-    Val  = ReadMem (Addr) << 1;
-    if (GET_CF ()) {
-        Val |= 0x01;
-    }
-    AC = (unsigned char) Val;
-    TEST_ZF (AC);
-    TEST_SF (AC);
-    TEST_CF (Val);
+    Addr = MemReadWord (PC+1) + XR;
+    Val  = MemReadByte (Addr);
+    ROL (Val);
+    MemWriteByte (Addr, Val);
     PC += 2;
 }
 
 
 
-static void OPC_6502_3F (void)
-/* Opcode $3F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_40 (void)
 /* Opcode $40: RTI */
 {
@@ -947,30 +753,6 @@ static void OPC_6502_41 (void)
 
 
 
-static void OPC_6502_42 (void)
-/* Opcode $42 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_43 (void)
-/* Opcode $43 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_44 (void)
-/* Opcode $44 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_45 (void)
 /* Opcode $45: EOR zp */
 {
@@ -985,11 +767,11 @@ static void OPC_6502_46 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr);
     SET_CF (Val & 0x01);
     Val >>= 1;
-    WriteMem (ZPAddr, Val);
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -997,14 +779,6 @@ static void OPC_6502_46 (void)
 
 
 
-static void OPC_6502_47 (void)
-/* Opcode $47 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_48 (void)
 /* Opcode $48: PHA */
 {
@@ -1036,19 +810,11 @@ static void OPC_6502_4A (void)
 
 
 
-static void OPC_6502_4B (void)
-/* Opcode $4B */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_4C (void)
 /* Opcode $4C: JMP abs */
 {
     Cycles = 3;
-    PC = ReadMemW (PC+1);
+    PC = MemReadWord (PC+1);
 }
 
 
@@ -1067,11 +833,11 @@ static void OPC_6502_4E (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 6;
-    Addr = ReadMemW (PC+1);
-    Val  = ReadMem (Addr);
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr);
     SET_CF (Val & 0x01);
     Val >>= 1;
-    WriteMem (Addr, Val);
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -1079,14 +845,6 @@ static void OPC_6502_4E (void)
 
 
 
-static void OPC_6502_4F (void)
-/* Opcode $4F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_50 (void)
 /* Opcode $50: BVC */
 {
@@ -1103,30 +861,6 @@ static void OPC_6502_51 (void)
 
 
 
-static void OPC_6502_52 (void)
-/* Opcode $52 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_53 (void)
-/* Opcode $53 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_54 (void)
-/* Opcode $54 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_55 (void)
 /* Opcode $55: EOR zp,x */
 {
@@ -1141,11 +875,11 @@ static void OPC_6502_56 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Val    = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val    = MemReadByte (ZPAddr);
     SET_CF (Val & 0x01);
     Val >>= 1;
-    WriteMem (ZPAddr, Val);
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -1153,14 +887,6 @@ static void OPC_6502_56 (void)
 
 
 
-static void OPC_6502_57 (void)
-/* Opcode $57 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_58 (void)
 /* Opcode $58: CLI */
 {
@@ -1179,30 +905,6 @@ static void OPC_6502_59 (void)
 
 
 
-static void OPC_6502_5A (void)
-/* Opcode $5A */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_5B (void)
-/* Opcode $5B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_5C (void)
-/* Opcode $5C */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_5D (void)
 /* Opcode $5D: EOR abs,x */
 {
@@ -1217,11 +919,11 @@ static void OPC_6502_5E (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 7;
-    Addr = ReadMemW (PC+1) + XR;
-    Val  = ReadMem (Addr);
+    Addr = MemReadWord (PC+1) + XR;
+    Val  = MemReadByte (Addr);
     SET_CF (Val & 0x01);
     Val >>= 1;
-    WriteMem (Addr, Val);
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -1229,14 +931,6 @@ static void OPC_6502_5E (void)
 
 
 
-static void OPC_6502_5F (void)
-/* Opcode $5F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_60 (void)
 /* Opcode $60: RTS */
 {
@@ -1251,31 +945,13 @@ static void OPC_6502_60 (void)
 static void OPC_6502_61 (void)
 /* Opcode $61: ADC (zp,x) */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_62 (void)
-/* Opcode $62 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_63 (void)
-/* Opcode $63 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_64 (void)
-/* Opcode $64 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Addr;
+    Cycles = 6;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Addr   = MemReadZPWord (ZPAddr);
+    ADC (MemReadByte (Addr));
+    PC += 2;
 }
 
 
@@ -1283,7 +959,11 @@ static void OPC_6502_64 (void)
 static void OPC_6502_65 (void)
 /* Opcode $65: ADC zp */
 {
-    NotImplemented ();
+    unsigned char ZPAddr;
+    Cycles = 3;
+    ZPAddr = MemReadByte (PC+1);
+    ADC (MemReadByte (ZPAddr));
+    PC += 2;
 }
 
 
@@ -1291,15 +971,14 @@ static void OPC_6502_65 (void)
 static void OPC_6502_66 (void)
 /* Opcode $66: ROR zp */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_67 (void)
-/* Opcode $67 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Val;
+    Cycles = 5;
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr);
+    ROR (Val);
+    MemWriteByte (ZPAddr, Val);
+    PC += 2;
 }
 
 
@@ -1319,7 +998,9 @@ static void OPC_6502_68 (void)
 static void OPC_6502_69 (void)
 /* Opcode $69: ADC #imm */
 {
-    NotImplemented ();
+    Cycles = 2;
+    ADC (MemReadByte (PC+1));
+    PC += 2;
 }
 
 
@@ -1327,15 +1008,12 @@ static void OPC_6502_69 (void)
 static void OPC_6502_6A (void)
 /* Opcode $6A: ROR a */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_6B (void)
-/* Opcode $6B */
-{
-    Illegal ();
+    unsigned Val;
+    Cycles = 2;
+    Val = AC;
+    ROR (Val);
+    AC = (unsigned char) Val;
+    PC += 1;
 }
 
 
@@ -1345,15 +1023,15 @@ static void OPC_6502_6C (void)
 {
     unsigned Addr;
     Cycles = 5;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (CPU == CPU_6502) {
         /* Emulate the 6502 bug */
-        PC = ReadMem (Addr);
+        PC = MemReadByte (Addr);
         Addr = (Addr & 0xFF00) | ((Addr + 1) & 0xFF);
-        PC |= (ReadMem (Addr) << 8);
+        PC |= (MemReadByte (Addr) << 8);
     } else {
         /* 65C02 and above have this bug fixed */
-        PC = ReadMemW (Addr);
+        PC = MemReadWord (Addr);
     }
     PC += 3;
 }
@@ -1363,7 +1041,11 @@ static void OPC_6502_6C (void)
 static void OPC_6502_6D (void)
 /* Opcode $6D: ADC abs */
 {
-    NotImplemented ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    ADC (MemReadByte (Addr));
+    PC += 3;
 }
 
 
@@ -1371,15 +1053,14 @@ static void OPC_6502_6D (void)
 static void OPC_6502_6E (void)
 /* Opcode $6E: ROR abs */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_6F (void)
-/* Opcode $6F */
-{
-    Illegal ();
+    unsigned Addr;
+    unsigned Val;
+    Cycles = 6;
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr);
+    ROR (Val);
+    MemWriteByte (Addr, Val);
+    PC += 3;
 }
 
 
@@ -1395,31 +1076,16 @@ static void OPC_6502_70 (void)
 static void OPC_6502_71 (void)
 /* Opcode $71: ADC (zp),y */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_72 (void)
-/* Opcode $72 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_73 (void)
-/* Opcode $73 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_74 (void)
-/* Opcode $74 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Addr;
+    Cycles = 5;
+    ZPAddr = MemReadByte (PC+1);
+    Addr   = MemReadZPWord (ZPAddr);
+    if (PAGE_CROSS (Addr, YR)) {
+        ++Cycles;
+    }
+    ADC (MemReadByte (Addr + YR));
+    PC += 2;
 }
 
 
@@ -1427,7 +1093,11 @@ static void OPC_6502_74 (void)
 static void OPC_6502_75 (void)
 /* Opcode $75: ADC zp,x */
 {
-    NotImplemented ();
+    unsigned char ZPAddr;
+    Cycles = 4;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    ADC (MemReadByte (ZPAddr));
+    PC += 2;
 }
 
 
@@ -1435,15 +1105,14 @@ static void OPC_6502_75 (void)
 static void OPC_6502_76 (void)
 /* Opcode $76: ROR zp,x */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_77 (void)
-/* Opcode $77 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Val;
+    Cycles = 6;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val    = MemReadByte (ZPAddr);
+    ROR (Val);
+    MemWriteByte (ZPAddr, Val);
+    PC += 2;
 }
 
 
@@ -1461,31 +1130,14 @@ static void OPC_6502_78 (void)
 static void OPC_6502_79 (void)
 /* Opcode $79: ADC abs,y */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_7A (void)
-/* Opcode $7A */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_7B (void)
-/* Opcode $7B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_7C (void)
-/* Opcode $7C */
-{
-    Illegal ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    if (PAGE_CROSS (Addr, YR)) {
+        ++Cycles;
+    }
+    ADC (MemReadByte (Addr + YR));
+    PC += 3;
 }
 
 
@@ -1493,7 +1145,14 @@ static void OPC_6502_7C (void)
 static void OPC_6502_7D (void)
 /* Opcode $7D: ADC abs,x */
 {
-    NotImplemented ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    if (PAGE_CROSS (Addr, XR)) {
+        ++Cycles;
+    }
+    ADC (MemReadByte (Addr + XR));
+    PC += 3;
 }
 
 
@@ -1501,23 +1160,14 @@ static void OPC_6502_7D (void)
 static void OPC_6502_7E (void)
 /* Opcode $7E: ROR abs,x */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_7F (void)
-/* Opcode $7F */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_80 (void)
-/* Opcode $80 */
-{
-    Illegal ();
+    unsigned Addr;
+    unsigned Val;
+    Cycles = 7;
+    Addr = MemReadByte (PC+1) + XR;
+    Val  = MemReadByte (Addr);
+    ROR (Val);
+    MemWriteByte (Addr, Val);
+    PC += 3;
 }
 
 
@@ -1525,23 +1175,13 @@ static void OPC_6502_80 (void)
 static void OPC_6502_81 (void)
 /* Opcode $81: STA (zp,x) */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_82 (void)
-/* Opcode $82 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_83 (void)
-/* Opcode $83 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Addr;
+    Cycles = 6;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Addr   = MemReadZPWord (ZPAddr);
+    MemWriteByte (Addr, AC);
+    PC += 2;
 }
 
 
@@ -1551,8 +1191,8 @@ static void OPC_6502_84 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    WriteMem (ZPAddr, YR);
+    ZPAddr = MemReadByte (PC+1);
+    MemWriteByte (ZPAddr, YR);
     PC += 2;
 }
 
@@ -1563,8 +1203,8 @@ static void OPC_6502_85 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    WriteMem (ZPAddr, AC);
+    ZPAddr = MemReadByte (PC+1);
+    MemWriteByte (ZPAddr, AC);
     PC += 2;
 }
 
@@ -1575,21 +1215,13 @@ static void OPC_6502_86 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    WriteMem (ZPAddr, XR);
+    ZPAddr = MemReadByte (PC+1);
+    MemWriteByte (ZPAddr, XR);
     PC += 2;
 }
 
 
 
-static void OPC_6502_87 (void)
-/* Opcode $87 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_88 (void)
 /* Opcode $88: DEY */
 {
@@ -1602,14 +1234,6 @@ static void OPC_6502_88 (void)
 
 
 
-static void OPC_6502_89 (void)
-/* Opcode $89 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_8A (void)
 /* Opcode $8A: TXA */
 {
@@ -1622,21 +1246,13 @@ static void OPC_6502_8A (void)
 
 
 
-static void OPC_6502_8B (void)
-/* Opcode $8B */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_8C (void)
 /* Opcode $8C: STY abs */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
-    WriteMem (Addr, YR);
+    Addr = MemReadWord (PC+1);
+    MemWriteByte (Addr, YR);
     PC += 3;
 }
 
@@ -1647,8 +1263,8 @@ static void OPC_6502_8D (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
-    WriteMem (Addr, AC);
+    Addr = MemReadWord (PC+1);
+    MemWriteByte (Addr, AC);
     PC += 3;
 }
 
@@ -1659,21 +1275,13 @@ static void OPC_6502_8E (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
-    WriteMem (Addr, XR);
+    Addr = MemReadWord (PC+1);
+    MemWriteByte (Addr, XR);
     PC += 3;
 }
 
 
 
-static void OPC_6502_8F (void)
-/* Opcode $8F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_90 (void)
 /* Opcode $90: BCC */
 {
@@ -1688,37 +1296,21 @@ static void OPC_6502_91 (void)
     unsigned char ZPAddr;
     unsigned Addr;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1);
-    Addr   = ReadZeroPageW (ZPAddr) + YR;
-    WriteMem (Addr, AC);
+    ZPAddr = MemReadByte (PC+1);
+    Addr   = MemReadZPWord (ZPAddr) + YR;
+    MemWriteByte (Addr, AC);
     PC += 2;
 }
 
 
 
-static void OPC_6502_92 (void)
-/* Opcode $92 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_93 (void)
-/* Opcode $93 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_94 (void)
 /* Opcode $94: STY zp,x */
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + XR;
-    WriteMem (ZPAddr, YR);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    MemWriteByte (ZPAddr, YR);
     PC += 2;
 }
 
@@ -1729,8 +1321,8 @@ static void OPC_6502_95 (void)
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + XR;
-    WriteMem (ZPAddr, AC);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    MemWriteByte (ZPAddr, AC);
     PC += 2;
 }
 
@@ -1741,21 +1333,13 @@ static void OPC_6502_96 (void)
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + YR;
-    WriteMem (ZPAddr, XR);
+    ZPAddr = MemReadByte (PC+1) + YR;
+    MemWriteByte (ZPAddr, XR);
     PC += 2;
 }
 
 
 
-static void OPC_6502_97 (void)
-/* Opcode $97 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_98 (void)
 /* Opcode $98: TYA */
 {
@@ -1773,8 +1357,8 @@ static void OPC_6502_99 (void)
 {
     unsigned Addr;
     Cycles = 5;
-    Addr   = ReadMemW (PC+1) + YR;
-    WriteMem (Addr, AC);
+    Addr   = MemReadWord (PC+1) + YR;
+    MemWriteByte (Addr, AC);
     PC += 3;
 }
 
@@ -1790,55 +1374,23 @@ static void OPC_6502_9A (void)
 
 
 
-static void OPC_6502_9B (void)
-/* Opcode $9B */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_9C (void)
-/* Opcode $9C */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_9D (void)
 /* Opcode $9D: STA abs,x */
 {
     unsigned Addr;
     Cycles = 5;
-    Addr   = ReadMemW (PC+1) + XR;
-    WriteMem (Addr, AC);
+    Addr   = MemReadWord (PC+1) + XR;
+    MemWriteByte (Addr, AC);
     PC += 3;
 }
 
 
 
-static void OPC_6502_9E (void)
-/* Opcode $9E */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_9F (void)
-/* Opcode $9F */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_A0 (void)
 /* Opcode $A0: LDY #imm */
 {
     Cycles = 2;
-    YR = ReadMem (PC+1);
+    YR = MemReadByte (PC+1);
     TEST_ZF (YR);
     TEST_SF (YR);
     PC += 2;
@@ -1852,9 +1404,9 @@ static void OPC_6502_A1 (void)
     unsigned char ZPAddr;
     unsigned Addr;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Addr = ReadZeroPageW (ZPAddr);
-    AC = ReadMem (Addr);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Addr = MemReadZPWord (ZPAddr);
+    AC = MemReadByte (Addr);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 2;
@@ -1866,7 +1418,7 @@ static void OPC_6502_A2 (void)
 /* Opcode $A2: LDX #imm */
 {
     Cycles = 2;
-    XR = ReadMem (PC+1);
+    XR = MemReadByte (PC+1);
     TEST_ZF (XR);
     TEST_SF (XR);
     PC += 2;
@@ -1874,21 +1426,13 @@ static void OPC_6502_A2 (void)
 
 
 
-static void OPC_6502_A3 (void)
-/* Opcode $A3 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_A4 (void)
 /* Opcode $A4: LDY zp */
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    YR = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    YR = MemReadByte (ZPAddr);
     TEST_ZF (YR);
     TEST_SF (YR);
     PC += 2;
@@ -1901,8 +1445,8 @@ static void OPC_6502_A5 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    AC = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    AC = MemReadByte (ZPAddr);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 2;
@@ -1915,8 +1459,8 @@ static void OPC_6502_A6 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    XR = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    XR = MemReadByte (ZPAddr);
     TEST_ZF (XR);
     TEST_SF (XR);
     PC += 2;
@@ -1924,14 +1468,6 @@ static void OPC_6502_A6 (void)
 
 
 
-static void OPC_6502_A7 (void)
-/* Opcode $A7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_A8 (void)
 /* Opcode $A8: TAY */
 {
@@ -1948,7 +1484,7 @@ static void OPC_6502_A9 (void)
 /* Opcode $A9: LDA #imm */
 {
     Cycles = 2;
-    AC = ReadMem (PC+1);
+    AC = MemReadByte (PC+1);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 2;
@@ -1968,21 +1504,13 @@ static void OPC_6502_AA (void)
 
 
 
-static void OPC_6502_AB (void)
-/* Opcode $AB */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_AC (void)
 /* Opcode $AC: LDY abs */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    YR     = ReadMem (Addr);
+    Addr   = MemReadWord (PC+1);
+    YR     = MemReadByte (Addr);
     TEST_ZF (YR);
     TEST_SF (YR);
     PC += 3;
@@ -1995,8 +1523,8 @@ static void OPC_6502_AD (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    AC     = ReadMem (Addr);
+    Addr   = MemReadWord (PC+1);
+    AC     = MemReadByte (Addr);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 3;
@@ -2009,8 +1537,8 @@ static void OPC_6502_AE (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    XR     = ReadMem (Addr);
+    Addr   = MemReadWord (PC+1);
+    XR     = MemReadByte (Addr);
     TEST_ZF (XR);
     TEST_SF (XR);
     PC += 3;
@@ -2018,14 +1546,6 @@ static void OPC_6502_AE (void)
 
 
 
-static void OPC_6502_AF (void)
-/* Opcode $AF */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_B0 (void)
 /* Opcode $B0: BCS */
 {
@@ -2040,12 +1560,12 @@ static void OPC_6502_B1 (void)
     unsigned char ZPAddr;
     unsigned Addr;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Addr   = ReadZeroPageW (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    Addr   = MemReadZPWord (ZPAddr);
     if (PAGE_CROSS (Addr, YR)) {
         ++Cycles;
     }
-    AC = ReadMem (Addr + YR);
+    AC = MemReadByte (Addr + YR);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 2;
@@ -2053,29 +1573,13 @@ static void OPC_6502_B1 (void)
 
 
 
-static void OPC_6502_B2 (void)
-/* Opcode $B2 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_B3 (void)
-/* Opcode $B3 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_B4 (void)
 /* Opcode $B4: LDY zp,x */
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + XR;
-    YR     = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    YR     = MemReadByte (ZPAddr);
     TEST_ZF (YR);
     TEST_SF (YR);
     PC += 2;
@@ -2088,8 +1592,8 @@ static void OPC_6502_B5 (void)
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + XR;
-    AC     = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    AC     = MemReadByte (ZPAddr);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 2;
@@ -2102,8 +1606,8 @@ static void OPC_6502_B6 (void)
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + YR;
-    XR     = ReadMem (ZPAddr);
+    ZPAddr = MemReadByte (PC+1) + YR;
+    XR     = MemReadByte (ZPAddr);
     TEST_ZF (XR);
     TEST_SF (XR);
     PC += 2;
@@ -2111,14 +1615,6 @@ static void OPC_6502_B6 (void)
 
 
 
-static void OPC_6502_B7 (void)
-/* Opcode $B7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_B8 (void)
 /* Opcode $B8: CLV */
 {
@@ -2134,11 +1630,11 @@ static void OPC_6502_B9 (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, YR)) {
         ++Cycles;
     }
-    AC = ReadMem (Addr + YR);
+    AC = MemReadByte (Addr + YR);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 3;
@@ -2158,24 +1654,16 @@ static void OPC_6502_BA (void)
 
 
 
-static void OPC_6502_BB (void)
-/* Opcode $BB */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_BC (void)
 /* Opcode $BC: LDY abs,x */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, XR)) {
         ++Cycles;
     }
-    YR = ReadMem (Addr + XR);
+    YR = MemReadByte (Addr + XR);
     TEST_ZF (YR);
     TEST_SF (YR);
     PC += 3;
@@ -2188,11 +1676,11 @@ static void OPC_6502_BD (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, XR)) {
         ++Cycles;
     }
-    AC = ReadMem (Addr + XR);
+    AC = MemReadByte (Addr + XR);
     TEST_ZF (AC);
     TEST_SF (AC);
     PC += 3;
@@ -2205,11 +1693,11 @@ static void OPC_6502_BE (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, YR)) {
         ++Cycles;
     }
-    XR = ReadMem (Addr + YR);
+    XR = MemReadByte (Addr + YR);
     TEST_ZF (XR);
     TEST_SF (XR);
     PC += 3;
@@ -2217,19 +1705,11 @@ static void OPC_6502_BE (void)
 
 
 
-static void OPC_6502_BF (void)
-/* Opcode $BF */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_C0 (void)
 /* Opcode $C0: CPY #imm */
 {
     Cycles = 2;
-    CMP (YR, ReadMem (PC+1));
+    CMP (YR, MemReadByte (PC+1));
     PC += 2;
 }
 
@@ -2241,37 +1721,21 @@ static void OPC_6502_C1 (void)
     unsigned char ZPAddr;
     unsigned Addr;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Addr   = ReadZeroPageW (ZPAddr);
-    CMP (AC, ReadMem (Addr));
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Addr   = MemReadZPWord (ZPAddr);
+    CMP (AC, MemReadByte (Addr));
     PC += 2;
 }
 
 
 
-static void OPC_6502_C2 (void)
-/* Opcode $C2 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_C3 (void)
-/* Opcode $C3 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_C4 (void)
 /* Opcode $C4: CPY zp */
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    CMP (YR, ReadMem (ZPAddr));
+    ZPAddr = MemReadByte (PC+1);
+    CMP (YR, MemReadByte (ZPAddr));
     PC += 2;
 }
 
@@ -2282,8 +1746,8 @@ static void OPC_6502_C5 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    CMP (AC, ReadMem (ZPAddr));
+    ZPAddr = MemReadByte (PC+1);
+    CMP (AC, MemReadByte (ZPAddr));
     PC += 2;
 }
 
@@ -2295,9 +1759,9 @@ static void OPC_6502_C6 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr) - 1;
-    WriteMem (ZPAddr, Val);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr) - 1;
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -2305,14 +1769,6 @@ static void OPC_6502_C6 (void)
 
 
 
-static void OPC_6502_C7 (void)
-/* Opcode $C7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_C8 (void)
 /* Opcode $C8: INY */
 {
@@ -2329,7 +1785,7 @@ static void OPC_6502_C9 (void)
 /* Opcode $C9: CMP #imm */
 {
     Cycles = 2;
-    CMP (AC, ReadMem (PC+1));
+    CMP (AC, MemReadByte (PC+1));
     PC += 2;
 }
 
@@ -2347,21 +1803,13 @@ static void OPC_6502_CA (void)
 
 
 
-static void OPC_6502_CB (void)
-/* Opcode $CB */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_CC (void)
 /* Opcode $CC: CPY abs */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    CMP (YR, ReadMem (Addr));
+    Addr   = MemReadWord (PC+1);
+    CMP (YR, MemReadByte (Addr));
     PC += 3;
 }
 
@@ -2372,8 +1820,8 @@ static void OPC_6502_CD (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    CMP (AC, ReadMem (Addr));
+    Addr   = MemReadWord (PC+1);
+    CMP (AC, MemReadByte (Addr));
     PC += 3;
 }
 
@@ -2385,9 +1833,9 @@ static void OPC_6502_CE (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 6;
-    Addr = ReadMemW (PC+1);
-    Val  = ReadMem (Addr) - 1;
-    WriteMem (Addr, Val);
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr) - 1;
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -2395,14 +1843,6 @@ static void OPC_6502_CE (void)
 
 
 
-static void OPC_6502_CF (void)
-/* Opcode $CF */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_D0 (void)
 /* Opcode $D0: BNE */
 {
@@ -2417,48 +1857,24 @@ static void OPC_6502_D1 (void)
     unsigned ZPAddr;
     unsigned Addr;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Addr   = ReadMemW (ZPAddr);
+    ZPAddr = MemReadByte (PC+1);
+    Addr   = MemReadWord (ZPAddr);
     if (PAGE_CROSS (Addr, YR)) {
         ++Cycles;
     }
-    CMP (AC, ReadMem (Addr + YR));
+    CMP (AC, MemReadByte (Addr + YR));
     PC += 2;
 }
 
 
 
-static void OPC_6502_D2 (void)
-/* Opcode $D2 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_D3 (void)
-/* Opcode $D3 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_D4 (void)
-/* Opcode $D4 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_D5 (void)
 /* Opcode $D5: CMP zp,x */
 {
     unsigned char ZPAddr;
     Cycles = 4;
-    ZPAddr = ReadMem (PC+1) + XR;
-    CMP (AC, ReadMem (ZPAddr));
+    ZPAddr = MemReadByte (PC+1) + XR;
+    CMP (AC, MemReadByte (ZPAddr));
     PC += 2;
 }
 
@@ -2470,9 +1886,9 @@ static void OPC_6502_D6 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Val  = ReadMem (ZPAddr) - 1;
-    WriteMem (ZPAddr, Val);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val  = MemReadByte (ZPAddr) - 1;
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -2480,14 +1896,6 @@ static void OPC_6502_D6 (void)
 
 
 
-static void OPC_6502_D7 (void)
-/* Opcode $D7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_D8 (void)
 /* Opcode $D8: CLD */
 {
@@ -2503,50 +1911,26 @@ static void OPC_6502_D9 (void)
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, YR)) {
         ++Cycles;
     }
-    CMP (AC, ReadMem (Addr + YR));
+    CMP (AC, MemReadByte (Addr + YR));
     PC += 3;
 }
 
 
 
-static void OPC_6502_DA (void)
-/* Opcode $DA */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_DB (void)
-/* Opcode $DB */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_DC (void)
-/* Opcode $DC */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_DD (void)
 /* Opcode $DD: CMP abs,x */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr = ReadMemW (PC+1);
+    Addr = MemReadWord (PC+1);
     if (PAGE_CROSS (Addr, XR)) {
         ++Cycles;
     }
-    CMP (AC, ReadMem (Addr + XR));
+    CMP (AC, MemReadByte (Addr + XR));
     PC += 3;
 }
 
@@ -2558,9 +1942,9 @@ static void OPC_6502_DE (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 7;
-    Addr = ReadMemW (PC+1) + XR;
-    Val  = ReadMem (Addr) - 1;
-    WriteMem (Addr, Val);
+    Addr = MemReadWord (PC+1) + XR;
+    Val  = MemReadByte (Addr) - 1;
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -2568,19 +1952,11 @@ static void OPC_6502_DE (void)
 
 
 
-static void OPC_6502_DF (void)
-/* Opcode $DF */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_E0 (void)
 /* Opcode $E0: CPX #imm */
 {
     Cycles = 2;
-    CMP (XR, ReadMem (PC+1));
+    CMP (XR, MemReadByte (PC+1));
     PC += 2;
 }
 
@@ -2589,23 +1965,13 @@ static void OPC_6502_E0 (void)
 static void OPC_6502_E1 (void)
 /* Opcode $E1: SBC (zp,x) */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_E2 (void)
-/* Opcode $E2 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_E3 (void)
-/* Opcode $E3 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Addr;
+    Cycles = 6;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Addr   = MemReadZPWord (ZPAddr);
+    SBC (MemReadByte (Addr));
+    PC += 2;
 }
 
 
@@ -2615,8 +1981,8 @@ static void OPC_6502_E4 (void)
 {
     unsigned char ZPAddr;
     Cycles = 3;
-    ZPAddr = ReadMem (PC+1);
-    CMP (XR, ReadMem (ZPAddr));
+    ZPAddr = MemReadByte (PC+1);
+    CMP (XR, MemReadByte (ZPAddr));
     PC += 2;
 }
 
@@ -2625,7 +1991,11 @@ static void OPC_6502_E4 (void)
 static void OPC_6502_E5 (void)
 /* Opcode $E5: SBC zp */
 {
-    NotImplemented ();
+    unsigned char ZPAddr;
+    Cycles = 3;
+    ZPAddr = MemReadByte (PC+1);
+    SBC (MemReadByte (ZPAddr));
+    PC += 2;
 }
 
 
@@ -2636,9 +2006,9 @@ static void OPC_6502_E6 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 5;
-    ZPAddr = ReadMem (PC+1);
-    Val    = ReadMem (ZPAddr) + 1;
-    WriteMem (ZPAddr, Val);
+    ZPAddr = MemReadByte (PC+1);
+    Val    = MemReadByte (ZPAddr) + 1;
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -2646,14 +2016,6 @@ static void OPC_6502_E6 (void)
 
 
 
-static void OPC_6502_E7 (void)
-/* Opcode $E7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_E8 (void)
 /* Opcode $E8: INX */
 {
@@ -2669,7 +2031,9 @@ static void OPC_6502_E8 (void)
 static void OPC_6502_E9 (void)
 /* Opcode $E9: SBC #imm */
 {
-    NotImplemented ();
+    Cycles = 2;
+    SBC (MemReadByte (PC+1));
+    PC += 2;
 }
 
 
@@ -2684,21 +2048,13 @@ static void OPC_6502_EA (void)
 
 
 
-static void OPC_6502_EB (void)
-/* Opcode $EB */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_EC (void)
 /* Opcode $EC: CPX abs */
 {
     unsigned Addr;
     Cycles = 4;
-    Addr   = ReadMemW (PC+1);
-    CMP (XR, ReadMem (Addr));
+    Addr   = MemReadWord (PC+1);
+    CMP (XR, MemReadByte (Addr));
     PC += 3;
 }
 
@@ -2707,7 +2063,11 @@ static void OPC_6502_EC (void)
 static void OPC_6502_ED (void)
 /* Opcode $ED: SBC abs */
 {
-    NotImplemented ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    SBC (MemReadByte (Addr));
+    PC += 3;
 }
 
 
@@ -2718,9 +2078,9 @@ static void OPC_6502_EE (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 6;
-    Addr = ReadMemW (PC+1);
-    Val  = ReadMem (Addr) + 1;
-    WriteMem (Addr, Val);
+    Addr = MemReadWord (PC+1);
+    Val  = MemReadByte (Addr) + 1;
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -2728,14 +2088,6 @@ static void OPC_6502_EE (void)
 
 
 
-static void OPC_6502_EF (void)
-/* Opcode $EF */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_F0 (void)
 /* Opcode $F0: BEQ */
 {
@@ -2747,31 +2099,16 @@ static void OPC_6502_F0 (void)
 static void OPC_6502_F1 (void)
 /* Opcode $F1: SBC (zp),y */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_F2 (void)
-/* Opcode $F2 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_F3 (void)
-/* Opcode $F3 */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_F4 (void)
-/* Opcode $F4 */
-{
-    Illegal ();
+    unsigned char ZPAddr;
+    unsigned Addr;
+    Cycles = 5;
+    ZPAddr = MemReadByte (PC+1);
+    Addr   = MemReadZPWord (ZPAddr);
+    if (PAGE_CROSS (Addr, YR)) {
+        ++Cycles;
+    }
+    SBC (MemReadByte (Addr + YR));
+    PC += 2;
 }
 
 
@@ -2779,7 +2116,11 @@ static void OPC_6502_F4 (void)
 static void OPC_6502_F5 (void)
 /* Opcode $F5: SBC zp,x */
 {
-    NotImplemented ();
+    unsigned char ZPAddr;
+    Cycles = 4;
+    ZPAddr = MemReadByte (PC+1) + XR;
+    SBC (MemReadByte (ZPAddr));
+    PC += 2;
 }
 
 
@@ -2790,9 +2131,9 @@ static void OPC_6502_F6 (void)
     unsigned char ZPAddr;
     unsigned char Val;
     Cycles = 6;
-    ZPAddr = ReadMem (PC+1) + XR;
-    Val  = ReadMem (ZPAddr) + 1;
-    WriteMem (ZPAddr, Val);
+    ZPAddr = MemReadByte (PC+1) + XR;
+    Val  = MemReadByte (ZPAddr) + 1;
+    MemWriteByte (ZPAddr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 2;
@@ -2800,14 +2141,6 @@ static void OPC_6502_F6 (void)
 
 
 
-static void OPC_6502_F7 (void)
-/* Opcode $F7 */
-{
-    Illegal ();
-}
-
-
-
 static void OPC_6502_F8 (void)
 /* Opcode $F8: SED */
 {
@@ -2819,31 +2152,14 @@ static void OPC_6502_F8 (void)
 static void OPC_6502_F9 (void)
 /* Opcode $F9: SBC abs,y */
 {
-    NotImplemented ();
-}
-
-
-
-static void OPC_6502_FA (void)
-/* Opcode $FA */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_FB (void)
-/* Opcode $FB */
-{
-    Illegal ();
-}
-
-
-
-static void OPC_6502_FC (void)
-/* Opcode $FC */
-{
-    Illegal ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    if (PAGE_CROSS (Addr, YR)) {
+        ++Cycles;
+    }
+    SBC (MemReadByte (Addr + YR));
+    PC += 3;
 }
 
 
@@ -2851,7 +2167,14 @@ static void OPC_6502_FC (void)
 static void OPC_6502_FD (void)
 /* Opcode $FD: SBC abs,x */
 {
-    NotImplemented ();
+    unsigned Addr;
+    Cycles = 4;
+    Addr   = MemReadWord (PC+1);
+    if (PAGE_CROSS (Addr, XR)) {
+        ++Cycles;
+    }
+    SBC (MemReadByte (Addr + XR));
+    PC += 3;
 }
 
 
@@ -2862,9 +2185,9 @@ static void OPC_6502_FE (void)
     unsigned Addr;
     unsigned char Val;
     Cycles = 7;
-    Addr = ReadMemW (PC+1) + XR;
-    Val  = ReadMem (Addr) + 1;
-    WriteMem (Addr, Val);
+    Addr = MemReadWord (PC+1) + XR;
+    Val  = MemReadByte (Addr) + 1;
+    MemWriteByte (Addr, Val);
     TEST_ZF (Val);
     TEST_SF (Val);
     PC += 3;
@@ -2872,14 +2195,6 @@ static void OPC_6502_FE (void)
 
 
 
-static void OPC_6502_FF (void)
-/* Opcode $FF */
-{
-    Illegal ();
-}
-
-
-
 /*****************************************************************************/
 /*				     Data				     */
 /*****************************************************************************/
@@ -2891,260 +2206,260 @@ typedef void (*OPCFunc) (void);
 static OPCFunc OPCTable[256] = {
     OPC_6502_00,
     OPC_6502_01,
-    OPC_6502_02,
-    OPC_6502_03,
-    OPC_6502_04,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_05,
     OPC_6502_06,
-    OPC_6502_07,
+    OPC_Illegal,
     OPC_6502_08,
     OPC_6502_09,
     OPC_6502_0A,
-    OPC_6502_0B,
-    OPC_6502_0C,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_0D,
     OPC_6502_0E,
-    OPC_6502_0F,
+    OPC_Illegal,
     OPC_6502_10,
     OPC_6502_11,
-    OPC_6502_12,
-    OPC_6502_13,
-    OPC_6502_14,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_15,
     OPC_6502_16,
-    OPC_6502_17,
+    OPC_Illegal,
     OPC_6502_18,
     OPC_6502_19,
-    OPC_6502_1A,
-    OPC_6502_1B,
-    OPC_6502_1C,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_1D,
     OPC_6502_1E,
-    OPC_6502_1F,
+    OPC_Illegal,
     OPC_6502_20,
     OPC_6502_21,
-    OPC_6502_22,
-    OPC_6502_23,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_24,
     OPC_6502_25,
     OPC_6502_26,
-    OPC_6502_27,
+    OPC_Illegal,
     OPC_6502_28,
     OPC_6502_29,
     OPC_6502_2A,
-    OPC_6502_2B,
+    OPC_Illegal,
     OPC_6502_2C,
     OPC_6502_2D,
     OPC_6502_2E,
-    OPC_6502_2F,
+    OPC_Illegal,
     OPC_6502_30,
     OPC_6502_31,
-    OPC_6502_32,
-    OPC_6502_33,
-    OPC_6502_34,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_35,
     OPC_6502_36,
-    OPC_6502_37,
+    OPC_Illegal,
     OPC_6502_38,
     OPC_6502_39,
-    OPC_6502_3A,
-    OPC_6502_3B,
-    OPC_6502_3C,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_3D,
     OPC_6502_3E,
-    OPC_6502_3F,
+    OPC_Illegal,
     OPC_6502_40,
     OPC_6502_41,
-    OPC_6502_42,
-    OPC_6502_43,
-    OPC_6502_44,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_45,
     OPC_6502_46,
-    OPC_6502_47,
+    OPC_Illegal,
     OPC_6502_48,
     OPC_6502_49,
     OPC_6502_4A,
-    OPC_6502_4B,
+    OPC_Illegal,
     OPC_6502_4C,
     OPC_6502_4D,
     OPC_6502_4E,
-    OPC_6502_4F,
+    OPC_Illegal,
     OPC_6502_50,
     OPC_6502_51,
-    OPC_6502_52,
-    OPC_6502_53,
-    OPC_6502_54,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_55,
     OPC_6502_56,
-    OPC_6502_57,
+    OPC_Illegal,
     OPC_6502_58,
     OPC_6502_59,
-    OPC_6502_5A,
-    OPC_6502_5B,
-    OPC_6502_5C,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_5D,
     OPC_6502_5E,
-    OPC_6502_5F,
+    OPC_Illegal,
     OPC_6502_60,
     OPC_6502_61,
-    OPC_6502_62,
-    OPC_6502_63,
-    OPC_6502_64,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_65,
     OPC_6502_66,
-    OPC_6502_67,
+    OPC_Illegal,
     OPC_6502_68,
     OPC_6502_69,
     OPC_6502_6A,
-    OPC_6502_6B,
+    OPC_Illegal,
     OPC_6502_6C,
     OPC_6502_6D,
     OPC_6502_6E,
-    OPC_6502_6F,
+    OPC_Illegal,
     OPC_6502_70,
     OPC_6502_71,
-    OPC_6502_72,
-    OPC_6502_73,
-    OPC_6502_74,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_75,
     OPC_6502_76,
-    OPC_6502_77,
+    OPC_Illegal,
     OPC_6502_78,
     OPC_6502_79,
-    OPC_6502_7A,
-    OPC_6502_7B,
-    OPC_6502_7C,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_7D,
     OPC_6502_7E,
-    OPC_6502_7F,
-    OPC_6502_80,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_81,
-    OPC_6502_82,
-    OPC_6502_83,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_84,
     OPC_6502_85,
     OPC_6502_86,
-    OPC_6502_87,
+    OPC_Illegal,
     OPC_6502_88,
-    OPC_6502_89,
+    OPC_Illegal,
     OPC_6502_8A,
-    OPC_6502_8B,
+    OPC_Illegal,
     OPC_6502_8C,
     OPC_6502_8D,
     OPC_6502_8E,
-    OPC_6502_8F,
+    OPC_Illegal,
     OPC_6502_90,
     OPC_6502_91,
-    OPC_6502_92,
-    OPC_6502_93,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_94,
     OPC_6502_95,
     OPC_6502_96,
-    OPC_6502_97,
+    OPC_Illegal,
     OPC_6502_98,
     OPC_6502_99,
     OPC_6502_9A,
-    OPC_6502_9B,
-    OPC_6502_9C,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_9D,
-    OPC_6502_9E,
-    OPC_6502_9F,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_A0,
     OPC_6502_A1,
     OPC_6502_A2,
-    OPC_6502_A3,
+    OPC_Illegal,
     OPC_6502_A4,
     OPC_6502_A5,
     OPC_6502_A6,
-    OPC_6502_A7,
+    OPC_Illegal,
     OPC_6502_A8,
     OPC_6502_A9,
     OPC_6502_AA,
-    OPC_6502_AB,
+    OPC_Illegal,
     OPC_6502_AC,
     OPC_6502_AD,
     OPC_6502_AE,
-    OPC_6502_AF,
+    OPC_Illegal,
     OPC_6502_B0,
     OPC_6502_B1,
-    OPC_6502_B2,
-    OPC_6502_B3,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_B4,
     OPC_6502_B5,
     OPC_6502_B6,
-    OPC_6502_B7,
+    OPC_Illegal,
     OPC_6502_B8,
     OPC_6502_B9,
     OPC_6502_BA,
-    OPC_6502_BB,
+    OPC_Illegal,
     OPC_6502_BC,
     OPC_6502_BD,
     OPC_6502_BE,
-    OPC_6502_BF,
+    OPC_Illegal,
     OPC_6502_C0,
     OPC_6502_C1,
-    OPC_6502_C2,
-    OPC_6502_C3,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_C4,
     OPC_6502_C5,
     OPC_6502_C6,
-    OPC_6502_C7,
+    OPC_Illegal,
     OPC_6502_C8,
     OPC_6502_C9,
     OPC_6502_CA,
-    OPC_6502_CB,
+    OPC_Illegal,
     OPC_6502_CC,
     OPC_6502_CD,
     OPC_6502_CE,
-    OPC_6502_CF,
+    OPC_Illegal,
     OPC_6502_D0,
     OPC_6502_D1,
-    OPC_6502_D2,
-    OPC_6502_D3,
-    OPC_6502_D4,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_D5,
     OPC_6502_D6,
-    OPC_6502_D7,
+    OPC_Illegal,
     OPC_6502_D8,
     OPC_6502_D9,
-    OPC_6502_DA,
-    OPC_6502_DB,
-    OPC_6502_DC,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_DD,
     OPC_6502_DE,
-    OPC_6502_DF,
+    OPC_Illegal,
     OPC_6502_E0,
     OPC_6502_E1,
-    OPC_6502_E2,
-    OPC_6502_E3,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_E4,
     OPC_6502_E5,
     OPC_6502_E6,
-    OPC_6502_E7,
+    OPC_Illegal,
     OPC_6502_E8,
     OPC_6502_E9,
     OPC_6502_EA,
-    OPC_6502_EB,
+    OPC_Illegal,
     OPC_6502_EC,
     OPC_6502_ED,
     OPC_6502_EE,
-    OPC_6502_EF,
+    OPC_Illegal,
     OPC_6502_F0,
     OPC_6502_F1,
-    OPC_6502_F2,
-    OPC_6502_F3,
-    OPC_6502_F4,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_F5,
     OPC_6502_F6,
-    OPC_6502_F7,
+    OPC_Illegal,
     OPC_6502_F8,
     OPC_6502_F9,
-    OPC_6502_FA,
-    OPC_6502_FB,
-    OPC_6502_FC,
+    OPC_Illegal,
+    OPC_Illegal,
+    OPC_Illegal,
     OPC_6502_FD,
     OPC_6502_FE,
-    OPC_6502_FF,
+    OPC_Illegal,
 };
 
 
diff --git a/src/sim65/memory.c b/src/sim65/memory.c
index 482733fa1..c433d41f3 100644
--- a/src/sim65/memory.c
+++ b/src/sim65/memory.c
@@ -54,7 +54,7 @@ static unsigned char RAM[0x10000];
 
 
 
-void WriteMem (unsigned Addr, unsigned char Val)
+void MemWriteByte (unsigned Addr, unsigned char Val)
 /* Write a byte to a memory location */
 {
     RAM[Addr] = Val;
@@ -62,7 +62,7 @@ void WriteMem (unsigned Addr, unsigned char Val)
 
 
 
-unsigned char ReadMem (unsigned Addr)
+unsigned char MemReadByte (unsigned Addr)
 /* Read a byte from a memory location */
 {
     return RAM[Addr];
@@ -70,23 +70,23 @@ unsigned char ReadMem (unsigned Addr)
 
 
 
-unsigned ReadMemW (unsigned Addr)
+unsigned MemReadWord (unsigned Addr)
 /* Read a word from a memory location */
 {
-    unsigned W = ReadMem (Addr++);
-    return (W | (ReadMem (Addr) << 8));
+    unsigned W = MemReadByte (Addr++);
+    return (W | (MemReadByte (Addr) << 8));
 }
 
 
 
-unsigned ReadZeroPageW (unsigned char Addr)
+unsigned MemReadZPWord (unsigned char Addr)
 /* Read a word from the zero page. This function differs from ReadMemW in that
 * the read will always be in the zero page, even in case of an address
 * overflow.
 */
 {
-    unsigned W = ReadMem (Addr++);
-    return (W | (ReadMem (Addr) << 8));
+    unsigned W = MemReadByte (Addr++);
+    return (W | (MemReadByte (Addr) << 8));
 }
 
 
diff --git a/src/sim65/memory.h b/src/sim65/memory.h
index cce83fc8d..201a27237 100644
--- a/src/sim65/memory.h
+++ b/src/sim65/memory.h
@@ -50,18 +50,18 @@
 
 
 
-void WriteMem (unsigned Addr, unsigned char Val);
+void MemWriteByte (unsigned Addr, unsigned char Val);
 /* Write a byte to a memory location */
 
-unsigned char ReadMem (unsigned Addr);
+unsigned char MemReadByte (unsigned Addr);
 /* Read a byte from a memory location */
 
-unsigned ReadMemW (unsigned Addr);
+unsigned MemReadWord (unsigned Addr);
 /* Read a word from a memory location */
 
-unsigned ReadZeroPageW (unsigned char Addr);
+unsigned MemReadZPWord (unsigned char Addr);
 /* Read a word from the zero page. This function differs from ReadMemW in that
- * the read will always be in the zero page, even in case of an address 
+ * the read will always be in the zero page, even in case of an address
  * overflow.
  */