--- /dev/null
+#include <stdbool.h>
+#include <stdlib.h>
+#include <string.h>
+#include "cpu_6809.h"
+
+// initialization
+void cpu_6809_init(
+ struct cpu_6809 *self,
+ int (*read_byte)(void *context, int addr),
+ void *read_byte_context,
+ void (*write_byte)(void *context, int addr, int data),
+ void *write_byte_context
+) {
+ memset(self, 0, sizeof(struct cpu_6809));
+ self->read_byte = read_byte;
+ self->read_byte_context = read_byte_context;
+ self->write_byte = write_byte;
+ self->write_byte_context = write_byte_context;
+}
+
+void cpu_6809_reset(struct cpu_6809 *self) {
+ self->regs.word.pc = cpu_6809_read_word(self, CPU_6809_RESET_VECTOR);
+ self->regs.byte.iflags = 0;
+ self->regs.bit._if = true;
+}
+
+// instruction decode
+int cpu_6809_addressing_mode(struct cpu_6809 *self) {
+ int ea;
+ switch (cpu_6809_fetch_byte(self)) {
+ case 0x00:
+ ea = (0 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x01:
+ ea = (1 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x02:
+ ea = (2 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x03:
+ ea = (3 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x04:
+ ea = (4 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x05:
+ ea = (5 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x06:
+ ea = (6 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x07:
+ ea = (7 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x08:
+ ea = (8 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x09:
+ ea = (9 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0a:
+ ea = (10 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0b:
+ ea = (11 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0c:
+ ea = (12 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0d:
+ ea = (13 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0e:
+ ea = (14 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x0f:
+ ea = (15 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x10:
+ ea = (-16 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x11:
+ ea = (-15 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x12:
+ ea = (-14 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x13:
+ ea = (-13 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x14:
+ ea = (-12 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x15:
+ ea = (-11 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x16:
+ ea = (-10 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x17:
+ ea = (-9 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x18:
+ ea = (-8 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x19:
+ ea = (-7 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1a:
+ ea = (-6 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1b:
+ ea = (-5 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1c:
+ ea = (-4 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1d:
+ ea = (-3 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1e:
+ ea = (-2 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x1f:
+ ea = (-1 + self->regs.word.x) & 0xffff;
+ break;
+ case 0x20:
+ ea = (0 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x21:
+ ea = (1 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x22:
+ ea = (2 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x23:
+ ea = (3 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x24:
+ ea = (4 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x25:
+ ea = (5 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x26:
+ ea = (6 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x27:
+ ea = (7 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x28:
+ ea = (8 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x29:
+ ea = (9 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2a:
+ ea = (10 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2b:
+ ea = (11 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2c:
+ ea = (12 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2d:
+ ea = (13 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2e:
+ ea = (14 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x2f:
+ ea = (15 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x30:
+ ea = (-16 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x31:
+ ea = (-15 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x32:
+ ea = (-14 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x33:
+ ea = (-13 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x34:
+ ea = (-12 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x35:
+ ea = (-11 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x36:
+ ea = (-10 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x37:
+ ea = (-9 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x38:
+ ea = (-8 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x39:
+ ea = (-7 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3a:
+ ea = (-6 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3b:
+ ea = (-5 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3c:
+ ea = (-4 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3d:
+ ea = (-3 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3e:
+ ea = (-2 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x3f:
+ ea = (-1 + self->regs.word.y) & 0xffff;
+ break;
+ case 0x40:
+ ea = (0 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x41:
+ ea = (1 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x42:
+ ea = (2 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x43:
+ ea = (3 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x44:
+ ea = (4 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x45:
+ ea = (5 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x46:
+ ea = (6 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x47:
+ ea = (7 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x48:
+ ea = (8 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x49:
+ ea = (9 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4a:
+ ea = (10 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4b:
+ ea = (11 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4c:
+ ea = (12 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4d:
+ ea = (13 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4e:
+ ea = (14 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x4f:
+ ea = (15 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x50:
+ ea = (-16 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x51:
+ ea = (-15 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x52:
+ ea = (-14 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x53:
+ ea = (-13 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x54:
+ ea = (-12 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x55:
+ ea = (-11 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x56:
+ ea = (-10 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x57:
+ ea = (-9 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x58:
+ ea = (-8 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x59:
+ ea = (-7 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5a:
+ ea = (-6 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5b:
+ ea = (-5 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5c:
+ ea = (-4 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5d:
+ ea = (-3 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5e:
+ ea = (-2 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x5f:
+ ea = (-1 + self->regs.word.u) & 0xffff;
+ break;
+ case 0x60:
+ ea = (0 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x61:
+ ea = (1 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x62:
+ ea = (2 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x63:
+ ea = (3 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x64:
+ ea = (4 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x65:
+ ea = (5 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x66:
+ ea = (6 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x67:
+ ea = (7 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x68:
+ ea = (8 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x69:
+ ea = (9 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6a:
+ ea = (10 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6b:
+ ea = (11 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6c:
+ ea = (12 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6d:
+ ea = (13 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6e:
+ ea = (14 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x6f:
+ ea = (15 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x70:
+ ea = (-16 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x71:
+ ea = (-15 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x72:
+ ea = (-14 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x73:
+ ea = (-13 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x74:
+ ea = (-12 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x75:
+ ea = (-11 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x76:
+ ea = (-10 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x77:
+ ea = (-9 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x78:
+ ea = (-8 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x79:
+ ea = (-7 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7a:
+ ea = (-6 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7b:
+ ea = (-5 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7c:
+ ea = (-4 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7d:
+ ea = (-3 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7e:
+ ea = (-2 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x7f:
+ ea = (-1 + self->regs.word.s) & 0xffff;
+ break;
+ case 0x80:
+ ea = self->regs.word.x++;
+ break;
+ case 0x81:
+ ea = self->regs.word.x;
+ self->regs.word.x += 2;
+ break;
+ case 0x82:
+ ea = --self->regs.word.x;
+ break;
+ case 0x83:
+ self->regs.word.x -= 2;
+ ea = self->regs.word.x;
+ break;
+ case 0x84:
+ ea = self->regs.word.x;
+ break;
+ case 0x85:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.x) & 0xffff;
+ break;
+ case 0x86:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.x) & 0xffff;
+ break;
+ case 0x87:
+ cpu_6809_illegal_opcode(self);
+ case 0x88:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.x) & 0xffff;
+ break;
+ case 0x89:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.x) & 0xffff;
+ break;
+ case 0x8a:
+ cpu_6809_illegal_opcode(self);
+ case 0x8b:
+ ea = (self->regs.word.d + self->regs.word.x) & 0xffff;
+ break;
+ case 0x8c:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0x8d:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0x8e:
+ cpu_6809_illegal_opcode(self);
+ case 0x8f:
+ cpu_6809_illegal_opcode(self);
+ case 0x90:
+ cpu_6809_illegal_opcode(self);
+ case 0x91:
+ ea = self->regs.word.x;
+ self->regs.word.x += 2;
+ goto indirect;
+ case 0x92:
+ cpu_6809_illegal_opcode(self);
+ case 0x93:
+ self->regs.word.x -= 2;
+ ea = self->regs.word.x;
+ goto indirect;
+ case 0x94:
+ ea = self->regs.word.x;
+ goto indirect;
+ case 0x95:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.x) & 0xffff;
+ goto indirect;
+ case 0x96:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.x) & 0xffff;
+ goto indirect;
+ case 0x97:
+ cpu_6809_illegal_opcode(self);
+ case 0x98:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.x) & 0xffff;
+ goto indirect;
+ case 0x99:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.x) & 0xffff;
+ goto indirect;
+ case 0x9a:
+ cpu_6809_illegal_opcode(self);
+ case 0x9b:
+ ea = (self->regs.word.d + self->regs.word.x) & 0xffff;
+ goto indirect;
+ case 0x9c:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0x9d:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0x9e:
+ cpu_6809_illegal_opcode(self);
+ case 0x9f:
+ ea = cpu_6809_fetch_word(self);
+ goto indirect;
+ case 0xa0:
+ ea = self->regs.word.y++;
+ break;
+ case 0xa1:
+ ea = self->regs.word.y;
+ self->regs.word.y += 2;
+ break;
+ case 0xa2:
+ ea = --self->regs.word.y;
+ break;
+ case 0xa3:
+ self->regs.word.y -= 2;
+ ea = self->regs.word.y;
+ break;
+ case 0xa4:
+ ea = self->regs.word.y;
+ break;
+ case 0xa5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.y) & 0xffff;
+ break;
+ case 0xa6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.y) & 0xffff;
+ break;
+ case 0xa7:
+ cpu_6809_illegal_opcode(self);
+ case 0xa8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.y) & 0xffff;
+ break;
+ case 0xa9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.y) & 0xffff;
+ break;
+ case 0xaa:
+ cpu_6809_illegal_opcode(self);
+ case 0xab:
+ ea = (self->regs.word.d + self->regs.word.y) & 0xffff;
+ break;
+ case 0xac:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xad:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xae:
+ cpu_6809_illegal_opcode(self);
+ case 0xaf:
+ cpu_6809_illegal_opcode(self);
+ case 0xb0:
+ cpu_6809_illegal_opcode(self);
+ case 0xb1:
+ ea = self->regs.word.y;
+ self->regs.word.y += 2;
+ goto indirect;
+ case 0xb2:
+ cpu_6809_illegal_opcode(self);
+ case 0xb3:
+ self->regs.word.y -= 2;
+ ea = self->regs.word.y;
+ goto indirect;
+ case 0xb4:
+ ea = self->regs.word.y;
+ goto indirect;
+ case 0xb5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.y) & 0xffff;
+ goto indirect;
+ case 0xb6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.y) & 0xffff;
+ goto indirect;
+ case 0xb7:
+ cpu_6809_illegal_opcode(self);
+ case 0xb8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.y) & 0xffff;
+ goto indirect;
+ case 0xb9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.y) & 0xffff;
+ goto indirect;
+ case 0xba:
+ cpu_6809_illegal_opcode(self);
+ case 0xbb:
+ ea = (self->regs.word.d + self->regs.word.y) & 0xffff;
+ goto indirect;
+ case 0xbc:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0xbd:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0xbe:
+ cpu_6809_illegal_opcode(self);
+ case 0xbf:
+ cpu_6809_illegal_opcode(self);
+ case 0xc0:
+ ea = self->regs.word.u++;
+ break;
+ case 0xc1:
+ ea = self->regs.word.u;
+ self->regs.word.u += 2;
+ break;
+ case 0xc2:
+ ea = --self->regs.word.u;
+ break;
+ case 0xc3:
+ self->regs.word.u -= 2;
+ ea = self->regs.word.u;
+ break;
+ case 0xc4:
+ ea = self->regs.word.u;
+ break;
+ case 0xc5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.u) & 0xffff;
+ break;
+ case 0xc6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.u) & 0xffff;
+ break;
+ case 0xc7:
+ cpu_6809_illegal_opcode(self);
+ case 0xc8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.u) & 0xffff;
+ break;
+ case 0xc9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.u) & 0xffff;
+ break;
+ case 0xca:
+ cpu_6809_illegal_opcode(self);
+ case 0xcb:
+ ea = (self->regs.word.d + self->regs.word.u) & 0xffff;
+ break;
+ case 0xcc:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xcd:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xce:
+ cpu_6809_illegal_opcode(self);
+ case 0xcf:
+ cpu_6809_illegal_opcode(self);
+ case 0xd0:
+ cpu_6809_illegal_opcode(self);
+ case 0xd1:
+ ea = self->regs.word.u;
+ self->regs.word.u += 2;
+ goto indirect;
+ case 0xd2:
+ cpu_6809_illegal_opcode(self);
+ case 0xd3:
+ self->regs.word.u -= 2;
+ ea = self->regs.word.u;
+ goto indirect;
+ case 0xd4:
+ ea = self->regs.word.u;
+ goto indirect;
+ case 0xd5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.u) & 0xffff;
+ goto indirect;
+ case 0xd6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.u) & 0xffff;
+ goto indirect;
+ case 0xd7:
+ cpu_6809_illegal_opcode(self);
+ case 0xd8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.u) & 0xffff;
+ goto indirect;
+ case 0xd9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.u) & 0xffff;
+ goto indirect;
+ case 0xda:
+ cpu_6809_illegal_opcode(self);
+ case 0xdb:
+ ea = (self->regs.word.d + self->regs.word.u) & 0xffff;
+ goto indirect;
+ case 0xdc:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0xdd:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0xde:
+ cpu_6809_illegal_opcode(self);
+ case 0xdf:
+ cpu_6809_illegal_opcode(self);
+ case 0xe0:
+ ea = self->regs.word.s++;
+ break;
+ case 0xe1:
+ ea = self->regs.word.s;
+ self->regs.word.s += 2;
+ break;
+ case 0xe2:
+ ea = --self->regs.word.s;
+ break;
+ case 0xe3:
+ self->regs.word.s -= 2;
+ ea = self->regs.word.s;
+ break;
+ case 0xe4:
+ ea = self->regs.word.s;
+ break;
+ case 0xe5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.s) & 0xffff;
+ break;
+ case 0xe6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.s) & 0xffff;
+ break;
+ case 0xe7:
+ cpu_6809_illegal_opcode(self);
+ case 0xe8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.s) & 0xffff;
+ break;
+ case 0xe9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.s) & 0xffff;
+ break;
+ case 0xea:
+ cpu_6809_illegal_opcode(self);
+ case 0xeb:
+ ea = (self->regs.word.d + self->regs.word.s) & 0xffff;
+ break;
+ case 0xec:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xed:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ break;
+ case 0xee:
+ cpu_6809_illegal_opcode(self);
+ case 0xef:
+ cpu_6809_illegal_opcode(self);
+ case 0xf0:
+ cpu_6809_illegal_opcode(self);
+ case 0xf1:
+ ea = self->regs.word.s;
+ self->regs.word.s += 2;
+ goto indirect;
+ case 0xf2:
+ cpu_6809_illegal_opcode(self);
+ case 0xf3:
+ self->regs.word.s -= 2;
+ ea = self->regs.word.s;
+ goto indirect;
+ case 0xf4:
+ ea = self->regs.word.s;
+ goto indirect;
+ case 0xf5:
+ ea = ((int8_t)self->regs.byte.b + self->regs.word.s) & 0xffff;
+ goto indirect;
+ case 0xf6:
+ ea = ((int8_t)self->regs.byte.a + self->regs.word.s) & 0xffff;
+ goto indirect;
+ case 0xf7:
+ cpu_6809_illegal_opcode(self);
+ case 0xf8:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.s) & 0xffff;
+ goto indirect;
+ case 0xf9:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.s) & 0xffff;
+ goto indirect;
+ case 0xfa:
+ cpu_6809_illegal_opcode(self);
+ case 0xfb:
+ ea = (self->regs.word.d + self->regs.word.s) & 0xffff;
+ goto indirect;
+ case 0xfc:
+ ea = ((int8_t)cpu_6809_fetch_byte(self) + self->regs.word.pc) & 0xffff;
+ goto indirect;
+ case 0xfd:
+ ea = (cpu_6809_fetch_word(self) + self->regs.word.pc) & 0xffff;
+ indirect:
+ ea = cpu_6809_read_word(self, ea);
+ break;
+ case 0xfe:
+ cpu_6809_illegal_opcode(self);
+ case 0xff:
+ cpu_6809_illegal_opcode(self);
+ }
+ return ea;
+}
+
+void cpu_6809_execute(struct cpu_6809 *self) {
+ if (self->regs.bit.nmi_pending) {
+ self->regs.bit.nmi_pending = false;
+ if (!self->regs.bit.wai_flag)
+ cpu_6809_cwai(self, 0);
+ self->regs.bit.wai_flag = false;
+ self->regs.word.pc = cpu_6809_read_word(self, CPU_6809_NMI_VECTOR);
+ self->regs.bit._if = true;
+ return;
+ }
+
+ if (self->regs.bit.irq_pending && !self->regs.bit._if) {
+ self->regs.bit.irq_pending = false;
+ if (!self->regs.bit.wai_flag)
+ cpu_6809_cwai(self, 0);
+ self->regs.bit.wai_flag = false;
+ self->regs.word.pc = cpu_6809_read_word(self, CPU_6809_IRQ_VECTOR);
+ self->regs.bit._if = true;
+ return;
+ }
+
+ if (self->regs.bit.wai_flag) {
+ ++self->cycles;
+ return;
+ }
+
+ switch (cpu_6809_fetch_byte(self)) {
+ case 0x00:
+ cpu_6809_neg(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x01:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x02:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x03:
+ cpu_6809_com(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x04:
+ cpu_6809_lsr(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x05:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x06:
+ cpu_6809_ror(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x07:
+ cpu_6809_asr(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x08:
+ cpu_6809_asl(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x09:
+ cpu_6809_rol(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x0a:
+ cpu_6809_dec_byte(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x0b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0c:
+ cpu_6809_inc_byte(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x0d:
+ cpu_6809_cmp_byte(self, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)), 0);
+ break;
+ case 0x0e:
+ cpu_6809_jmp(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x0f:
+ cpu_6809_clr(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x10:
+ cpu_6809_execute_10(self);
+ break;
+ case 0x11:
+ cpu_6809_execute_11(self);
+ break;
+ case 0x12:
+ cpu_6809_nop(self);
+ break;
+ case 0x13:
+ cpu_6809_sync(self);
+ break;
+ case 0x14:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x15:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x16:
+ cpu_6809_lbra(self, true, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x17:
+ cpu_6809_lbsr(self, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x18:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x19:
+ cpu_6809_daa(self);
+ break;
+ case 0x1a:
+ cpu_6809_orcc(self, cpu_6809_fetch_byte(self));
+ break;
+ case 0x1b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1c:
+ cpu_6809_andcc(self, cpu_6809_fetch_byte(self));
+ break;
+ case 0x1d:
+ cpu_6809_sex(self);
+ break;
+ case 0x1e:
+ cpu_6809_exg(self, cpu_6809_fetch_byte(self));
+ break;
+ case 0x1f:
+ cpu_6809_tfr(self, cpu_6809_fetch_byte(self));
+ break;
+ case 0x20:
+ cpu_6809_bra(self, true, cpu_6809_ea_relative(self));
+ break;
+ case 0x21:
+ cpu_6809_bra(self, false, cpu_6809_ea_relative(self));
+ break;
+ case 0x22:
+ cpu_6809_bra(self, !self->regs.bit.cf && !self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x23:
+ cpu_6809_bra(self, self->regs.bit.cf || self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x24:
+ cpu_6809_bra(self, !self->regs.bit.cf, cpu_6809_ea_relative(self));
+ break;
+ case 0x25:
+ cpu_6809_bra(self, self->regs.bit.cf, cpu_6809_ea_relative(self));
+ break;
+ case 0x26:
+ cpu_6809_bra(self, !self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x27:
+ cpu_6809_bra(self, self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x28:
+ cpu_6809_bra(self, !self->regs.bit.vf, cpu_6809_ea_relative(self));
+ break;
+ case 0x29:
+ cpu_6809_bra(self, self->regs.bit.vf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2a:
+ cpu_6809_bra(self, !self->regs.bit.nf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2b:
+ cpu_6809_bra(self, self->regs.bit.nf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2c:
+ cpu_6809_bra(self, !self->regs.bit.nf && !self->regs.bit.vf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2d:
+ cpu_6809_bra(self, self->regs.bit.nf || self->regs.bit.vf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2e:
+ cpu_6809_bra(self, !self->regs.bit.nf && !self->regs.bit.vf && !self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x2f:
+ cpu_6809_bra(self, self->regs.bit.nf || self->regs.bit.vf || self->regs.bit.zf, cpu_6809_ea_relative(self));
+ break;
+ case 0x30:
+ cpu_6809_lea(self, CPU_6809_EA_X, cpu_6809_addressing_mode(self));
+ break;
+ case 0x31:
+ cpu_6809_lea(self, CPU_6809_EA_Y, cpu_6809_addressing_mode(self));
+ break;
+ case 0x32:
+ cpu_6809_lea(self, CPU_6809_EA_S, cpu_6809_addressing_mode(self));
+ break;
+ case 0x33:
+ cpu_6809_lea(self, CPU_6809_EA_U, cpu_6809_addressing_mode(self));
+ break;
+ case 0x34:
+ cpu_6809_psh(self, CPU_6809_EA_S, cpu_6809_fetch_byte(self));
+ break;
+ case 0x35:
+ cpu_6809_pul(self, CPU_6809_EA_S, cpu_6809_fetch_byte(self));
+ break;
+ case 0x36:
+ cpu_6809_psh(self, CPU_6809_EA_U, cpu_6809_fetch_byte(self));
+ break;
+ case 0x37:
+ cpu_6809_pul(self, CPU_6809_EA_U, cpu_6809_fetch_byte(self));
+ break;
+ case 0x38:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x39:
+ cpu_6809_rts(self);
+ break;
+ case 0x3a:
+ cpu_6809_add_word(self, CPU_6809_EA_X, self->regs.byte.b);
+ break;
+ case 0x3b:
+ cpu_6809_rti(self);
+ break;
+ case 0x3c:
+ cpu_6809_cwai(self, cpu_6809_fetch_byte(self));
+ break;
+ case 0x3d:
+ cpu_6809_mul(self);
+ break;
+ case 0x3e:
+ cpu_6809_reset(self);
+ break;
+ case 0x3f:
+ cpu_6809_swi(self);
+ break;
+ case 0x40:
+ cpu_6809_neg(self, CPU_6809_EA_A);
+ break;
+ case 0x41:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x42:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x43:
+ cpu_6809_com(self, CPU_6809_EA_A);
+ break;
+ case 0x44:
+ cpu_6809_lsr(self, CPU_6809_EA_A);
+ break;
+ case 0x45:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x46:
+ cpu_6809_ror(self, CPU_6809_EA_A);
+ break;
+ case 0x47:
+ cpu_6809_asr(self, CPU_6809_EA_A);
+ break;
+ case 0x48:
+ cpu_6809_asl(self, CPU_6809_EA_A);
+ break;
+ case 0x49:
+ cpu_6809_rol(self, CPU_6809_EA_A);
+ break;
+ case 0x4a:
+ cpu_6809_dec_byte(self, CPU_6809_EA_A);
+ break;
+ case 0x4b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4c:
+ cpu_6809_inc_byte(self, CPU_6809_EA_A);
+ break;
+ case 0x4d:
+ cpu_6809_cmp_byte(self, self->regs.byte.a, 0);
+ break;
+ case 0x4e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4f:
+ cpu_6809_clr(self, CPU_6809_EA_A);
+ break;
+ case 0x50:
+ cpu_6809_neg(self, CPU_6809_EA_B);
+ break;
+ case 0x51:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x52:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x53:
+ cpu_6809_com(self, CPU_6809_EA_B);
+ break;
+ case 0x54:
+ cpu_6809_lsr(self, CPU_6809_EA_B);
+ break;
+ case 0x55:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x56:
+ cpu_6809_ror(self, CPU_6809_EA_B);
+ break;
+ case 0x57:
+ cpu_6809_asr(self, CPU_6809_EA_B);
+ break;
+ case 0x58:
+ cpu_6809_asl(self, CPU_6809_EA_B);
+ break;
+ case 0x59:
+ cpu_6809_rol(self, CPU_6809_EA_B);
+ break;
+ case 0x5a:
+ cpu_6809_dec_byte(self, CPU_6809_EA_B);
+ break;
+ case 0x5b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5c:
+ cpu_6809_inc_byte(self, CPU_6809_EA_B);
+ break;
+ case 0x5d:
+ cpu_6809_cmp_byte(self, self->regs.byte.b, 0);
+ break;
+ case 0x5e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5f:
+ cpu_6809_clr(self, CPU_6809_EA_B);
+ break;
+ case 0x60:
+ cpu_6809_neg(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x61:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x62:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x63:
+ cpu_6809_com(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x64:
+ cpu_6809_lsr(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x65:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x66:
+ cpu_6809_ror(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x67:
+ cpu_6809_asr(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x68:
+ cpu_6809_asl(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x69:
+ cpu_6809_rol(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x6a:
+ cpu_6809_dec_byte(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x6b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6c:
+ cpu_6809_inc_byte(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x6d:
+ cpu_6809_cmp_byte(self, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)), 0);
+ break;
+ case 0x6e:
+ cpu_6809_jmp(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x6f:
+ cpu_6809_clr(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0x70:
+ cpu_6809_neg(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x71:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x72:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x73:
+ cpu_6809_com(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x74:
+ cpu_6809_lsr(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x75:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x76:
+ cpu_6809_ror(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x77:
+ cpu_6809_asr(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x78:
+ cpu_6809_asl(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x79:
+ cpu_6809_rol(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x7a:
+ cpu_6809_dec_byte(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x7b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7c:
+ cpu_6809_inc_byte(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x7d:
+ cpu_6809_cmp_byte(self, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)), 0);
+ break;
+ case 0x7e:
+ cpu_6809_jmp(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x7f:
+ cpu_6809_clr(self, cpu_6809_ea_extended(self));
+ break;
+ case 0x80:
+ cpu_6809_sub_byte(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x81:
+ cpu_6809_cmp_byte(self, self->regs.byte.a, cpu_6809_fetch_byte(self));
+ break;
+ case 0x82:
+ cpu_6809_sbc(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x83:
+ cpu_6809_sub_word(self, CPU_6809_EA_D, cpu_6809_fetch_word(self));
+ break;
+ case 0x84:
+ cpu_6809_and(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x85:
+ cpu_6809_bit(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x86:
+ cpu_6809_ld_byte(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x87:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x88:
+ cpu_6809_eor(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x89:
+ cpu_6809_adc(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x8a:
+ cpu_6809_or(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x8b:
+ cpu_6809_add_byte(self, CPU_6809_EA_A, cpu_6809_fetch_byte(self));
+ break;
+ case 0x8c:
+ cpu_6809_cmp_word(self, self->regs.word.x, cpu_6809_fetch_word(self));
+ break;
+ case 0x8d:
+ cpu_6809_bsr(self, cpu_6809_ea_relative(self));
+ break;
+ case 0x8e:
+ cpu_6809_ld_word(self, CPU_6809_EA_X, cpu_6809_fetch_word(self));
+ break;
+ case 0x8f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x90:
+ cpu_6809_sub_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x91:
+ cpu_6809_cmp_byte(self, self->regs.byte.a, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x92:
+ cpu_6809_sbc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x93:
+ cpu_6809_sub_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x94:
+ cpu_6809_and(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x95:
+ cpu_6809_bit(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x96:
+ cpu_6809_ld_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x97:
+ cpu_6809_st_byte(self, self->regs.byte.a, cpu_6809_ea_direct(self));
+ break;
+ case 0x98:
+ cpu_6809_eor(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x99:
+ cpu_6809_adc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9a:
+ cpu_6809_or(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9b:
+ cpu_6809_add_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9c:
+ cpu_6809_cmp_word(self, self->regs.word.x, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9d:
+ cpu_6809_jsr(self, cpu_6809_ea_direct(self));
+ break;
+ case 0x9e:
+ cpu_6809_ld_word(self, CPU_6809_EA_X, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9f:
+ cpu_6809_st_word(self, self->regs.word.x, cpu_6809_ea_direct(self));
+ break;
+ case 0xa0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa1:
+ cpu_6809_cmp_byte(self, self->regs.byte.a, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa2:
+ cpu_6809_sbc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa3:
+ cpu_6809_sub_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa4:
+ cpu_6809_and(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa5:
+ cpu_6809_bit(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa7:
+ cpu_6809_st_byte(self, self->regs.byte.a, cpu_6809_addressing_mode(self));
+ break;
+ case 0xa8:
+ cpu_6809_eor(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa9:
+ cpu_6809_adc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xaa:
+ cpu_6809_or(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xab:
+ cpu_6809_add_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xac:
+ cpu_6809_cmp_word(self, self->regs.word.x, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xad:
+ cpu_6809_jsr(self, cpu_6809_addressing_mode(self));
+ break;
+ case 0xae:
+ cpu_6809_ld_word(self, CPU_6809_EA_X, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xaf:
+ cpu_6809_st_word(self, self->regs.word.x, cpu_6809_addressing_mode(self));
+ break;
+ case 0xb0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb1:
+ cpu_6809_cmp_byte(self, self->regs.byte.a, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb2:
+ cpu_6809_sbc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb3:
+ cpu_6809_sub_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb4:
+ cpu_6809_and(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb5:
+ cpu_6809_bit(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb7:
+ cpu_6809_st_byte(self, self->regs.byte.a, cpu_6809_ea_extended(self));
+ break;
+ case 0xb8:
+ cpu_6809_eor(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb9:
+ cpu_6809_adc(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xba:
+ cpu_6809_or(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbb:
+ cpu_6809_add_byte(self, CPU_6809_EA_A, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbc:
+ cpu_6809_cmp_word(self, self->regs.word.x, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbd:
+ cpu_6809_jsr(self, cpu_6809_ea_extended(self));
+ break;
+ case 0xbe:
+ cpu_6809_ld_word(self, CPU_6809_EA_X, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbf:
+ cpu_6809_st_word(self, self->regs.word.x, cpu_6809_ea_extended(self));
+ break;
+ case 0xc0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc1:
+ cpu_6809_cmp_byte(self, self->regs.byte.b, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc2:
+ cpu_6809_sbc(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc3:
+ cpu_6809_add_word(self, CPU_6809_EA_D, cpu_6809_fetch_word(self));
+ break;
+ case 0xc4:
+ cpu_6809_and(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc5:
+ cpu_6809_bit(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc8:
+ cpu_6809_eor(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xc9:
+ cpu_6809_adc(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xca:
+ cpu_6809_or(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xcb:
+ cpu_6809_add_byte(self, CPU_6809_EA_B, cpu_6809_fetch_byte(self));
+ break;
+ case 0xcc:
+ cpu_6809_ld_word(self, CPU_6809_EA_D, cpu_6809_fetch_word(self));
+ break;
+ case 0xcd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xce:
+ cpu_6809_ld_word(self, CPU_6809_EA_U, cpu_6809_fetch_word(self));
+ break;
+ case 0xcf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd1:
+ cpu_6809_cmp_byte(self, self->regs.byte.b, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd2:
+ cpu_6809_sbc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd3:
+ cpu_6809_add_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd4:
+ cpu_6809_and(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd5:
+ cpu_6809_bit(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd7:
+ cpu_6809_st_byte(self, self->regs.byte.b, cpu_6809_ea_direct(self));
+ break;
+ case 0xd8:
+ cpu_6809_eor(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xd9:
+ cpu_6809_adc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xda:
+ cpu_6809_or(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xdb:
+ cpu_6809_add_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xdc:
+ cpu_6809_ld_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xdd:
+ cpu_6809_st_word(self, self->regs.word.d, cpu_6809_ea_direct(self));
+ break;
+ case 0xde:
+ cpu_6809_ld_word(self, CPU_6809_EA_U, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xdf:
+ cpu_6809_st_word(self, self->regs.word.u, cpu_6809_ea_direct(self));
+ break;
+ case 0xe0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe1:
+ cpu_6809_cmp_byte(self, self->regs.byte.b, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe2:
+ cpu_6809_sbc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe3:
+ cpu_6809_add_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe4:
+ cpu_6809_and(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe5:
+ cpu_6809_bit(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe7:
+ cpu_6809_st_byte(self, self->regs.byte.b, cpu_6809_addressing_mode(self));
+ break;
+ case 0xe8:
+ cpu_6809_eor(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xe9:
+ cpu_6809_adc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xea:
+ cpu_6809_or(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xeb:
+ cpu_6809_add_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xec:
+ cpu_6809_ld_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xed:
+ cpu_6809_st_word(self, self->regs.word.d, cpu_6809_addressing_mode(self));
+ break;
+ case 0xee:
+ cpu_6809_ld_word(self, CPU_6809_EA_U, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xef:
+ cpu_6809_st_word(self, self->regs.word.u, cpu_6809_addressing_mode(self));
+ break;
+ case 0xf0:
+ cpu_6809_sub_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf1:
+ cpu_6809_cmp_byte(self, self->regs.byte.b, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf2:
+ cpu_6809_sbc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf3:
+ cpu_6809_add_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf4:
+ cpu_6809_and(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf5:
+ cpu_6809_bit(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf6:
+ cpu_6809_ld_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf7:
+ cpu_6809_st_byte(self, self->regs.byte.b, cpu_6809_ea_extended(self));
+ break;
+ case 0xf8:
+ cpu_6809_eor(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xf9:
+ cpu_6809_adc(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xfa:
+ cpu_6809_or(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xfb:
+ cpu_6809_add_byte(self, CPU_6809_EA_B, cpu_6809_read_byte(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xfc:
+ cpu_6809_ld_word(self, CPU_6809_EA_D, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xfd:
+ cpu_6809_st_word(self, self->regs.word.d, cpu_6809_ea_extended(self));
+ break;
+ case 0xfe:
+ cpu_6809_ld_word(self, CPU_6809_EA_U, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xff:
+ cpu_6809_st_word(self, self->regs.word.u, cpu_6809_ea_extended(self));
+ break;
+ }
+}
+
+void cpu_6809_execute_10(struct cpu_6809 *self) {
+ switch (cpu_6809_fetch_byte(self)) {
+ case 0x00:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x01:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x02:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x03:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x04:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x05:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x06:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x07:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x08:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x09:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x10:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x11:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x12:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x13:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x14:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x15:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x16:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x17:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x18:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x19:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x20:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x21:
+ cpu_6809_lbra(self, false, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x22:
+ cpu_6809_lbra(self, !self->regs.bit.cf && !self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x23:
+ cpu_6809_lbra(self, self->regs.bit.cf || self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x24:
+ cpu_6809_lbra(self, !self->regs.bit.cf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x25:
+ cpu_6809_lbra(self, self->regs.bit.cf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x26:
+ cpu_6809_lbra(self, !self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x27:
+ cpu_6809_lbra(self, self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x28:
+ cpu_6809_lbra(self, !self->regs.bit.vf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x29:
+ cpu_6809_lbra(self, self->regs.bit.vf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2a:
+ cpu_6809_lbra(self, !self->regs.bit.nf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2b:
+ cpu_6809_lbra(self, self->regs.bit.nf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2c:
+ cpu_6809_lbra(self, !self->regs.bit.nf && !self->regs.bit.vf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2d:
+ cpu_6809_lbra(self, self->regs.bit.nf || self->regs.bit.vf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2e:
+ cpu_6809_lbra(self, !self->regs.bit.nf && !self->regs.bit.vf && !self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x2f:
+ cpu_6809_lbra(self, self->regs.bit.nf || self->regs.bit.vf || self->regs.bit.zf, cpu_6809_ea_long_relative(self));
+ break;
+ case 0x30:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x31:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x32:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x33:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x34:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x35:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x36:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x37:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x38:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x39:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3f:
+ cpu_6809_swi_n(self, 2);
+ break;
+ case 0x40:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x41:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x42:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x43:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x44:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x45:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x46:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x47:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x48:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x49:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x50:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x51:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x52:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x53:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x54:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x55:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x56:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x57:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x58:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x59:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x60:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x61:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x62:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x63:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x64:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x65:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x66:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x67:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x68:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x69:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x70:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x71:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x72:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x73:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x74:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x75:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x76:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x77:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x78:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x79:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x80:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x81:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x82:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x83:
+ cpu_6809_cmp_word(self, self->regs.word.d, cpu_6809_fetch_word(self));
+ break;
+ case 0x84:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x85:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x86:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x87:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x88:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x89:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8c:
+ cpu_6809_cmp_word(self, self->regs.word.y, cpu_6809_fetch_word(self));
+ break;
+ case 0x8d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8e:
+ cpu_6809_ld_word(self, CPU_6809_EA_Y, cpu_6809_fetch_word(self));
+ break;
+ case 0x8f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x90:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x91:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x92:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x93:
+ cpu_6809_cmp_word(self, self->regs.word.d, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x94:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x95:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x96:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x97:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x98:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x99:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9c:
+ cpu_6809_cmp_word(self, self->regs.word.y, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9e:
+ cpu_6809_ld_word(self, CPU_6809_EA_Y, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9f:
+ cpu_6809_st_word(self, self->regs.word.y, cpu_6809_ea_direct(self));
+ break;
+ case 0xa0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa3:
+ cpu_6809_cmp_word(self, self->regs.word.d, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xaa:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xab:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xac:
+ cpu_6809_cmp_word(self, self->regs.word.y, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xad:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xae:
+ cpu_6809_ld_word(self, CPU_6809_EA_Y, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xaf:
+ cpu_6809_st_word(self, self->regs.word.y, cpu_6809_addressing_mode(self));
+ break;
+ case 0xb0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb3:
+ cpu_6809_cmp_word(self, self->regs.word.d, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xba:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbc:
+ cpu_6809_cmp_word(self, self->regs.word.y, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbe:
+ cpu_6809_ld_word(self, CPU_6809_EA_Y, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbf:
+ cpu_6809_st_word(self, self->regs.word.y, cpu_6809_ea_extended(self));
+ break;
+ case 0xc0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xca:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xce:
+ cpu_6809_ld_word(self, CPU_6809_EA_S, cpu_6809_fetch_word(self));
+ break;
+ case 0xcf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xda:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xde:
+ cpu_6809_ld_word(self, CPU_6809_EA_S, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0xdf:
+ cpu_6809_st_word(self, self->regs.word.s, cpu_6809_ea_direct(self));
+ break;
+ case 0xe0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xea:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xeb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xec:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xed:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xee:
+ cpu_6809_ld_word(self, CPU_6809_EA_S, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xef:
+ cpu_6809_st_word(self, self->regs.word.s, cpu_6809_addressing_mode(self));
+ break;
+ case 0xf0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfa:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfe:
+ cpu_6809_ld_word(self, CPU_6809_EA_S, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xff:
+ cpu_6809_st_word(self, self->regs.word.s, cpu_6809_ea_extended(self));
+ break;
+ }
+}
+
+void cpu_6809_execute_11(struct cpu_6809 *self) {
+ switch (cpu_6809_fetch_byte(self)) {
+ case 0x00:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x01:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x02:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x03:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x04:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x05:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x06:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x07:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x08:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x09:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x0f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x10:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x11:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x12:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x13:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x14:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x15:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x16:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x17:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x18:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x19:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x1f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x20:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x21:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x22:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x23:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x24:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x25:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x26:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x27:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x28:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x29:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x2f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x30:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x31:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x32:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x33:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x34:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x35:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x36:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x37:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x38:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x39:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x3f:
+ cpu_6809_swi_n(self, 3);
+ break;
+ case 0x40:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x41:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x42:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x43:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x44:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x45:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x46:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x47:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x48:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x49:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x4f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x50:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x51:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x52:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x53:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x54:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x55:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x56:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x57:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x58:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x59:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x5f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x60:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x61:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x62:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x63:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x64:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x65:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x66:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x67:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x68:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x69:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x6f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x70:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x71:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x72:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x73:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x74:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x75:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x76:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x77:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x78:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x79:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7c:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x7f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x80:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x81:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x82:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x83:
+ cpu_6809_cmp_word(self, self->regs.word.u, cpu_6809_fetch_word(self));
+ break;
+ case 0x84:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x85:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x86:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x87:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x88:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x89:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8c:
+ cpu_6809_cmp_word(self, self->regs.word.s, cpu_6809_fetch_word(self));
+ break;
+ case 0x8d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x8f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x90:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x91:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x92:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x93:
+ cpu_6809_cmp_word(self, self->regs.word.u, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x94:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x95:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x96:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x97:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x98:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x99:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9a:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9b:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9c:
+ cpu_6809_cmp_word(self, self->regs.word.s, cpu_6809_read_word(self, cpu_6809_ea_direct(self)));
+ break;
+ case 0x9d:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9e:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0x9f:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa3:
+ cpu_6809_cmp_word(self, self->regs.word.u, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xa4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xa9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xaa:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xab:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xac:
+ cpu_6809_cmp_word(self, self->regs.word.s, cpu_6809_read_word(self, cpu_6809_addressing_mode(self)));
+ break;
+ case 0xad:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xae:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xaf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb3:
+ cpu_6809_cmp_word(self, self->regs.word.u, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xb4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xb9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xba:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbc:
+ cpu_6809_cmp_word(self, self->regs.word.s, cpu_6809_read_word(self, cpu_6809_ea_extended(self)));
+ break;
+ case 0xbd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbe:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xbf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xc9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xca:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xce:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xcf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xd9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xda:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xde:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xdf:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xe9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xea:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xeb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xec:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xed:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xee:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xef:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf0:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf1:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf2:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf3:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf4:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf5:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf6:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf7:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf8:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xf9:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfa:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfb:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfc:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfd:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xfe:
+ cpu_6809_illegal_opcode(self);
+ break;
+ case 0xff:
+ cpu_6809_illegal_opcode(self);
+ break;
+ }
+}
--- /dev/null
+#ifndef _CPU_6809_H
+#define _CPU_6809_H
+
+#include <endian.h>
+#include <stdbool.h>
+#include <stdint.h>
+
+// gcc specific
+#ifndef ALWAYS_INLINE
+#define ALWAYS_INLINE __attribute__((always_inline))
+#endif
+
+#define CPU_6809_IRQ_VECTOR 0xfff8
+#define CPU_6809_SWI_VECTOR 0xfffa
+#define CPU_6809_NMI_VECTOR 0xfffc
+#define CPU_6809_RESET_VECTOR 0xfffe
+
+// bits within REG_CC
+#define CPU_6809_REG_CC_BIT_H 5
+#define CPU_6809_REG_CC_BIT_I 4
+#define CPU_6809_REG_CC_BIT_N 3
+#define CPU_6809_REG_CC_BIT_Z 2
+#define CPU_6809_REG_CC_BIT_V 1
+#define CPU_6809_REG_CC_BIT_C 0
+
+// special memory locations (negative address)
+#define CPU_6809_EA_PC (-0xe)
+#define CPU_6809_EA_D (-0xc)
+#define CPU_6809_EA_A (-0xc)
+#define CPU_6809_EA_B (-0xb)
+#define CPU_6809_EA_U (-0xa)
+#define CPU_6809_EA_S (-8)
+#define CPU_6809_EA_X (-6)
+#define CPU_6809_EA_Y (-4)
+#define CPU_6809_EA_P (-2)
+#define CPU_6809_EA_IFLAGS (-1)
+
+// registers, in same order as special memory locations, but reversed on
+// little endian hardware where special memory address will be complemented
+// (this allows special memory to always look like it is big endian)
+union cpu_6809_regs {
+#if __BYTE_ORDER == __BIG_ENDIAN
+ struct {
+ uint16_t _fill_pc;
+ uint16_t _fill_d;
+ uint16_t _fill_u;
+ uint16_t _fill_s;
+ uint16_t _fill_x;
+ uint16_t _fill_y;
+ uint8_t ef : 1;
+ uint8_t ff : 1;
+ uint8_t hf : 1;
+ uint8_t _if : 1;
+ uint8_t nf : 1;
+ uint8_t zf : 1;
+ uint8_t vf : 1;
+ uint8_t cf : 1;
+ uint8_t _fill_iflags : 5;
+ uint8_t wai_flag : 1;
+ uint8_t irq_pending : 1;
+ uint8_t nmi_pending : 1;
+ } bit;
+ struct {
+ uint16_t _fill_pc;
+ uint8_t a;
+ uint8_t b;
+ uint16_t _fill_u;
+ uint16_t _fill_s;
+ uint16_t _fill_x;
+ uint16_t _fill_y;
+ uint8_t cc;
+ uint8_t iflags;
+ } byte;
+ struct {
+ uint16_t pc;
+ uint16_t d;
+ uint16_t u;
+ uint16_t s;
+ uint16_t x;
+ uint16_t y;
+ uint8_t _fill_cc;
+ uint8_t _fill_iflags;
+ } word;
+ uint8_t mem_be[0xe];
+#else
+ struct {
+ uint8_t nmi_pending : 1;
+ uint8_t irq_pending : 1;
+ uint8_t wai_flag : 1;
+ uint8_t _fill_iflags : 5;
+ uint8_t cf : 1;
+ uint8_t vf : 1;
+ uint8_t zf : 1;
+ uint8_t nf : 1;
+ uint8_t _if : 1;
+ uint8_t hf : 1;
+ uint8_t ff : 1;
+ uint8_t ef : 1;
+ uint16_t _fill_y;
+ uint16_t _fill_x;
+ uint16_t _fill_s;
+ uint16_t _fill_u;
+ uint16_t _fill_d;
+ uint16_t _fill_pc;
+ } bit;
+ struct {
+ uint8_t iflags;
+ uint8_t cc;
+ uint16_t _fill_y;
+ uint16_t _fill_x;
+ uint16_t _fill_s;
+ uint16_t _fill_u;
+ uint8_t b;
+ uint8_t a;
+ uint16_t _fill_pc;
+ } byte;
+ struct {
+ uint8_t _fill_iflags;
+ uint8_t _fill_cc;
+ uint16_t y;
+ uint16_t x;
+ uint16_t s;
+ uint16_t u;
+ uint16_t d;
+ uint16_t pc;
+ } word;
+ uint8_t mem_le[0xe];
+#endif
+};
+
+struct cpu_6809 {
+ int cycles;
+ int (*read_byte)(void *context, int addr);
+ void *read_byte_context;
+ void (*write_byte)(void *context, int addr, int data);
+ void *write_byte_context;
+ union cpu_6809_regs regs;
+};
+
+// memory or special memory access
+static ALWAYS_INLINE int cpu_6809_read_byte(struct cpu_6809 *self, int addr) {
+ if (addr < 0)
+#if __BYTE_ORDER == __BIG_ENDIAN
+ return self->regs.mem_be[sizeof(union cpu_6809_regs) + addr];
+#else
+ return self->regs.mem_le[~addr];
+#endif
+ self->cycles += 1;
+ return self->read_byte(self->read_byte_context, addr & 0xffff);
+}
+
+static ALWAYS_INLINE int cpu_6809_read_word(struct cpu_6809 *self, int addr) {
+ int data = cpu_6809_read_byte(self, addr) << 8;
+ return data | cpu_6809_read_byte(self, addr + 1);
+}
+
+static ALWAYS_INLINE void cpu_6809_write_byte(struct cpu_6809 *self, int addr, int data) {
+ self->cycles += 1;
+ if (addr < 0)
+#if __BYTE_ORDER == __BIG_ENDIAN
+ self->regs.mem_be[sizeof(union cpu_6809_regs) + addr] = data;
+#else
+ self->regs.mem_le[~addr] = data;
+#endif
+ else
+ self->write_byte(self->write_byte_context, addr, data);
+}
+
+static ALWAYS_INLINE void cpu_6809_write_word(struct cpu_6809 *self, int addr, int data) {
+ cpu_6809_write_byte(self, addr, data >> 8);
+ cpu_6809_write_byte(self, addr + 1, data & 0xff);
+}
+
+static ALWAYS_INLINE int cpu_6809_fetch_byte(struct cpu_6809 *self) {
+ int data = cpu_6809_read_byte(self, self->regs.word.pc++);
+ return data;
+}
+
+static ALWAYS_INLINE int cpu_6809_fetch_word(struct cpu_6809 *self) {
+ int data = cpu_6809_fetch_byte(self) << 8;
+ return data | cpu_6809_fetch_byte(self);
+}
+
+static ALWAYS_INLINE void cpu_6809_push_byte(struct cpu_6809 *self, int data) {
+ cpu_6809_write_byte(self, self->regs.word.s--, data);
+}
+
+static ALWAYS_INLINE void cpu_6809_push_word(struct cpu_6809 *self, int data) {
+ cpu_6809_push_byte(self, data & 0xff);
+ cpu_6809_push_byte(self, data >> 8);
+}
+
+static ALWAYS_INLINE int cpu_6809_pop_byte(struct cpu_6809 *self) {
+ return cpu_6809_read_byte(self, ++self->regs.word.s);
+}
+
+static ALWAYS_INLINE int cpu_6809_pop_word(struct cpu_6809 *self) {
+ int data = cpu_6809_pop_byte(self) << 8;
+ return data | cpu_6809_pop_byte(self);
+}
+
+// effective address calculation
+static ALWAYS_INLINE int cpu_6809_ea_extended(struct cpu_6809 *self) {
+ return cpu_6809_fetch_word(self);
+}
+
+static ALWAYS_INLINE int cpu_6809_ea_relative(struct cpu_6809 *self) {
+ return (int8_t)cpu_6809_fetch_byte(self);
+}
+
+static ALWAYS_INLINE int cpu_6809_ea_long_relative(struct cpu_6809 *self) {
+ return cpu_6809_fetch_word(self);
+}
+
+static ALWAYS_INLINE int cpu_6809_ea_direct(struct cpu_6809 *self) {
+ return cpu_6809_fetch_byte(self);
+}
+
+// instruction execute
+static ALWAYS_INLINE void cpu_6809_adc(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0xf) + (rvalue & 0xf) + self->regs.bit.cf;
+ int result1 = result0 + (data & 0x70) + (rvalue & 0x70);
+ int result2 = result1 + (data & 0x80) + (rvalue & 0x80);
+
+ cpu_6809_write_byte(self, lvalue, result2 & 0xff);
+ self->regs.bit.hf = result0 >> 4;
+ self->regs.bit.nf = (result2 >> 7) & 1;
+ self->regs.bit.zf = (result2 & 0xff) == 0;
+ self->regs.bit.vf = ((result1 >> 7) ^ (result2 >> 8)) & 1;
+ self->regs.bit.cf = result2 >> 8;
+}
+
+static ALWAYS_INLINE void cpu_6809_add_byte(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0xf) + (rvalue & 0xf);
+ int result1 = result0 + (data & 0x70) + (rvalue & 0x70);
+ int result2 = result1 + (data & 0x80) + (rvalue & 0x80);
+
+ cpu_6809_write_byte(self, lvalue, result2 & 0xff);
+ self->regs.bit.hf = result0 >> 4;
+ self->regs.bit.nf = (result2 >> 7) & 1;
+ self->regs.bit.zf = (result2 & 0xff) == 0;
+ self->regs.bit.vf = ((result1 >> 7) ^ (result2 >> 8)) & 1;
+ self->regs.bit.cf = result2 >> 8;
+}
+
+static ALWAYS_INLINE void cpu_6809_add_word(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_word(self, lvalue);
+
+ int result0 = (data & 0xfff) + (rvalue & 0xfff);
+ int result1 = result0 + (data & 0x7000) + (rvalue & 0x7000);
+ int result2 = result1 + (data & 0x8000) + (rvalue & 0x8000);
+
+ cpu_6809_write_word(self, lvalue, result2 & 0xffff);
+ self->regs.bit.hf = result0 >> 12;
+ self->regs.bit.nf = (result2 >> 15) & 1;
+ self->regs.bit.zf = (result2 & 0xffff) == 0;
+ self->regs.bit.vf = ((result1 >> 15) ^ (result2 >> 16)) & 1;
+ self->regs.bit.cf = result2 >> 16;
+}
+
+static ALWAYS_INLINE void cpu_6809_and(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) & rvalue;
+
+ cpu_6809_write_byte(self, lvalue, result);
+ self->regs.bit.nf = result >> 7;
+ self->regs.bit.zf = result == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_andcc(struct cpu_6809 *self, int rvalue) {
+ self->regs.byte.cc &= rvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_asl(struct cpu_6809 *self, int lvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) << 1;
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result & 0xff);
+ self->regs.bit.nf = (result >> 7) & 1;
+ self->regs.bit.zf = (result & 0xff) == 0;
+ self->regs.bit.vf = ((result >> 7) ^ (result >> 8)) & 1;
+ self->regs.bit.cf = result >> 8;
+}
+
+static ALWAYS_INLINE void cpu_6809_asr(struct cpu_6809 *self, int lvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result = data | ((data << 1) & 0x100);
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result >> 1);
+ self->regs.bit.nf = result >> 8;
+ self->regs.bit.zf = (result & 0xfe) == 0;
+ self->regs.bit.vf = (result ^ (result >> 8)) & 1;
+ self->regs.bit.cf = result & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_bit(struct cpu_6809 *self, int rvalue0, int rvalue1) {
+ int result = rvalue0 & rvalue1;
+
+ self->regs.bit.nf = result >> 7;
+ self->regs.bit.zf = result == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_bra(struct cpu_6809 *self, bool pred, int lvalue) {
+ if (pred) {
+ self->cycles += ((self->regs.word.pc & 0xff) + (lvalue & 0xff)) >> 8;
+ self->regs.word.pc += lvalue;
+ }
+}
+
+static ALWAYS_INLINE void cpu_6809_bsr(struct cpu_6809 *self, int lvalue) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ self->cycles += ((self->regs.word.pc & 0xff) + (lvalue & 0xff)) >> 8;
+ self->regs.word.pc += lvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_clr(struct cpu_6809 *self, int lvalue) {
+ //cpu_6809_read_byte(self, lvalue); // clr is implemented as RMW like inc/dec
+ cpu_6809_write_byte(self, lvalue, 0);
+
+ self->regs.bit.nf = false;
+ self->regs.bit.zf = true;
+ self->regs.bit.vf = false;
+ self->regs.bit.cf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_cmp_byte(struct cpu_6809 *self, int rvalue0, int rvalue1) {
+ int result0 = (rvalue0 & 0x7f) - (rvalue1 & 0x7f);
+ int result1 = result0 + (rvalue0 & 0x80) - (rvalue1 & 0x80);
+
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+ self->regs.bit.cf = (result1 >> 8) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_com(struct cpu_6809 *self, int lvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) ^ 0xff;
+
+ cpu_6809_write_byte(self, lvalue, result);
+ self->regs.bit.nf = result >> 7;
+ self->regs.bit.zf = result == 0;
+ self->regs.bit.vf = false;
+ self->regs.bit.cf = true;
+}
+
+static ALWAYS_INLINE void cpu_6809_cmp_word(struct cpu_6809 *self, int rvalue0, int rvalue1) {
+ int result0 = (rvalue0 & 0x7fff) - (rvalue1 & 0x7fff);
+ int result1 = result0 + (rvalue0 & 0x8000) - (rvalue1 & 0x8000);
+
+ self->regs.bit.nf = (result1 >> 15) & 1;
+ self->regs.bit.zf = (result1 & 0xffff) == 0;
+ self->regs.bit.vf = ((result0 >> 15) ^ (result1 >> 16)) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_cwai(struct cpu_6809 *self, int rvalue) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ cpu_6809_push_word(self, self->regs.word.x);
+ cpu_6809_push_byte(self, self->regs.byte.a);
+ cpu_6809_push_byte(self, self->regs.byte.b);
+ cpu_6809_push_byte(self, self->regs.byte.cc);
+ self->regs.bit.wai_flag = true;
+}
+
+static ALWAYS_INLINE void cpu_6809_daa(struct cpu_6809 *self) {
+ int correction = 0;
+ if (self->regs.bit.hf || (self->regs.byte.a & 0xf) >= 0xa)
+ correction = 6;
+ if (self->regs.bit.cf || self->regs.byte.a >= 0x9a) {
+ correction |= 0x60;
+ self->regs.bit.cf = true;
+ }
+
+ int result0 = (self->regs.byte.a & 0x7f) + correction;
+ int result1 = result0 + (self->regs.byte.a & 0x80);
+
+ self->regs.byte.a = result1 & 0xff;
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+ //self->regs.bit.cf |= result1 >> 8;
+}
+
+static ALWAYS_INLINE void cpu_6809_dec_byte(struct cpu_6809 *self, int lvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0x7f) - 1;
+ int result1 = result0 + (data & 0x80);
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result1 & 0xff);
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_dec_word(struct cpu_6809 *self, int lvalue) {
+ cpu_6809_write_word(
+ self,
+ lvalue,
+ (cpu_6809_read_word(self, lvalue) - 1) & 0xffff
+ );
+ ++self->cycles;
+}
+
+static ALWAYS_INLINE void cpu_6809_dec_word_zf(struct cpu_6809 *self, int lvalue) {
+ int result = (cpu_6809_read_word(self, lvalue) - 1) & 0xffff;
+ ++self->cycles;
+
+ self->regs.word.x = result;
+ self->regs.bit.zf = result == 0;
+}
+
+static ALWAYS_INLINE void cpu_6809_eor(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) ^ rvalue;
+
+ cpu_6809_write_byte(self, lvalue, result);
+ self->regs.bit.nf = result >> 7;
+ self->regs.bit.zf = result == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_exg(struct cpu_6809 *self, int postbyte) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_illegal_opcode(struct cpu_6809 *self) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_inc_byte(struct cpu_6809 *self, int lvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0x7f) + 1;
+ int result1 = result0 + (data & 0x80);
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result1 & 0xff);
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_inc_word(struct cpu_6809 *self, int lvalue) {
+ cpu_6809_write_word(
+ self,
+ lvalue,
+ (cpu_6809_read_word(self, lvalue) + 1) & 0xffff
+ );
+ ++self->cycles;
+}
+
+static ALWAYS_INLINE void cpu_6809_inc_word_zf(struct cpu_6809 *self, int lvalue) {
+ int result = (cpu_6809_read_word(self, lvalue) + 1) & 0xffff;
+ ++self->cycles;
+
+ self->regs.word.x = result;
+ self->regs.bit.zf = result == 0;
+}
+
+static ALWAYS_INLINE void cpu_6809_jmp(struct cpu_6809 *self, int lvalue) {
+ self->regs.word.pc = lvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_jsr(struct cpu_6809 *self, int lvalue) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ self->regs.word.pc = lvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_lbra(struct cpu_6809 *self, bool pred, int lvalue) {
+ if (pred) {
+ self->cycles += ((self->regs.word.pc & 0xff) + (lvalue & 0xff)) >> 8;
+ self->regs.word.pc += lvalue;
+ }
+}
+
+static ALWAYS_INLINE void cpu_6809_lbsr(struct cpu_6809 *self, int lvalue) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ self->cycles += ((self->regs.word.pc & 0xff) + (lvalue & 0xff)) >> 8;
+ self->regs.word.pc += lvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_ld_word(struct cpu_6809 *self, int lvalue, int rvalue) {
+ cpu_6809_write_word(self, lvalue, rvalue);
+
+ self->regs.bit.nf = (rvalue >> 15) & 1;
+ self->regs.bit.zf = rvalue == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_ld_byte(struct cpu_6809 *self, int lvalue, int rvalue) {
+ cpu_6809_write_byte(self, lvalue, rvalue);
+
+ self->regs.bit.nf = (rvalue >> 7) & 1;
+ self->regs.bit.zf = rvalue == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_lea(struct cpu_6809 *self, int lvalue0, int lvalue1) {
+ cpu_6809_write_word(self, lvalue0, lvalue1);
+
+ self->regs.bit.nf = (lvalue1 >> 15) & 1;
+ self->regs.bit.zf = lvalue1 == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_lsr(struct cpu_6809 *self, int lvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result = data;
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result >> 1);
+ self->regs.bit.nf = result >> 8;
+ self->regs.bit.zf = (result & 0xfe) == 0;
+ self->regs.bit.vf = (result ^ (result >> 8)) & 1;
+ self->regs.bit.cf = result & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_mul(struct cpu_6809 *self) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_neg(struct cpu_6809 *self, int lvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = -(data & 0x7f);
+ int result1 = result0 - (data & 0x80);
+
+ cpu_6809_write_byte(self, lvalue, result1 & 0xff);
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+ self->regs.bit.cf = (result1 >> 8) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_nop(struct cpu_6809 *self) {
+}
+
+static ALWAYS_INLINE void cpu_6809_or(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) | rvalue;
+
+ cpu_6809_write_byte(self, lvalue, result);
+ self->regs.bit.nf = result >> 7;
+ self->regs.bit.zf = result == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_orcc(struct cpu_6809 *self, int rvalue) {
+ self->regs.byte.cc |= rvalue;
+}
+
+static ALWAYS_INLINE void cpu_6809_psh(struct cpu_6809 *self, int lvalue, int postbyte) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_pul(struct cpu_6809 *self, int lvalue, int postbyte) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_rol(struct cpu_6809 *self, int lvalue) {
+ int result = self->regs.bit.cf | (cpu_6809_read_byte(self, lvalue) << 1);
+ ++self->cycles;
+
+ cpu_6809_write_byte(self, lvalue, result & 0xff);
+ self->regs.bit.nf = (result >> 7) & 1;
+ self->regs.bit.zf = (result & 0xff) == 0;
+ self->regs.bit.vf = ((result >> 7) ^ (result >> 8)) & 1;
+ self->regs.bit.cf = result >> 8;
+}
+
+static ALWAYS_INLINE void cpu_6809_ror(struct cpu_6809 *self, int lvalue) {
+ int result = cpu_6809_read_byte(self, lvalue) | (self->regs.bit.cf << 8);
+ ++self->cycles;
+ cpu_6809_write_byte(self, lvalue, result >> 1);
+
+ self->regs.bit.nf = result >> 8;
+ self->regs.bit.zf = (result & 0x1fe) == 0;
+ self->regs.bit.vf = (result ^ (result >> 8)) & 1;
+ self->regs.bit.cf = result & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_rti(struct cpu_6809 *self) {
+ self->regs.byte.cc = cpu_6809_pop_byte(self);
+ self->regs.byte.b = cpu_6809_pop_byte(self);
+ self->regs.byte.a = cpu_6809_pop_byte(self);
+ self->regs.word.x = cpu_6809_pop_word(self);
+ self->regs.word.pc = cpu_6809_pop_word(self);
+}
+
+static ALWAYS_INLINE void cpu_6809_rts(struct cpu_6809 *self) {
+ self->regs.word.pc = cpu_6809_pop_word(self);
+}
+
+static ALWAYS_INLINE void cpu_6809_sbc(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0x7f) - (rvalue & 0x7f) - self->regs.bit.cf;
+ int result1 = result0 + (data & 0x80) - (rvalue & 0x80);
+
+ cpu_6809_write_byte(self, lvalue, result1 & 0xff);
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+ self->regs.bit.cf = (result1 >> 8) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_sex(struct cpu_6809 *self) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_st_word(struct cpu_6809 *self, int rvalue, int lvalue) {
+ cpu_6809_write_word(self, lvalue, rvalue);
+
+ self->regs.bit.nf = (rvalue >> 15) & 1;
+ self->regs.bit.zf = rvalue == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_st_byte(struct cpu_6809 *self, int rvalue, int lvalue) {
+ cpu_6809_write_byte(self, lvalue, rvalue);
+
+ self->regs.bit.nf = (rvalue >> 7) & 1;
+ self->regs.bit.zf = rvalue == 0;
+ self->regs.bit.vf = false;
+}
+
+static ALWAYS_INLINE void cpu_6809_sub_byte(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_byte(self, lvalue);
+
+ int result0 = (data & 0x7f) - (rvalue & 0x7f);
+ int result1 = result0 + (data & 0x80) - (rvalue & 0x80);
+
+ cpu_6809_write_byte(self, lvalue, result1 & 0xff);
+ self->regs.bit.nf = (result1 >> 7) & 1;
+ self->regs.bit.zf = (result1 & 0xff) == 0;
+ self->regs.bit.vf = ((result0 >> 7) ^ (result1 >> 8)) & 1;
+ self->regs.bit.cf = (result1 >> 8) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_sub_word(struct cpu_6809 *self, int lvalue, int rvalue) {
+ int data = cpu_6809_read_word(self, lvalue);
+
+ int result0 = (data & 0x7fff) - (rvalue & 0x7fff);
+ int result1 = result0 + (data & 0x8000) - (rvalue & 0x8000);
+
+ cpu_6809_write_word(self, lvalue, result1 & 0xffff);
+ self->regs.bit.nf = (result1 >> 15) & 1;
+ self->regs.bit.zf = (result1 & 0xffff) == 0;
+ self->regs.bit.vf = ((result0 >> 15) ^ (result1 >> 16)) & 1;
+ self->regs.bit.cf = (result1 >> 16) & 1;
+}
+
+static ALWAYS_INLINE void cpu_6809_swi(struct cpu_6809 *self) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ cpu_6809_push_word(self, self->regs.word.x);
+ cpu_6809_push_byte(self, self->regs.byte.a);
+ cpu_6809_push_byte(self, self->regs.byte.b);
+ cpu_6809_push_byte(self, self->regs.byte.cc);
+ self->regs.word.pc = cpu_6809_read_word(self, CPU_6809_SWI_VECTOR);
+ self->regs.bit._if = true;
+}
+
+static ALWAYS_INLINE void cpu_6809_swi_n(struct cpu_6809 *self, int n) {
+ cpu_6809_push_word(self, self->regs.word.pc);
+ cpu_6809_push_word(self, self->regs.word.x);
+ cpu_6809_push_byte(self, self->regs.byte.a);
+ cpu_6809_push_byte(self, self->regs.byte.b);
+ cpu_6809_push_byte(self, self->regs.byte.cc);
+ self->regs.word.pc = cpu_6809_read_word(self, CPU_6809_SWI_VECTOR);
+ self->regs.bit._if = true;
+}
+
+static ALWAYS_INLINE void cpu_6809_sync(struct cpu_6809 *self) {
+ abort();
+}
+
+static ALWAYS_INLINE void cpu_6809_tfr(struct cpu_6809 *self, int postbyte) {
+ abort();
+}
+
+
+// prototypes
+void cpu_6809_init(
+ struct cpu_6809 *self,
+ int (*read_byte)(void *context, int addr),
+ void *read_byte_context,
+ void (*write_byte)(void *context, int addr, int data),
+ void *write_byte_context
+);
+void cpu_6809_reset(struct cpu_6809 *self);
+int cpu_6809_addressing_mode(struct cpu_6809 *self);
+void cpu_6809_execute(struct cpu_6809 *self);
+void cpu_6809_execute_10(struct cpu_6809 *self);
+void cpu_6809_execute_11(struct cpu_6809 *self);
+
+#endif