void run(void) {
m_icount = 1000;
- execute_run();
+ z180_device_execute_run();
}
//
//class device_t {
//public:
-// virtual void device_start() = 0;
-// virtual void device_reset() = 0;
+// virtual void z180_device_device_start() = 0;
+// virtual void z180_device_device_reset() = 0;
//};
//
//class cpu_device : public device_t {
// virtual uint32_t execute_input_lines() const = 0;
// virtual uint32_t execute_default_irq_vector(int inputnum) const = 0;
// virtual bool execute_input_edge_triggered(int inputnum) const = 0;
-// virtual void execute_run() = 0;
-// virtual void execute_burn(int32_t cycles) = 0;
-// virtual void execute_set_input(int inputnum, int state) = 0;
+// virtual void z180_device_execute_run() = 0;
+// virtual void z180_device_execute_burn(int32_t cycles) = 0;
+// virtual void z180_device_execute_set_input(int inputnum, int state) = 0;
// void set_icountptr(int &icount) {
// assert(!m_icountptr);
// m_icountptr = &icount;
//DEFINE_DEVICE_TYPE(Z180, z180_device, "z180", "Zilog Z180")
//
//
-///*z180_device::*/z180_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
+//z180_device_z180_device(const machine_config &mconfig, const char *tag, device_t *owner, uint32_t clock)
// : cpu_device(mconfig, Z180, tag, owner, clock)
// , z80_daisy_chain_interface(mconfig, *this)
// , m_program_config("program", ENDIANNESS_LITTLE, 8, 20, 0)
//{
//}
//
-//std::unique_ptr<util::disasm_interface> /*z180_device::*/create_disassembler()
+//std_unique_ptr<util_disasm_interface> z180_device_create_disassembler()
//{
-// return std::make_unique<z180_disassembler>();
+// return std_make_unique<z180_disassembler>();
//}
#define CF 0x01
#define Z180_TXA1 0x00200000 /* O asynchronous transmit data 1 (active high) */
#define Z180_TXS 0x00400000 /* O clocked serial transmit data (active high) */
-bool /*z180_device::*/get_tend0()
+bool z180_device_get_tend0()
{
return !!(m_iol & Z180_TEND0);
}
-bool /*z180_device::*/get_tend1()
+bool z180_device_get_tend1()
{
return !!(m_iol & Z180_TEND1);
}
static uint8_t SZHV_inc[256]; /* zero, sign, half carry and overflow flags INC r8 */
static uint8_t SZHV_dec[256]; /* zero, sign, half carry and overflow flags DEC r8 */
-static uint8_t *SZHVC_add; //std::unique_ptr<uint8_t[]> SZHVC_add;
-static uint8_t *SZHVC_sub; //std::unique_ptr<uint8_t[]> SZHVC_sub;
+static uint8_t *SZHVC_add; //std_unique_ptr<uint8_t[]> SZHVC_add;
+static uint8_t *SZHVC_sub; //std_unique_ptr<uint8_t[]> SZHVC_sub;
#include "z180ops.inc"
#include "z180tbl.inc"
#include "z180op.inc"
-///*device_memory_interface::*/space_config_vector /*z180_device::*/memory_space_config() const
+//device_memory_interface_space_config_vector z180_device_memory_space_config() const
//{
// if(has_configured_map(AS_OPCODES))
-// return space_config_vector {
-// std::make_pair(AS_PROGRAM, &m_program_config),
-// std::make_pair(AS_OPCODES, &m_decrypted_opcodes_config),
-// std::make_pair(AS_IO, &m_io_config)
+// return device_memory_interface_space_config_vector {
+// std_make_pair(AS_PROGRAM, &m_program_config),
+// std_make_pair(AS_OPCODES, &m_decrypted_opcodes_config),
+// std_make_pair(AS_IO, &m_io_config)
// };
// else
-// return space_config_vector {
-// std::make_pair(AS_PROGRAM, &m_program_config),
-// std::make_pair(AS_IO, &m_io_config)
+// return device_memory_interface_space_config_vector {
+// std_make_pair(AS_PROGRAM, &m_program_config),
+// std_make_pair(AS_IO, &m_io_config)
// };
//}
-uint8_t /*z180_device::*/z180_readcontrol(offs_t port)
+uint8_t z180_device_z180_readcontrol(offs_t port)
{
/* normal external readport */
uint8_t data = m_iospace_read_byte(port);
return data;
}
-void /*z180_device::*/z180_writecontrol(offs_t port, uint8_t data)
+void z180_device_z180_writecontrol(offs_t port, uint8_t data)
{
/* normal external write port */
m_iospace_write_byte(port, data);
case Z180_CBR:
LOG("Z180 CBR wr $%02x ($%02x)\n", data, data & Z180_CBR_WMASK);
IO_CBR = (IO_CBR & ~Z180_CBR_WMASK) | (data & Z180_CBR_WMASK);
- z180_mmu();
+ z180_device_z180_mmu();
break;
case Z180_BBR:
LOG("Z180 BBR wr $%02x ($%02x)\n", data, data & Z180_BBR_WMASK);
IO_BBR = (IO_BBR & ~Z180_BBR_WMASK) | (data & Z180_BBR_WMASK);
- z180_mmu();
+ z180_device_z180_mmu();
break;
case Z180_CBAR:
LOG("Z180 CBAR wr $%02x ($%02x)\n", data, data & Z180_CBAR_WMASK);
IO_CBAR = (IO_CBAR & ~Z180_CBAR_WMASK) | (data & Z180_CBAR_WMASK);
- z180_mmu();
+ z180_device_z180_mmu();
break;
case Z180_IO3B:
}
}
-int /*z180_device::*/z180_dma0(int max_cycles)
+int z180_device_z180_dma0(int max_cycles)
{
offs_t sar0 = 65536 * IO_SAR0B + 256 * IO_SAR0H + IO_SAR0L;
offs_t dar0 = 65536 * IO_DAR0B + 256 * IO_DAR0H + IO_DAR0L;
case 0x0c: /* I/O SAR0 fixed to memory DAR0+1 */
if (m_iol & Z180_DREQ0)
{
- m_program_write_byte(dar0++, IN(sar0));
+ m_program_write_byte(dar0++, z180_device_IN(sar0));
cycles += IO_DCNTL >> 6; // memory wait states
bcr0--;
/* edge sensitive DREQ0 ? */
case 0x1c: /* I/O SAR0 fixed to memory DAR0-1 */
if (m_iol & Z180_DREQ0)
{
- m_program_write_byte(dar0--, IN(sar0));
+ m_program_write_byte(dar0--, z180_device_IN(sar0));
cycles += IO_DCNTL >> 6; // memory wait states
bcr0--;
/* edge sensitive DREQ0 ? */
case 0x30: /* memory SAR0+1 to I/O DAR0 fixed */
if (m_iol & Z180_DREQ0)
{
- OUT(dar0, m_program_read_byte(sar0++));
+ z180_device_OUT(dar0, m_program_read_byte(sar0++));
cycles += IO_DCNTL >> 6; // memory wait states
bcr0--;
/* edge sensitive DREQ0 ? */
case 0x34: /* memory SAR0-1 to I/O DAR0 fixed */
if (m_iol & Z180_DREQ0)
{
- OUT(dar0, m_program_read_byte(sar0--));
+ z180_device_OUT(dar0, m_program_read_byte(sar0--));
cycles += IO_DCNTL >> 6; // memory wait states
bcr0--;
/* edge sensitive DREQ0 ? */
return cycles;
}
-int /*z180_device::*/z180_dma1()
+int z180_device_z180_dma1()
{
offs_t mar1 = 65536 * IO_MAR1B + 256 * IO_MAR1H + IO_MAR1L;
offs_t iar1 = 256 * IO_IAR1H + IO_IAR1L;
return 6 + cycles;
}
-void /*z180_device::*/z180_write_iolines(uint32_t data)
+void z180_device_z180_write_iolines(uint32_t data)
{
uint32_t changes = m_iol ^ data;
}
}
-void /*z180_device::*/device_start()
+void z180_device_device_start()
{
int i, p;
int oldval, newval, val;
uint8_t *padd, *padc, *psub, *psbc;
/* allocate big flag arrays once */
- SZHVC_add = (uint8_t *)malloc(2*256*256); //std::make_unique<uint8_t[]>(2*256*256);
+ SZHVC_add = (uint8_t *)malloc(2*256*256); //std_make_unique<uint8_t[]>(2*256*256);
rassert(SZHVC_add);
- SZHVC_sub = (uint8_t *)malloc(2*256*256); //std::make_unique<uint8_t[]>(2*256*256);
+ SZHVC_sub = (uint8_t *)malloc(2*256*256); //std_make_unique<uint8_t[]>(2*256*256);
rassert(SZHVC_sub);
padd = &SZHVC_add[ 0*256];
/****************************************************************************
* Reset registers to their initial values
****************************************************************************/
-void /*z180_device::*/device_reset()
+void z180_device_device_reset()
{
_PPC = 0;
_PCD = 0;
IO_OMCR = Z180_OMCR_RESET;
IO_IOCR = Z180_IOCR_RESET;
- z180_mmu();
+ z180_device_z180_mmu();
}
/* Handle PRT timers, decreasing them after 20 clocks and returning the new icount base that needs to be used for the next check */
-void /*z180_device::*/clock_timers()
+void z180_device_clock_timers()
{
m_timer_cnt++;
if (m_timer_cnt >= 20)
}
}
-int /*z180_device::*/check_interrupts()
+int z180_device_check_interrupts()
{
int i;
int cycles = 0;
for (i = 0; i <= Z180_INT_MAX; i++)
if (m_int_pending[i])
{
- cycles += take_interrupt(i);
+ cycles += z180_device_take_interrupt(i);
m_int_pending[i] = 0;
break;
}
* Handle I/O and timers
****************************************************************************/
-void /*z180_device::*/handle_io_timers(int cycles)
+void z180_device_handle_io_timers(int cycles)
{
while (cycles-- > 0)
{
- clock_timers();
+ z180_device_clock_timers();
}
}
/****************************************************************************
* Execute 'cycles' T-states. Return number of T-states really executed
****************************************************************************/
-void /*z180_device::*/execute_run()
+void z180_device_execute_run()
{
int curcycles;
_PCD = 0x0066;
m_icount -= 11;
m_nmi_pending = 0;
- handle_io_timers(11);
+ z180_device_handle_io_timers(11);
}
again:
debugger_instruction_hook(_PCD);
/* FIXME z180_dma0 should be handled in handle_io_timers */
- curcycles = z180_dma0(m_icount);
+ curcycles = z180_device_z180_dma0(m_icount);
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
}
else
{
do
{
- curcycles = check_interrupts();
+ curcycles = z180_device_check_interrupts();
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
m_after_EI = 0;
_PPC = _PCD;
m_R++;
IO_FRC++; /* Added FRC counting, not implemented yet */
m_extra_cycles = 0;
- curcycles = exec_op(ROP());
+ curcycles = z180_device_exec_op(z180_device_ROP());
curcycles += m_extra_cycles;
}
else
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
/* if channel 0 was started in burst mode, go recheck the mode */
if ((IO_DSTAT & Z180_DSTAT_DE0) == Z180_DSTAT_DE0 &&
* channel 1 releases control of the bus.
*
*/
- curcycles = z180_dma0(6);
+ curcycles = z180_device_z180_dma0(6);
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
- curcycles = z180_dma1();
+ curcycles = z180_device_z180_dma1();
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
/* If DMA is done break out to the faster loop */
if ((IO_DSTAT & Z180_DSTAT_DME) != Z180_DSTAT_DME)
if ((IO_DSTAT & Z180_DSTAT_DME) == Z180_DSTAT_DME)
goto again;
- curcycles = check_interrupts();
+ curcycles = z180_device_check_interrupts();
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
m_after_EI = 0;
_PPC = _PCD;
m_R++;
IO_FRC++; /* Added FRC counting, not implemented yet */
m_extra_cycles = 0;
- curcycles = exec_op(ROP());
+ curcycles = z180_device_exec_op(z180_device_ROP());
curcycles += m_extra_cycles;
}
else
curcycles = 3;
m_icount -= curcycles;
- handle_io_timers(curcycles);
+ z180_device_handle_io_timers(curcycles);
} while( m_icount > 0 );
}
}
/****************************************************************************
* Burn 'cycles' T-states. Adjust R register for the lost time
****************************************************************************/
-void /*z180_device::*/execute_burn(int32_t cycles)
+void z180_device_execute_burn(int32_t cycles)
{
int extra_cycles = IO_DCNTL >> 6; // memory wait states
/* FIXME: This is not appropriate for dma */
while ( (cycles > 0) )
{
- handle_io_timers(3 + extra_cycles);
+ z180_device_handle_io_timers(3 + extra_cycles);
/* NOP takes 3 cycles per instruction */
m_R += 1;
m_icount -= 3 + extra_cycles;
/****************************************************************************
* Set IRQ line state
****************************************************************************/
-void /*z180_device::*/execute_set_input(int irqline, int state)
+void z180_device_execute_set_input(int irqline, int state)
{
if (irqline == INPUT_LINE_NMI)
{
uint32_t iol = m_iol & ~Z180_DREQ0;
if(state == ASSERT_LINE)
iol |= Z180_DREQ0;
- z180_write_iolines(iol);
+ z180_device_z180_write_iolines(iol);
} else if(irqline == Z180_INPUT_LINE_DREQ1) {
uint32_t iol = m_iol & ~Z180_DREQ1;
if(state == ASSERT_LINE)
iol |= Z180_DREQ1;
- z180_write_iolines(iol);
+ z180_device_z180_write_iolines(iol);
}
}
}
/* logical to physical address translation */
-//bool /*z180_device::*/memory_translate(int spacenum, int intention, offs_t &address)
+//bool z180_device_memory_translate(int spacenum, int intention, offs_t &address)
//{
// if (spacenum == AS_PROGRAM)
// {
* STATE IMPORT/EXPORT
**************************************************************************/
-//void /*z180_device::*/state_import(const device_state_entry &entry)
+//void z180_device_state_import(const device_state_entry &entry)
//{
// switch (entry.index())
// {
// case Z180_CBR:
// case Z180_BBR:
// case Z180_CBAR:
-// z180_mmu();
+// z180_device_z180_mmu();
// break;
//
// case Z180_IOLINES:
-// z180_write_iolines(m_ioltemp);
+// z180_device_z180_write_iolines(m_ioltemp);
// break;
//
// default:
//}
//
//
-//void /*z180_device::*/state_export(const device_state_entry &entry)
+//void z180_device_state_export(const device_state_entry &entry)
//{
// switch (entry.index())
// {
// }
//}
//
-//void /*z180_device::*/state_string_export(const device_state_entry &entry, std::string &str) const
+//void z180_device_state_string_export(const device_state_entry &entry, std_string &str) const
//{
// switch (entry.index())
// {
// case STATE_GENFLAGS:
-// str = string_format("%c%c%c%c%c%c%c%c",
+// str = std_string_format("%c%c%c%c%c%c%c%c",
// m_AF.b.l & 0x80 ? 'S':'.',
// m_AF.b.l & 0x40 ? 'Z':'.',
// m_AF.b.l & 0x20 ? '5':'.',
//{
//public:
// // construction/destruction
-// z180_device(const machine_config &mconfig, const char *_tag, device_t *_owner, uint32_t _clock);
+// z180_device_z180_device(const machine_config &mconfig, const char *_tag, device_t *_owner, uint32_t _clock);
- bool get_tend0();
- bool get_tend1();
+ bool z180_device_get_tend0();
+ bool z180_device_get_tend1();
//protected:
// // device-level overrides
-// virtual void device_start() override;
-void /*z180_device::*/device_start();
-// virtual void device_reset() override;
-void /*z180_device::*/device_reset();
+// virtual void z180_device_device_start() override;
+void z180_device_device_start();
+// virtual void z180_device_device_reset() override;
+void z180_device_device_reset();
// // device_execute_interface overrides
// virtual uint32_t execute_min_cycles() const override { return 1; }
// virtual uint32_t execute_input_lines() const override { return 5; }
// virtual uint32_t execute_default_irq_vector(int inputnum) const override { return 0xff; }
// virtual bool execute_input_edge_triggered(int inputnum) const override { return inputnum == INPUT_LINE_NMI; }
-// virtual void execute_run() override;
-void /*z180_device::*/execute_run();
-// virtual void execute_burn(int32_t cycles) override;
-void /*z180_device::*/execute_burn(int32_t cycles);
-// virtual void execute_set_input(int inputnum, int state) override;
-void /*z180_device::*/execute_set_input(int irqline, int state);
+// virtual void z180_device_execute_run() override;
+void z180_device_execute_run();
+// virtual void z180_device_execute_burn(int32_t cycles) override;
+void z180_device_execute_burn(int32_t cycles);
+// virtual void z180_device_execute_set_input(int inputnum, int state) override;
+void z180_device_execute_set_input(int irqline, int state);
// // device_memory_interface overrides
-// virtual space_config_vector memory_space_config() const override;
-// virtual bool memory_translate(int spacenum, int intention, offs_t &address) override;
+// virtual device_memory_interface_space_config_vector z180_device_memory_space_config() const override;
+// virtual bool z180_device_memory_translate(int spacenum, int intention, offs_t &address) override;
//
// // device_state_interface overrides
-// virtual void state_import(const device_state_entry &entry) override;
-// virtual void state_export(const device_state_entry &entry) override;
-// virtual void state_string_export(const device_state_entry &entry, std::string &str) const override;
+// virtual void z180_device_state_import(const device_state_entry &entry) override;
+// virtual void z180_device_state_export(const device_state_entry &entry) override;
+// virtual void state_std_string_export(const device_state_entry &entry, std_string &str) const override;
//
-// // device_disasm_interface overrides
-// virtual std::unique_ptr<util::disasm_interface> create_disassembler() override;
+// // device_util_disasm_interface overrides
+// virtual std_unique_ptr<util_disasm_interface> z180_device_create_disassembler() override;
//
//private:
// address_space_config m_program_config;
int m_extra_cycles; /* extra cpu cycles */
uint8_t *m_cc[6];
- typedef void (/*z180_device::*/*opcode_func)();
-// static const opcode_func s_z180ops[6][0x100];
-extern const /*z180_device::*/opcode_func /*z180_device::*/s_z180ops[/*Z180_PREFIX_COUNT*/6][0x100];
+ typedef void (*z180_device_opcode_func)();
+// static const z180_device_opcode_func z180_device_s_z180ops[6][0x100];
+extern const z180_device_opcode_func z180_device_s_z180ops[/*Z180_PREFIX_COUNT*/6][0x100];
- /*inline*/ void z180_mmu();
- /*inline*/ u8 RM(offs_t addr);
- /*inline*/ u8 IN(u16 port);
- /*inline*/ void OUT(u16 port, u8 value);
- /*inline*/ void RM16( offs_t addr, PAIR *r );
- /*inline*/ void WM16( offs_t addr, PAIR *r );
- /*inline*/ uint8_t ROP();
- /*inline*/ uint8_t ARG();
- /*inline*/ uint32_t ARG16();
- /*inline*/ uint8_t INC(uint8_t value);
- /*inline*/ uint8_t DEC(uint8_t value);
- /*inline*/ uint8_t RLC(uint8_t value);
- /*inline*/ uint8_t RRC(uint8_t value);
- /*inline*/ uint8_t RL(uint8_t value);
- /*inline*/ uint8_t RR(uint8_t value);
- /*inline*/ uint8_t SLA(uint8_t value);
- /*inline*/ uint8_t SRA(uint8_t value);
- /*inline*/ uint8_t SLL(uint8_t value);
- /*inline*/ uint8_t SRL(uint8_t value);
- /*inline*/ uint8_t RES(uint8_t bit, uint8_t value);
- /*inline*/ uint8_t SET(uint8_t bit, uint8_t value);
- /*inline*/ int exec_op(const uint8_t opcode);
- /*inline*/ int exec_cb(const uint8_t opcode);
- /*inline*/ int exec_dd(const uint8_t opcode);
- /*inline*/ int exec_ed(const uint8_t opcode);
- /*inline*/ int exec_fd(const uint8_t opcode);
- /*inline*/ int exec_xycb(const uint8_t opcode);
- int take_interrupt(int irq);
- uint8_t z180_readcontrol(offs_t port);
- void z180_writecontrol(offs_t port, uint8_t data);
- int z180_dma0(int max_cycles);
- int z180_dma1();
- void z180_write_iolines(uint32_t data);
- void clock_timers();
- int check_interrupts();
- void handle_io_timers(int cycles);
+ /*inline*/ void z180_device_z180_mmu();
+ /*inline*/ u8 z180_device_RM(offs_t addr);
+ /*inline*/ u8 z180_device_IN(u16 port);
+ /*inline*/ void z180_device_OUT(u16 port, u8 value);
+ /*inline*/ void z180_device_RM16( offs_t addr, PAIR *r );
+ /*inline*/ void z180_device_WM16( offs_t addr, PAIR *r );
+ /*inline*/ uint8_t z180_device_ROP();
+ /*inline*/ uint8_t z180_device_ARG();
+ /*inline*/ uint32_t z180_device_ARG16();
+ /*inline*/ uint8_t z180_device_INC(uint8_t value);
+ /*inline*/ uint8_t z180_device_DEC(uint8_t value);
+ /*inline*/ uint8_t z180_device_RLC(uint8_t value);
+ /*inline*/ uint8_t z180_device_RRC(uint8_t value);
+ /*inline*/ uint8_t z180_device_RL(uint8_t value);
+ /*inline*/ uint8_t z180_device_RR(uint8_t value);
+ /*inline*/ uint8_t z180_device_SLA(uint8_t value);
+ /*inline*/ uint8_t z180_device_SRA(uint8_t value);
+ /*inline*/ uint8_t z180_device_SLL(uint8_t value);
+ /*inline*/ uint8_t z180_device_SRL(uint8_t value);
+ /*inline*/ uint8_t z180_device_RES(uint8_t bit, uint8_t value);
+ /*inline*/ uint8_t z180_device_SET(uint8_t bit, uint8_t value);
+ /*inline*/ int z180_device_exec_op(const uint8_t opcode);
+ /*inline*/ int z180_device_exec_cb(const uint8_t opcode);
+ /*inline*/ int z180_device_exec_dd(const uint8_t opcode);
+ /*inline*/ int z180_device_exec_ed(const uint8_t opcode);
+ /*inline*/ int z180_device_exec_fd(const uint8_t opcode);
+ /*inline*/ int z180_device_exec_xycb(const uint8_t opcode);
+ int z180_device_take_interrupt(int irq);
+ uint8_t z180_device_z180_readcontrol(offs_t port);
+ void z180_device_z180_writecontrol(offs_t port, uint8_t data);
+ int z180_device_z180_dma0(int max_cycles);
+ int z180_device_z180_dma1();
+ void z180_device_z180_write_iolines(uint32_t data);
+ void z180_device_clock_timers();
+ int z180_device_check_interrupts();
+ void z180_device_handle_io_timers(int cycles);
- void op_00();
- void op_01();
- void op_02();
- void op_03();
- void op_04();
- void op_05();
- void op_06();
- void op_07();
- void op_08();
- void op_09();
- void op_0a();
- void op_0b();
- void op_0c();
- void op_0d();
- void op_0e();
- void op_0f();
- void op_10();
- void op_11();
- void op_12();
- void op_13();
- void op_14();
- void op_15();
- void op_16();
- void op_17();
- void op_18();
- void op_19();
- void op_1a();
- void op_1b();
- void op_1c();
- void op_1d();
- void op_1e();
- void op_1f();
- void op_20();
- void op_21();
- void op_22();
- void op_23();
- void op_24();
- void op_25();
- void op_26();
- void op_27();
- void op_28();
- void op_29();
- void op_2a();
- void op_2b();
- void op_2c();
- void op_2d();
- void op_2e();
- void op_2f();
- void op_30();
- void op_31();
- void op_32();
- void op_33();
- void op_34();
- void op_35();
- void op_36();
- void op_37();
- void op_38();
- void op_39();
- void op_3a();
- void op_3b();
- void op_3c();
- void op_3d();
- void op_3e();
- void op_3f();
- void op_40();
- void op_41();
- void op_42();
- void op_43();
- void op_44();
- void op_45();
- void op_46();
- void op_47();
- void op_48();
- void op_49();
- void op_4a();
- void op_4b();
- void op_4c();
- void op_4d();
- void op_4e();
- void op_4f();
- void op_50();
- void op_51();
- void op_52();
- void op_53();
- void op_54();
- void op_55();
- void op_56();
- void op_57();
- void op_58();
- void op_59();
- void op_5a();
- void op_5b();
- void op_5c();
- void op_5d();
- void op_5e();
- void op_5f();
- void op_60();
- void op_61();
- void op_62();
- void op_63();
- void op_64();
- void op_65();
- void op_66();
- void op_67();
- void op_68();
- void op_69();
- void op_6a();
- void op_6b();
- void op_6c();
- void op_6d();
- void op_6e();
- void op_6f();
- void op_70();
- void op_71();
- void op_72();
- void op_73();
- void op_74();
- void op_75();
- void op_76();
- void op_77();
- void op_78();
- void op_79();
- void op_7a();
- void op_7b();
- void op_7c();
- void op_7d();
- void op_7e();
- void op_7f();
- void op_80();
- void op_81();
- void op_82();
- void op_83();
- void op_84();
- void op_85();
- void op_86();
- void op_87();
- void op_88();
- void op_89();
- void op_8a();
- void op_8b();
- void op_8c();
- void op_8d();
- void op_8e();
- void op_8f();
- void op_90();
- void op_91();
- void op_92();
- void op_93();
- void op_94();
- void op_95();
- void op_96();
- void op_97();
- void op_98();
- void op_99();
- void op_9a();
- void op_9b();
- void op_9c();
- void op_9d();
- void op_9e();
- void op_9f();
- void op_a0();
- void op_a1();
- void op_a2();
- void op_a3();
- void op_a4();
- void op_a5();
- void op_a6();
- void op_a7();
- void op_a8();
- void op_a9();
- void op_aa();
- void op_ab();
- void op_ac();
- void op_ad();
- void op_ae();
- void op_af();
- void op_b0();
- void op_b1();
- void op_b2();
- void op_b3();
- void op_b4();
- void op_b5();
- void op_b6();
- void op_b7();
- void op_b8();
- void op_b9();
- void op_ba();
- void op_bb();
- void op_bc();
- void op_bd();
- void op_be();
- void op_bf();
- void op_c0();
- void op_c1();
- void op_c2();
- void op_c3();
- void op_c4();
- void op_c5();
- void op_c6();
- void op_c7();
- void op_c8();
- void op_c9();
- void op_ca();
- void op_cb();
- void op_cc();
- void op_cd();
- void op_ce();
- void op_cf();
- void op_d0();
- void op_d1();
- void op_d2();
- void op_d3();
- void op_d4();
- void op_d5();
- void op_d6();
- void op_d7();
- void op_d8();
- void op_d9();
- void op_da();
- void op_db();
- void op_dc();
- void op_dd();
- void op_de();
- void op_df();
- void op_e0();
- void op_e1();
- void op_e2();
- void op_e3();
- void op_e4();
- void op_e5();
- void op_e6();
- void op_e7();
- void op_e8();
- void op_e9();
- void op_ea();
- void op_eb();
- void op_ec();
- void op_ed();
- void op_ee();
- void op_ef();
- void op_f0();
- void op_f1();
- void op_f2();
- void op_f3();
- void op_f4();
- void op_f5();
- void op_f6();
- void op_f7();
- void op_f8();
- void op_f9();
- void op_fa();
- void op_fb();
- void op_fc();
- void op_fd();
- void op_fe();
- void op_ff();
- void cb_00();
- void cb_01();
- void cb_02();
- void cb_03();
- void cb_04();
- void cb_05();
- void cb_06();
- void cb_07();
- void cb_08();
- void cb_09();
- void cb_0a();
- void cb_0b();
- void cb_0c();
- void cb_0d();
- void cb_0e();
- void cb_0f();
- void cb_10();
- void cb_11();
- void cb_12();
- void cb_13();
- void cb_14();
- void cb_15();
- void cb_16();
- void cb_17();
- void cb_18();
- void cb_19();
- void cb_1a();
- void cb_1b();
- void cb_1c();
- void cb_1d();
- void cb_1e();
- void cb_1f();
- void cb_20();
- void cb_21();
- void cb_22();
- void cb_23();
- void cb_24();
- void cb_25();
- void cb_26();
- void cb_27();
- void cb_28();
- void cb_29();
- void cb_2a();
- void cb_2b();
- void cb_2c();
- void cb_2d();
- void cb_2e();
- void cb_2f();
- void cb_30();
- void cb_31();
- void cb_32();
- void cb_33();
- void cb_34();
- void cb_35();
- void cb_36();
- void cb_37();
- void cb_38();
- void cb_39();
- void cb_3a();
- void cb_3b();
- void cb_3c();
- void cb_3d();
- void cb_3e();
- void cb_3f();
- void cb_40();
- void cb_41();
- void cb_42();
- void cb_43();
- void cb_44();
- void cb_45();
- void cb_46();
- void cb_47();
- void cb_48();
- void cb_49();
- void cb_4a();
- void cb_4b();
- void cb_4c();
- void cb_4d();
- void cb_4e();
- void cb_4f();
- void cb_50();
- void cb_51();
- void cb_52();
- void cb_53();
- void cb_54();
- void cb_55();
- void cb_56();
- void cb_57();
- void cb_58();
- void cb_59();
- void cb_5a();
- void cb_5b();
- void cb_5c();
- void cb_5d();
- void cb_5e();
- void cb_5f();
- void cb_60();
- void cb_61();
- void cb_62();
- void cb_63();
- void cb_64();
- void cb_65();
- void cb_66();
- void cb_67();
- void cb_68();
- void cb_69();
- void cb_6a();
- void cb_6b();
- void cb_6c();
- void cb_6d();
- void cb_6e();
- void cb_6f();
- void cb_70();
- void cb_71();
- void cb_72();
- void cb_73();
- void cb_74();
- void cb_75();
- void cb_76();
- void cb_77();
- void cb_78();
- void cb_79();
- void cb_7a();
- void cb_7b();
- void cb_7c();
- void cb_7d();
- void cb_7e();
- void cb_7f();
- void cb_80();
- void cb_81();
- void cb_82();
- void cb_83();
- void cb_84();
- void cb_85();
- void cb_86();
- void cb_87();
- void cb_88();
- void cb_89();
- void cb_8a();
- void cb_8b();
- void cb_8c();
- void cb_8d();
- void cb_8e();
- void cb_8f();
- void cb_90();
- void cb_91();
- void cb_92();
- void cb_93();
- void cb_94();
- void cb_95();
- void cb_96();
- void cb_97();
- void cb_98();
- void cb_99();
- void cb_9a();
- void cb_9b();
- void cb_9c();
- void cb_9d();
- void cb_9e();
- void cb_9f();
- void cb_a0();
- void cb_a1();
- void cb_a2();
- void cb_a3();
- void cb_a4();
- void cb_a5();
- void cb_a6();
- void cb_a7();
- void cb_a8();
- void cb_a9();
- void cb_aa();
- void cb_ab();
- void cb_ac();
- void cb_ad();
- void cb_ae();
- void cb_af();
- void cb_b0();
- void cb_b1();
- void cb_b2();
- void cb_b3();
- void cb_b4();
- void cb_b5();
- void cb_b6();
- void cb_b7();
- void cb_b8();
- void cb_b9();
- void cb_ba();
- void cb_bb();
- void cb_bc();
- void cb_bd();
- void cb_be();
- void cb_bf();
- void cb_c0();
- void cb_c1();
- void cb_c2();
- void cb_c3();
- void cb_c4();
- void cb_c5();
- void cb_c6();
- void cb_c7();
- void cb_c8();
- void cb_c9();
- void cb_ca();
- void cb_cb();
- void cb_cc();
- void cb_cd();
- void cb_ce();
- void cb_cf();
- void cb_d0();
- void cb_d1();
- void cb_d2();
- void cb_d3();
- void cb_d4();
- void cb_d5();
- void cb_d6();
- void cb_d7();
- void cb_d8();
- void cb_d9();
- void cb_da();
- void cb_db();
- void cb_dc();
- void cb_dd();
- void cb_de();
- void cb_df();
- void cb_e0();
- void cb_e1();
- void cb_e2();
- void cb_e3();
- void cb_e4();
- void cb_e5();
- void cb_e6();
- void cb_e7();
- void cb_e8();
- void cb_e9();
- void cb_ea();
- void cb_eb();
- void cb_ec();
- void cb_ed();
- void cb_ee();
- void cb_ef();
- void cb_f0();
- void cb_f1();
- void cb_f2();
- void cb_f3();
- void cb_f4();
- void cb_f5();
- void cb_f6();
- void cb_f7();
- void cb_f8();
- void cb_f9();
- void cb_fa();
- void cb_fb();
- void cb_fc();
- void cb_fd();
- void cb_fe();
- void cb_ff();
- void illegal_1();
- void dd_00();
- void dd_01();
- void dd_02();
- void dd_03();
- void dd_04();
- void dd_05();
- void dd_06();
- void dd_07();
- void dd_08();
- void dd_09();
- void dd_0a();
- void dd_0b();
- void dd_0c();
- void dd_0d();
- void dd_0e();
- void dd_0f();
- void dd_10();
- void dd_11();
- void dd_12();
- void dd_13();
- void dd_14();
- void dd_15();
- void dd_16();
- void dd_17();
- void dd_18();
- void dd_19();
- void dd_1a();
- void dd_1b();
- void dd_1c();
- void dd_1d();
- void dd_1e();
- void dd_1f();
- void dd_20();
- void dd_21();
- void dd_22();
- void dd_23();
- void dd_24();
- void dd_25();
- void dd_26();
- void dd_27();
- void dd_28();
- void dd_29();
- void dd_2a();
- void dd_2b();
- void dd_2c();
- void dd_2d();
- void dd_2e();
- void dd_2f();
- void dd_30();
- void dd_31();
- void dd_32();
- void dd_33();
- void dd_34();
- void dd_35();
- void dd_36();
- void dd_37();
- void dd_38();
- void dd_39();
- void dd_3a();
- void dd_3b();
- void dd_3c();
- void dd_3d();
- void dd_3e();
- void dd_3f();
- void dd_40();
- void dd_41();
- void dd_42();
- void dd_43();
- void dd_44();
- void dd_45();
- void dd_46();
- void dd_47();
- void dd_48();
- void dd_49();
- void dd_4a();
- void dd_4b();
- void dd_4c();
- void dd_4d();
- void dd_4e();
- void dd_4f();
- void dd_50();
- void dd_51();
- void dd_52();
- void dd_53();
- void dd_54();
- void dd_55();
- void dd_56();
- void dd_57();
- void dd_58();
- void dd_59();
- void dd_5a();
- void dd_5b();
- void dd_5c();
- void dd_5d();
- void dd_5e();
- void dd_5f();
- void dd_60();
- void dd_61();
- void dd_62();
- void dd_63();
- void dd_64();
- void dd_65();
- void dd_66();
- void dd_67();
- void dd_68();
- void dd_69();
- void dd_6a();
- void dd_6b();
- void dd_6c();
- void dd_6d();
- void dd_6e();
- void dd_6f();
- void dd_70();
- void dd_71();
- void dd_72();
- void dd_73();
- void dd_74();
- void dd_75();
- void dd_76();
- void dd_77();
- void dd_78();
- void dd_79();
- void dd_7a();
- void dd_7b();
- void dd_7c();
- void dd_7d();
- void dd_7e();
- void dd_7f();
- void dd_80();
- void dd_81();
- void dd_82();
- void dd_83();
- void dd_84();
- void dd_85();
- void dd_86();
- void dd_87();
- void dd_88();
- void dd_89();
- void dd_8a();
- void dd_8b();
- void dd_8c();
- void dd_8d();
- void dd_8e();
- void dd_8f();
- void dd_90();
- void dd_91();
- void dd_92();
- void dd_93();
- void dd_94();
- void dd_95();
- void dd_96();
- void dd_97();
- void dd_98();
- void dd_99();
- void dd_9a();
- void dd_9b();
- void dd_9c();
- void dd_9d();
- void dd_9e();
- void dd_9f();
- void dd_a0();
- void dd_a1();
- void dd_a2();
- void dd_a3();
- void dd_a4();
- void dd_a5();
- void dd_a6();
- void dd_a7();
- void dd_a8();
- void dd_a9();
- void dd_aa();
- void dd_ab();
- void dd_ac();
- void dd_ad();
- void dd_ae();
- void dd_af();
- void dd_b0();
- void dd_b1();
- void dd_b2();
- void dd_b3();
- void dd_b4();
- void dd_b5();
- void dd_b6();
- void dd_b7();
- void dd_b8();
- void dd_b9();
- void dd_ba();
- void dd_bb();
- void dd_bc();
- void dd_bd();
- void dd_be();
- void dd_bf();
- void dd_c0();
- void dd_c1();
- void dd_c2();
- void dd_c3();
- void dd_c4();
- void dd_c5();
- void dd_c6();
- void dd_c7();
- void dd_c8();
- void dd_c9();
- void dd_ca();
- void dd_cb();
- void dd_cc();
- void dd_cd();
- void dd_ce();
- void dd_cf();
- void dd_d0();
- void dd_d1();
- void dd_d2();
- void dd_d3();
- void dd_d4();
- void dd_d5();
- void dd_d6();
- void dd_d7();
- void dd_d8();
- void dd_d9();
- void dd_da();
- void dd_db();
- void dd_dc();
- void dd_dd();
- void dd_de();
- void dd_df();
- void dd_e0();
- void dd_e1();
- void dd_e2();
- void dd_e3();
- void dd_e4();
- void dd_e5();
- void dd_e6();
- void dd_e7();
- void dd_e8();
- void dd_e9();
- void dd_ea();
- void dd_eb();
- void dd_ec();
- void dd_ed();
- void dd_ee();
- void dd_ef();
- void dd_f0();
- void dd_f1();
- void dd_f2();
- void dd_f3();
- void dd_f4();
- void dd_f5();
- void dd_f6();
- void dd_f7();
- void dd_f8();
- void dd_f9();
- void dd_fa();
- void dd_fb();
- void dd_fc();
- void dd_fd();
- void dd_fe();
- void dd_ff();
- void illegal_2();
- void ed_00();
- void ed_01();
- void ed_02();
- void ed_03();
- void ed_04();
- void ed_05();
- void ed_06();
- void ed_07();
- void ed_08();
- void ed_09();
- void ed_0a();
- void ed_0b();
- void ed_0c();
- void ed_0d();
- void ed_0e();
- void ed_0f();
- void ed_10();
- void ed_11();
- void ed_12();
- void ed_13();
- void ed_14();
- void ed_15();
- void ed_16();
- void ed_17();
- void ed_18();
- void ed_19();
- void ed_1a();
- void ed_1b();
- void ed_1c();
- void ed_1d();
- void ed_1e();
- void ed_1f();
- void ed_20();
- void ed_21();
- void ed_22();
- void ed_23();
- void ed_24();
- void ed_25();
- void ed_26();
- void ed_27();
- void ed_28();
- void ed_29();
- void ed_2a();
- void ed_2b();
- void ed_2c();
- void ed_2d();
- void ed_2e();
- void ed_2f();
- void ed_30();
- void ed_31();
- void ed_32();
- void ed_33();
- void ed_34();
- void ed_35();
- void ed_36();
- void ed_37();
- void ed_38();
- void ed_39();
- void ed_3a();
- void ed_3b();
- void ed_3c();
- void ed_3d();
- void ed_3e();
- void ed_3f();
- void ed_40();
- void ed_41();
- void ed_42();
- void ed_43();
- void ed_44();
- void ed_45();
- void ed_46();
- void ed_47();
- void ed_48();
- void ed_49();
- void ed_4a();
- void ed_4b();
- void ed_4c();
- void ed_4d();
- void ed_4e();
- void ed_4f();
- void ed_50();
- void ed_51();
- void ed_52();
- void ed_53();
- void ed_54();
- void ed_55();
- void ed_56();
- void ed_57();
- void ed_58();
- void ed_59();
- void ed_5a();
- void ed_5b();
- void ed_5c();
- void ed_5d();
- void ed_5e();
- void ed_5f();
- void ed_60();
- void ed_61();
- void ed_62();
- void ed_63();
- void ed_64();
- void ed_65();
- void ed_66();
- void ed_67();
- void ed_68();
- void ed_69();
- void ed_6a();
- void ed_6b();
- void ed_6c();
- void ed_6d();
- void ed_6e();
- void ed_6f();
- void ed_70();
- void ed_71();
- void ed_72();
- void ed_73();
- void ed_74();
- void ed_75();
- void ed_76();
- void ed_77();
- void ed_78();
- void ed_79();
- void ed_7a();
- void ed_7b();
- void ed_7c();
- void ed_7d();
- void ed_7e();
- void ed_7f();
- void ed_80();
- void ed_81();
- void ed_82();
- void ed_83();
- void ed_84();
- void ed_85();
- void ed_86();
- void ed_87();
- void ed_88();
- void ed_89();
- void ed_8a();
- void ed_8b();
- void ed_8c();
- void ed_8d();
- void ed_8e();
- void ed_8f();
- void ed_90();
- void ed_91();
- void ed_92();
- void ed_93();
- void ed_94();
- void ed_95();
- void ed_96();
- void ed_97();
- void ed_98();
- void ed_99();
- void ed_9a();
- void ed_9b();
- void ed_9c();
- void ed_9d();
- void ed_9e();
- void ed_9f();
- void ed_a0();
- void ed_a1();
- void ed_a2();
- void ed_a3();
- void ed_a4();
- void ed_a5();
- void ed_a6();
- void ed_a7();
- void ed_a8();
- void ed_a9();
- void ed_aa();
- void ed_ab();
- void ed_ac();
- void ed_ad();
- void ed_ae();
- void ed_af();
- void ed_b0();
- void ed_b1();
- void ed_b2();
- void ed_b3();
- void ed_b4();
- void ed_b5();
- void ed_b6();
- void ed_b7();
- void ed_b8();
- void ed_b9();
- void ed_ba();
- void ed_bb();
- void ed_bc();
- void ed_bd();
- void ed_be();
- void ed_bf();
- void ed_c0();
- void ed_c1();
- void ed_c2();
- void ed_c3();
- void ed_c4();
- void ed_c5();
- void ed_c6();
- void ed_c7();
- void ed_c8();
- void ed_c9();
- void ed_ca();
- void ed_cb();
- void ed_cc();
- void ed_cd();
- void ed_ce();
- void ed_cf();
- void ed_d0();
- void ed_d1();
- void ed_d2();
- void ed_d3();
- void ed_d4();
- void ed_d5();
- void ed_d6();
- void ed_d7();
- void ed_d8();
- void ed_d9();
- void ed_da();
- void ed_db();
- void ed_dc();
- void ed_dd();
- void ed_de();
- void ed_df();
- void ed_e0();
- void ed_e1();
- void ed_e2();
- void ed_e3();
- void ed_e4();
- void ed_e5();
- void ed_e6();
- void ed_e7();
- void ed_e8();
- void ed_e9();
- void ed_ea();
- void ed_eb();
- void ed_ec();
- void ed_ed();
- void ed_ee();
- void ed_ef();
- void ed_f0();
- void ed_f1();
- void ed_f2();
- void ed_f3();
- void ed_f4();
- void ed_f5();
- void ed_f6();
- void ed_f7();
- void ed_f8();
- void ed_f9();
- void ed_fa();
- void ed_fb();
- void ed_fc();
- void ed_fd();
- void ed_fe();
- void ed_ff();
- void fd_00();
- void fd_01();
- void fd_02();
- void fd_03();
- void fd_04();
- void fd_05();
- void fd_06();
- void fd_07();
- void fd_08();
- void fd_09();
- void fd_0a();
- void fd_0b();
- void fd_0c();
- void fd_0d();
- void fd_0e();
- void fd_0f();
- void fd_10();
- void fd_11();
- void fd_12();
- void fd_13();
- void fd_14();
- void fd_15();
- void fd_16();
- void fd_17();
- void fd_18();
- void fd_19();
- void fd_1a();
- void fd_1b();
- void fd_1c();
- void fd_1d();
- void fd_1e();
- void fd_1f();
- void fd_20();
- void fd_21();
- void fd_22();
- void fd_23();
- void fd_24();
- void fd_25();
- void fd_26();
- void fd_27();
- void fd_28();
- void fd_29();
- void fd_2a();
- void fd_2b();
- void fd_2c();
- void fd_2d();
- void fd_2e();
- void fd_2f();
- void fd_30();
- void fd_31();
- void fd_32();
- void fd_33();
- void fd_34();
- void fd_35();
- void fd_36();
- void fd_37();
- void fd_38();
- void fd_39();
- void fd_3a();
- void fd_3b();
- void fd_3c();
- void fd_3d();
- void fd_3e();
- void fd_3f();
- void fd_40();
- void fd_41();
- void fd_42();
- void fd_43();
- void fd_44();
- void fd_45();
- void fd_46();
- void fd_47();
- void fd_48();
- void fd_49();
- void fd_4a();
- void fd_4b();
- void fd_4c();
- void fd_4d();
- void fd_4e();
- void fd_4f();
- void fd_50();
- void fd_51();
- void fd_52();
- void fd_53();
- void fd_54();
- void fd_55();
- void fd_56();
- void fd_57();
- void fd_58();
- void fd_59();
- void fd_5a();
- void fd_5b();
- void fd_5c();
- void fd_5d();
- void fd_5e();
- void fd_5f();
- void fd_60();
- void fd_61();
- void fd_62();
- void fd_63();
- void fd_64();
- void fd_65();
- void fd_66();
- void fd_67();
- void fd_68();
- void fd_69();
- void fd_6a();
- void fd_6b();
- void fd_6c();
- void fd_6d();
- void fd_6e();
- void fd_6f();
- void fd_70();
- void fd_71();
- void fd_72();
- void fd_73();
- void fd_74();
- void fd_75();
- void fd_76();
- void fd_77();
- void fd_78();
- void fd_79();
- void fd_7a();
- void fd_7b();
- void fd_7c();
- void fd_7d();
- void fd_7e();
- void fd_7f();
- void fd_80();
- void fd_81();
- void fd_82();
- void fd_83();
- void fd_84();
- void fd_85();
- void fd_86();
- void fd_87();
- void fd_88();
- void fd_89();
- void fd_8a();
- void fd_8b();
- void fd_8c();
- void fd_8d();
- void fd_8e();
- void fd_8f();
- void fd_90();
- void fd_91();
- void fd_92();
- void fd_93();
- void fd_94();
- void fd_95();
- void fd_96();
- void fd_97();
- void fd_98();
- void fd_99();
- void fd_9a();
- void fd_9b();
- void fd_9c();
- void fd_9d();
- void fd_9e();
- void fd_9f();
- void fd_a0();
- void fd_a1();
- void fd_a2();
- void fd_a3();
- void fd_a4();
- void fd_a5();
- void fd_a6();
- void fd_a7();
- void fd_a8();
- void fd_a9();
- void fd_aa();
- void fd_ab();
- void fd_ac();
- void fd_ad();
- void fd_ae();
- void fd_af();
- void fd_b0();
- void fd_b1();
- void fd_b2();
- void fd_b3();
- void fd_b4();
- void fd_b5();
- void fd_b6();
- void fd_b7();
- void fd_b8();
- void fd_b9();
- void fd_ba();
- void fd_bb();
- void fd_bc();
- void fd_bd();
- void fd_be();
- void fd_bf();
- void fd_c0();
- void fd_c1();
- void fd_c2();
- void fd_c3();
- void fd_c4();
- void fd_c5();
- void fd_c6();
- void fd_c7();
- void fd_c8();
- void fd_c9();
- void fd_ca();
- void fd_cb();
- void fd_cc();
- void fd_cd();
- void fd_ce();
- void fd_cf();
- void fd_d0();
- void fd_d1();
- void fd_d2();
- void fd_d3();
- void fd_d4();
- void fd_d5();
- void fd_d6();
- void fd_d7();
- void fd_d8();
- void fd_d9();
- void fd_da();
- void fd_db();
- void fd_dc();
- void fd_dd();
- void fd_de();
- void fd_df();
- void fd_e0();
- void fd_e1();
- void fd_e2();
- void fd_e3();
- void fd_e4();
- void fd_e5();
- void fd_e6();
- void fd_e7();
- void fd_e8();
- void fd_e9();
- void fd_ea();
- void fd_eb();
- void fd_ec();
- void fd_ed();
- void fd_ee();
- void fd_ef();
- void fd_f0();
- void fd_f1();
- void fd_f2();
- void fd_f3();
- void fd_f4();
- void fd_f5();
- void fd_f6();
- void fd_f7();
- void fd_f8();
- void fd_f9();
- void fd_fa();
- void fd_fb();
- void fd_fc();
- void fd_fd();
- void fd_fe();
- void fd_ff();
- void xycb_00();
- void xycb_01();
- void xycb_02();
- void xycb_03();
- void xycb_04();
- void xycb_05();
- void xycb_06();
- void xycb_07();
- void xycb_08();
- void xycb_09();
- void xycb_0a();
- void xycb_0b();
- void xycb_0c();
- void xycb_0d();
- void xycb_0e();
- void xycb_0f();
- void xycb_10();
- void xycb_11();
- void xycb_12();
- void xycb_13();
- void xycb_14();
- void xycb_15();
- void xycb_16();
- void xycb_17();
- void xycb_18();
- void xycb_19();
- void xycb_1a();
- void xycb_1b();
- void xycb_1c();
- void xycb_1d();
- void xycb_1e();
- void xycb_1f();
- void xycb_20();
- void xycb_21();
- void xycb_22();
- void xycb_23();
- void xycb_24();
- void xycb_25();
- void xycb_26();
- void xycb_27();
- void xycb_28();
- void xycb_29();
- void xycb_2a();
- void xycb_2b();
- void xycb_2c();
- void xycb_2d();
- void xycb_2e();
- void xycb_2f();
- void xycb_30();
- void xycb_31();
- void xycb_32();
- void xycb_33();
- void xycb_34();
- void xycb_35();
- void xycb_36();
- void xycb_37();
- void xycb_38();
- void xycb_39();
- void xycb_3a();
- void xycb_3b();
- void xycb_3c();
- void xycb_3d();
- void xycb_3e();
- void xycb_3f();
- void xycb_40();
- void xycb_41();
- void xycb_42();
- void xycb_43();
- void xycb_44();
- void xycb_45();
- void xycb_46();
- void xycb_47();
- void xycb_48();
- void xycb_49();
- void xycb_4a();
- void xycb_4b();
- void xycb_4c();
- void xycb_4d();
- void xycb_4e();
- void xycb_4f();
- void xycb_50();
- void xycb_51();
- void xycb_52();
- void xycb_53();
- void xycb_54();
- void xycb_55();
- void xycb_56();
- void xycb_57();
- void xycb_58();
- void xycb_59();
- void xycb_5a();
- void xycb_5b();
- void xycb_5c();
- void xycb_5d();
- void xycb_5e();
- void xycb_5f();
- void xycb_60();
- void xycb_61();
- void xycb_62();
- void xycb_63();
- void xycb_64();
- void xycb_65();
- void xycb_66();
- void xycb_67();
- void xycb_68();
- void xycb_69();
- void xycb_6a();
- void xycb_6b();
- void xycb_6c();
- void xycb_6d();
- void xycb_6e();
- void xycb_6f();
- void xycb_70();
- void xycb_71();
- void xycb_72();
- void xycb_73();
- void xycb_74();
- void xycb_75();
- void xycb_76();
- void xycb_77();
- void xycb_78();
- void xycb_79();
- void xycb_7a();
- void xycb_7b();
- void xycb_7c();
- void xycb_7d();
- void xycb_7e();
- void xycb_7f();
- void xycb_80();
- void xycb_81();
- void xycb_82();
- void xycb_83();
- void xycb_84();
- void xycb_85();
- void xycb_86();
- void xycb_87();
- void xycb_88();
- void xycb_89();
- void xycb_8a();
- void xycb_8b();
- void xycb_8c();
- void xycb_8d();
- void xycb_8e();
- void xycb_8f();
- void xycb_90();
- void xycb_91();
- void xycb_92();
- void xycb_93();
- void xycb_94();
- void xycb_95();
- void xycb_96();
- void xycb_97();
- void xycb_98();
- void xycb_99();
- void xycb_9a();
- void xycb_9b();
- void xycb_9c();
- void xycb_9d();
- void xycb_9e();
- void xycb_9f();
- void xycb_a0();
- void xycb_a1();
- void xycb_a2();
- void xycb_a3();
- void xycb_a4();
- void xycb_a5();
- void xycb_a6();
- void xycb_a7();
- void xycb_a8();
- void xycb_a9();
- void xycb_aa();
- void xycb_ab();
- void xycb_ac();
- void xycb_ad();
- void xycb_ae();
- void xycb_af();
- void xycb_b0();
- void xycb_b1();
- void xycb_b2();
- void xycb_b3();
- void xycb_b4();
- void xycb_b5();
- void xycb_b6();
- void xycb_b7();
- void xycb_b8();
- void xycb_b9();
- void xycb_ba();
- void xycb_bb();
- void xycb_bc();
- void xycb_bd();
- void xycb_be();
- void xycb_bf();
- void xycb_c0();
- void xycb_c1();
- void xycb_c2();
- void xycb_c3();
- void xycb_c4();
- void xycb_c5();
- void xycb_c6();
- void xycb_c7();
- void xycb_c8();
- void xycb_c9();
- void xycb_ca();
- void xycb_cb();
- void xycb_cc();
- void xycb_cd();
- void xycb_ce();
- void xycb_cf();
- void xycb_d0();
- void xycb_d1();
- void xycb_d2();
- void xycb_d3();
- void xycb_d4();
- void xycb_d5();
- void xycb_d6();
- void xycb_d7();
- void xycb_d8();
- void xycb_d9();
- void xycb_da();
- void xycb_db();
- void xycb_dc();
- void xycb_dd();
- void xycb_de();
- void xycb_df();
- void xycb_e0();
- void xycb_e1();
- void xycb_e2();
- void xycb_e3();
- void xycb_e4();
- void xycb_e5();
- void xycb_e6();
- void xycb_e7();
- void xycb_e8();
- void xycb_e9();
- void xycb_ea();
- void xycb_eb();
- void xycb_ec();
- void xycb_ed();
- void xycb_ee();
- void xycb_ef();
- void xycb_f0();
- void xycb_f1();
- void xycb_f2();
- void xycb_f3();
- void xycb_f4();
- void xycb_f5();
- void xycb_f6();
- void xycb_f7();
- void xycb_f8();
- void xycb_f9();
- void xycb_fa();
- void xycb_fb();
- void xycb_fc();
- void xycb_fd();
- void xycb_fe();
- void xycb_ff();
+ void z180_device_op_00();
+ void z180_device_op_01();
+ void z180_device_op_02();
+ void z180_device_op_03();
+ void z180_device_op_04();
+ void z180_device_op_05();
+ void z180_device_op_06();
+ void z180_device_op_07();
+ void z180_device_op_08();
+ void z180_device_op_09();
+ void z180_device_op_0a();
+ void z180_device_op_0b();
+ void z180_device_op_0c();
+ void z180_device_op_0d();
+ void z180_device_op_0e();
+ void z180_device_op_0f();
+ void z180_device_op_10();
+ void z180_device_op_11();
+ void z180_device_op_12();
+ void z180_device_op_13();
+ void z180_device_op_14();
+ void z180_device_op_15();
+ void z180_device_op_16();
+ void z180_device_op_17();
+ void z180_device_op_18();
+ void z180_device_op_19();
+ void z180_device_op_1a();
+ void z180_device_op_1b();
+ void z180_device_op_1c();
+ void z180_device_op_1d();
+ void z180_device_op_1e();
+ void z180_device_op_1f();
+ void z180_device_op_20();
+ void z180_device_op_21();
+ void z180_device_op_22();
+ void z180_device_op_23();
+ void z180_device_op_24();
+ void z180_device_op_25();
+ void z180_device_op_26();
+ void z180_device_op_27();
+ void z180_device_op_28();
+ void z180_device_op_29();
+ void z180_device_op_2a();
+ void z180_device_op_2b();
+ void z180_device_op_2c();
+ void z180_device_op_2d();
+ void z180_device_op_2e();
+ void z180_device_op_2f();
+ void z180_device_op_30();
+ void z180_device_op_31();
+ void z180_device_op_32();
+ void z180_device_op_33();
+ void z180_device_op_34();
+ void z180_device_op_35();
+ void z180_device_op_36();
+ void z180_device_op_37();
+ void z180_device_op_38();
+ void z180_device_op_39();
+ void z180_device_op_3a();
+ void z180_device_op_3b();
+ void z180_device_op_3c();
+ void z180_device_op_3d();
+ void z180_device_op_3e();
+ void z180_device_op_3f();
+ void z180_device_op_40();
+ void z180_device_op_41();
+ void z180_device_op_42();
+ void z180_device_op_43();
+ void z180_device_op_44();
+ void z180_device_op_45();
+ void z180_device_op_46();
+ void z180_device_op_47();
+ void z180_device_op_48();
+ void z180_device_op_49();
+ void z180_device_op_4a();
+ void z180_device_op_4b();
+ void z180_device_op_4c();
+ void z180_device_op_4d();
+ void z180_device_op_4e();
+ void z180_device_op_4f();
+ void z180_device_op_50();
+ void z180_device_op_51();
+ void z180_device_op_52();
+ void z180_device_op_53();
+ void z180_device_op_54();
+ void z180_device_op_55();
+ void z180_device_op_56();
+ void z180_device_op_57();
+ void z180_device_op_58();
+ void z180_device_op_59();
+ void z180_device_op_5a();
+ void z180_device_op_5b();
+ void z180_device_op_5c();
+ void z180_device_op_5d();
+ void z180_device_op_5e();
+ void z180_device_op_5f();
+ void z180_device_op_60();
+ void z180_device_op_61();
+ void z180_device_op_62();
+ void z180_device_op_63();
+ void z180_device_op_64();
+ void z180_device_op_65();
+ void z180_device_op_66();
+ void z180_device_op_67();
+ void z180_device_op_68();
+ void z180_device_op_69();
+ void z180_device_op_6a();
+ void z180_device_op_6b();
+ void z180_device_op_6c();
+ void z180_device_op_6d();
+ void z180_device_op_6e();
+ void z180_device_op_6f();
+ void z180_device_op_70();
+ void z180_device_op_71();
+ void z180_device_op_72();
+ void z180_device_op_73();
+ void z180_device_op_74();
+ void z180_device_op_75();
+ void z180_device_op_76();
+ void z180_device_op_77();
+ void z180_device_op_78();
+ void z180_device_op_79();
+ void z180_device_op_7a();
+ void z180_device_op_7b();
+ void z180_device_op_7c();
+ void z180_device_op_7d();
+ void z180_device_op_7e();
+ void z180_device_op_7f();
+ void z180_device_op_80();
+ void z180_device_op_81();
+ void z180_device_op_82();
+ void z180_device_op_83();
+ void z180_device_op_84();
+ void z180_device_op_85();
+ void z180_device_op_86();
+ void z180_device_op_87();
+ void z180_device_op_88();
+ void z180_device_op_89();
+ void z180_device_op_8a();
+ void z180_device_op_8b();
+ void z180_device_op_8c();
+ void z180_device_op_8d();
+ void z180_device_op_8e();
+ void z180_device_op_8f();
+ void z180_device_op_90();
+ void z180_device_op_91();
+ void z180_device_op_92();
+ void z180_device_op_93();
+ void z180_device_op_94();
+ void z180_device_op_95();
+ void z180_device_op_96();
+ void z180_device_op_97();
+ void z180_device_op_98();
+ void z180_device_op_99();
+ void z180_device_op_9a();
+ void z180_device_op_9b();
+ void z180_device_op_9c();
+ void z180_device_op_9d();
+ void z180_device_op_9e();
+ void z180_device_op_9f();
+ void z180_device_op_a0();
+ void z180_device_op_a1();
+ void z180_device_op_a2();
+ void z180_device_op_a3();
+ void z180_device_op_a4();
+ void z180_device_op_a5();
+ void z180_device_op_a6();
+ void z180_device_op_a7();
+ void z180_device_op_a8();
+ void z180_device_op_a9();
+ void z180_device_op_aa();
+ void z180_device_op_ab();
+ void z180_device_op_ac();
+ void z180_device_op_ad();
+ void z180_device_op_ae();
+ void z180_device_op_af();
+ void z180_device_op_b0();
+ void z180_device_op_b1();
+ void z180_device_op_b2();
+ void z180_device_op_b3();
+ void z180_device_op_b4();
+ void z180_device_op_b5();
+ void z180_device_op_b6();
+ void z180_device_op_b7();
+ void z180_device_op_b8();
+ void z180_device_op_b9();
+ void z180_device_op_ba();
+ void z180_device_op_bb();
+ void z180_device_op_bc();
+ void z180_device_op_bd();
+ void z180_device_op_be();
+ void z180_device_op_bf();
+ void z180_device_op_c0();
+ void z180_device_op_c1();
+ void z180_device_op_c2();
+ void z180_device_op_c3();
+ void z180_device_op_c4();
+ void z180_device_op_c5();
+ void z180_device_op_c6();
+ void z180_device_op_c7();
+ void z180_device_op_c8();
+ void z180_device_op_c9();
+ void z180_device_op_ca();
+ void z180_device_op_cb();
+ void z180_device_op_cc();
+ void z180_device_op_cd();
+ void z180_device_op_ce();
+ void z180_device_op_cf();
+ void z180_device_op_d0();
+ void z180_device_op_d1();
+ void z180_device_op_d2();
+ void z180_device_op_d3();
+ void z180_device_op_d4();
+ void z180_device_op_d5();
+ void z180_device_op_d6();
+ void z180_device_op_d7();
+ void z180_device_op_d8();
+ void z180_device_op_d9();
+ void z180_device_op_da();
+ void z180_device_op_db();
+ void z180_device_op_dc();
+ void z180_device_op_dd();
+ void z180_device_op_de();
+ void z180_device_op_df();
+ void z180_device_op_e0();
+ void z180_device_op_e1();
+ void z180_device_op_e2();
+ void z180_device_op_e3();
+ void z180_device_op_e4();
+ void z180_device_op_e5();
+ void z180_device_op_e6();
+ void z180_device_op_e7();
+ void z180_device_op_e8();
+ void z180_device_op_e9();
+ void z180_device_op_ea();
+ void z180_device_op_eb();
+ void z180_device_op_ec();
+ void z180_device_op_ed();
+ void z180_device_op_ee();
+ void z180_device_op_ef();
+ void z180_device_op_f0();
+ void z180_device_op_f1();
+ void z180_device_op_f2();
+ void z180_device_op_f3();
+ void z180_device_op_f4();
+ void z180_device_op_f5();
+ void z180_device_op_f6();
+ void z180_device_op_f7();
+ void z180_device_op_f8();
+ void z180_device_op_f9();
+ void z180_device_op_fa();
+ void z180_device_op_fb();
+ void z180_device_op_fc();
+ void z180_device_op_fd();
+ void z180_device_op_fe();
+ void z180_device_op_ff();
+ void z180_device_cb_00();
+ void z180_device_cb_01();
+ void z180_device_cb_02();
+ void z180_device_cb_03();
+ void z180_device_cb_04();
+ void z180_device_cb_05();
+ void z180_device_cb_06();
+ void z180_device_cb_07();
+ void z180_device_cb_08();
+ void z180_device_cb_09();
+ void z180_device_cb_0a();
+ void z180_device_cb_0b();
+ void z180_device_cb_0c();
+ void z180_device_cb_0d();
+ void z180_device_cb_0e();
+ void z180_device_cb_0f();
+ void z180_device_cb_10();
+ void z180_device_cb_11();
+ void z180_device_cb_12();
+ void z180_device_cb_13();
+ void z180_device_cb_14();
+ void z180_device_cb_15();
+ void z180_device_cb_16();
+ void z180_device_cb_17();
+ void z180_device_cb_18();
+ void z180_device_cb_19();
+ void z180_device_cb_1a();
+ void z180_device_cb_1b();
+ void z180_device_cb_1c();
+ void z180_device_cb_1d();
+ void z180_device_cb_1e();
+ void z180_device_cb_1f();
+ void z180_device_cb_20();
+ void z180_device_cb_21();
+ void z180_device_cb_22();
+ void z180_device_cb_23();
+ void z180_device_cb_24();
+ void z180_device_cb_25();
+ void z180_device_cb_26();
+ void z180_device_cb_27();
+ void z180_device_cb_28();
+ void z180_device_cb_29();
+ void z180_device_cb_2a();
+ void z180_device_cb_2b();
+ void z180_device_cb_2c();
+ void z180_device_cb_2d();
+ void z180_device_cb_2e();
+ void z180_device_cb_2f();
+ void z180_device_cb_30();
+ void z180_device_cb_31();
+ void z180_device_cb_32();
+ void z180_device_cb_33();
+ void z180_device_cb_34();
+ void z180_device_cb_35();
+ void z180_device_cb_36();
+ void z180_device_cb_37();
+ void z180_device_cb_38();
+ void z180_device_cb_39();
+ void z180_device_cb_3a();
+ void z180_device_cb_3b();
+ void z180_device_cb_3c();
+ void z180_device_cb_3d();
+ void z180_device_cb_3e();
+ void z180_device_cb_3f();
+ void z180_device_cb_40();
+ void z180_device_cb_41();
+ void z180_device_cb_42();
+ void z180_device_cb_43();
+ void z180_device_cb_44();
+ void z180_device_cb_45();
+ void z180_device_cb_46();
+ void z180_device_cb_47();
+ void z180_device_cb_48();
+ void z180_device_cb_49();
+ void z180_device_cb_4a();
+ void z180_device_cb_4b();
+ void z180_device_cb_4c();
+ void z180_device_cb_4d();
+ void z180_device_cb_4e();
+ void z180_device_cb_4f();
+ void z180_device_cb_50();
+ void z180_device_cb_51();
+ void z180_device_cb_52();
+ void z180_device_cb_53();
+ void z180_device_cb_54();
+ void z180_device_cb_55();
+ void z180_device_cb_56();
+ void z180_device_cb_57();
+ void z180_device_cb_58();
+ void z180_device_cb_59();
+ void z180_device_cb_5a();
+ void z180_device_cb_5b();
+ void z180_device_cb_5c();
+ void z180_device_cb_5d();
+ void z180_device_cb_5e();
+ void z180_device_cb_5f();
+ void z180_device_cb_60();
+ void z180_device_cb_61();
+ void z180_device_cb_62();
+ void z180_device_cb_63();
+ void z180_device_cb_64();
+ void z180_device_cb_65();
+ void z180_device_cb_66();
+ void z180_device_cb_67();
+ void z180_device_cb_68();
+ void z180_device_cb_69();
+ void z180_device_cb_6a();
+ void z180_device_cb_6b();
+ void z180_device_cb_6c();
+ void z180_device_cb_6d();
+ void z180_device_cb_6e();
+ void z180_device_cb_6f();
+ void z180_device_cb_70();
+ void z180_device_cb_71();
+ void z180_device_cb_72();
+ void z180_device_cb_73();
+ void z180_device_cb_74();
+ void z180_device_cb_75();
+ void z180_device_cb_76();
+ void z180_device_cb_77();
+ void z180_device_cb_78();
+ void z180_device_cb_79();
+ void z180_device_cb_7a();
+ void z180_device_cb_7b();
+ void z180_device_cb_7c();
+ void z180_device_cb_7d();
+ void z180_device_cb_7e();
+ void z180_device_cb_7f();
+ void z180_device_cb_80();
+ void z180_device_cb_81();
+ void z180_device_cb_82();
+ void z180_device_cb_83();
+ void z180_device_cb_84();
+ void z180_device_cb_85();
+ void z180_device_cb_86();
+ void z180_device_cb_87();
+ void z180_device_cb_88();
+ void z180_device_cb_89();
+ void z180_device_cb_8a();
+ void z180_device_cb_8b();
+ void z180_device_cb_8c();
+ void z180_device_cb_8d();
+ void z180_device_cb_8e();
+ void z180_device_cb_8f();
+ void z180_device_cb_90();
+ void z180_device_cb_91();
+ void z180_device_cb_92();
+ void z180_device_cb_93();
+ void z180_device_cb_94();
+ void z180_device_cb_95();
+ void z180_device_cb_96();
+ void z180_device_cb_97();
+ void z180_device_cb_98();
+ void z180_device_cb_99();
+ void z180_device_cb_9a();
+ void z180_device_cb_9b();
+ void z180_device_cb_9c();
+ void z180_device_cb_9d();
+ void z180_device_cb_9e();
+ void z180_device_cb_9f();
+ void z180_device_cb_a0();
+ void z180_device_cb_a1();
+ void z180_device_cb_a2();
+ void z180_device_cb_a3();
+ void z180_device_cb_a4();
+ void z180_device_cb_a5();
+ void z180_device_cb_a6();
+ void z180_device_cb_a7();
+ void z180_device_cb_a8();
+ void z180_device_cb_a9();
+ void z180_device_cb_aa();
+ void z180_device_cb_ab();
+ void z180_device_cb_ac();
+ void z180_device_cb_ad();
+ void z180_device_cb_ae();
+ void z180_device_cb_af();
+ void z180_device_cb_b0();
+ void z180_device_cb_b1();
+ void z180_device_cb_b2();
+ void z180_device_cb_b3();
+ void z180_device_cb_b4();
+ void z180_device_cb_b5();
+ void z180_device_cb_b6();
+ void z180_device_cb_b7();
+ void z180_device_cb_b8();
+ void z180_device_cb_b9();
+ void z180_device_cb_ba();
+ void z180_device_cb_bb();
+ void z180_device_cb_bc();
+ void z180_device_cb_bd();
+ void z180_device_cb_be();
+ void z180_device_cb_bf();
+ void z180_device_cb_c0();
+ void z180_device_cb_c1();
+ void z180_device_cb_c2();
+ void z180_device_cb_c3();
+ void z180_device_cb_c4();
+ void z180_device_cb_c5();
+ void z180_device_cb_c6();
+ void z180_device_cb_c7();
+ void z180_device_cb_c8();
+ void z180_device_cb_c9();
+ void z180_device_cb_ca();
+ void z180_device_cb_cb();
+ void z180_device_cb_cc();
+ void z180_device_cb_cd();
+ void z180_device_cb_ce();
+ void z180_device_cb_cf();
+ void z180_device_cb_d0();
+ void z180_device_cb_d1();
+ void z180_device_cb_d2();
+ void z180_device_cb_d3();
+ void z180_device_cb_d4();
+ void z180_device_cb_d5();
+ void z180_device_cb_d6();
+ void z180_device_cb_d7();
+ void z180_device_cb_d8();
+ void z180_device_cb_d9();
+ void z180_device_cb_da();
+ void z180_device_cb_db();
+ void z180_device_cb_dc();
+ void z180_device_cb_dd();
+ void z180_device_cb_de();
+ void z180_device_cb_df();
+ void z180_device_cb_e0();
+ void z180_device_cb_e1();
+ void z180_device_cb_e2();
+ void z180_device_cb_e3();
+ void z180_device_cb_e4();
+ void z180_device_cb_e5();
+ void z180_device_cb_e6();
+ void z180_device_cb_e7();
+ void z180_device_cb_e8();
+ void z180_device_cb_e9();
+ void z180_device_cb_ea();
+ void z180_device_cb_eb();
+ void z180_device_cb_ec();
+ void z180_device_cb_ed();
+ void z180_device_cb_ee();
+ void z180_device_cb_ef();
+ void z180_device_cb_f0();
+ void z180_device_cb_f1();
+ void z180_device_cb_f2();
+ void z180_device_cb_f3();
+ void z180_device_cb_f4();
+ void z180_device_cb_f5();
+ void z180_device_cb_f6();
+ void z180_device_cb_f7();
+ void z180_device_cb_f8();
+ void z180_device_cb_f9();
+ void z180_device_cb_fa();
+ void z180_device_cb_fb();
+ void z180_device_cb_fc();
+ void z180_device_cb_fd();
+ void z180_device_cb_fe();
+ void z180_device_cb_ff();
+ void z180_device_illegal_1();
+ void z180_device_dd_00();
+ void z180_device_dd_01();
+ void z180_device_dd_02();
+ void z180_device_dd_03();
+ void z180_device_dd_04();
+ void z180_device_dd_05();
+ void z180_device_dd_06();
+ void z180_device_dd_07();
+ void z180_device_dd_08();
+ void z180_device_dd_09();
+ void z180_device_dd_0a();
+ void z180_device_dd_0b();
+ void z180_device_dd_0c();
+ void z180_device_dd_0d();
+ void z180_device_dd_0e();
+ void z180_device_dd_0f();
+ void z180_device_dd_10();
+ void z180_device_dd_11();
+ void z180_device_dd_12();
+ void z180_device_dd_13();
+ void z180_device_dd_14();
+ void z180_device_dd_15();
+ void z180_device_dd_16();
+ void z180_device_dd_17();
+ void z180_device_dd_18();
+ void z180_device_dd_19();
+ void z180_device_dd_1a();
+ void z180_device_dd_1b();
+ void z180_device_dd_1c();
+ void z180_device_dd_1d();
+ void z180_device_dd_1e();
+ void z180_device_dd_1f();
+ void z180_device_dd_20();
+ void z180_device_dd_21();
+ void z180_device_dd_22();
+ void z180_device_dd_23();
+ void z180_device_dd_24();
+ void z180_device_dd_25();
+ void z180_device_dd_26();
+ void z180_device_dd_27();
+ void z180_device_dd_28();
+ void z180_device_dd_29();
+ void z180_device_dd_2a();
+ void z180_device_dd_2b();
+ void z180_device_dd_2c();
+ void z180_device_dd_2d();
+ void z180_device_dd_2e();
+ void z180_device_dd_2f();
+ void z180_device_dd_30();
+ void z180_device_dd_31();
+ void z180_device_dd_32();
+ void z180_device_dd_33();
+ void z180_device_dd_34();
+ void z180_device_dd_35();
+ void z180_device_dd_36();
+ void z180_device_dd_37();
+ void z180_device_dd_38();
+ void z180_device_dd_39();
+ void z180_device_dd_3a();
+ void z180_device_dd_3b();
+ void z180_device_dd_3c();
+ void z180_device_dd_3d();
+ void z180_device_dd_3e();
+ void z180_device_dd_3f();
+ void z180_device_dd_40();
+ void z180_device_dd_41();
+ void z180_device_dd_42();
+ void z180_device_dd_43();
+ void z180_device_dd_44();
+ void z180_device_dd_45();
+ void z180_device_dd_46();
+ void z180_device_dd_47();
+ void z180_device_dd_48();
+ void z180_device_dd_49();
+ void z180_device_dd_4a();
+ void z180_device_dd_4b();
+ void z180_device_dd_4c();
+ void z180_device_dd_4d();
+ void z180_device_dd_4e();
+ void z180_device_dd_4f();
+ void z180_device_dd_50();
+ void z180_device_dd_51();
+ void z180_device_dd_52();
+ void z180_device_dd_53();
+ void z180_device_dd_54();
+ void z180_device_dd_55();
+ void z180_device_dd_56();
+ void z180_device_dd_57();
+ void z180_device_dd_58();
+ void z180_device_dd_59();
+ void z180_device_dd_5a();
+ void z180_device_dd_5b();
+ void z180_device_dd_5c();
+ void z180_device_dd_5d();
+ void z180_device_dd_5e();
+ void z180_device_dd_5f();
+ void z180_device_dd_60();
+ void z180_device_dd_61();
+ void z180_device_dd_62();
+ void z180_device_dd_63();
+ void z180_device_dd_64();
+ void z180_device_dd_65();
+ void z180_device_dd_66();
+ void z180_device_dd_67();
+ void z180_device_dd_68();
+ void z180_device_dd_69();
+ void z180_device_dd_6a();
+ void z180_device_dd_6b();
+ void z180_device_dd_6c();
+ void z180_device_dd_6d();
+ void z180_device_dd_6e();
+ void z180_device_dd_6f();
+ void z180_device_dd_70();
+ void z180_device_dd_71();
+ void z180_device_dd_72();
+ void z180_device_dd_73();
+ void z180_device_dd_74();
+ void z180_device_dd_75();
+ void z180_device_dd_76();
+ void z180_device_dd_77();
+ void z180_device_dd_78();
+ void z180_device_dd_79();
+ void z180_device_dd_7a();
+ void z180_device_dd_7b();
+ void z180_device_dd_7c();
+ void z180_device_dd_7d();
+ void z180_device_dd_7e();
+ void z180_device_dd_7f();
+ void z180_device_dd_80();
+ void z180_device_dd_81();
+ void z180_device_dd_82();
+ void z180_device_dd_83();
+ void z180_device_dd_84();
+ void z180_device_dd_85();
+ void z180_device_dd_86();
+ void z180_device_dd_87();
+ void z180_device_dd_88();
+ void z180_device_dd_89();
+ void z180_device_dd_8a();
+ void z180_device_dd_8b();
+ void z180_device_dd_8c();
+ void z180_device_dd_8d();
+ void z180_device_dd_8e();
+ void z180_device_dd_8f();
+ void z180_device_dd_90();
+ void z180_device_dd_91();
+ void z180_device_dd_92();
+ void z180_device_dd_93();
+ void z180_device_dd_94();
+ void z180_device_dd_95();
+ void z180_device_dd_96();
+ void z180_device_dd_97();
+ void z180_device_dd_98();
+ void z180_device_dd_99();
+ void z180_device_dd_9a();
+ void z180_device_dd_9b();
+ void z180_device_dd_9c();
+ void z180_device_dd_9d();
+ void z180_device_dd_9e();
+ void z180_device_dd_9f();
+ void z180_device_dd_a0();
+ void z180_device_dd_a1();
+ void z180_device_dd_a2();
+ void z180_device_dd_a3();
+ void z180_device_dd_a4();
+ void z180_device_dd_a5();
+ void z180_device_dd_a6();
+ void z180_device_dd_a7();
+ void z180_device_dd_a8();
+ void z180_device_dd_a9();
+ void z180_device_dd_aa();
+ void z180_device_dd_ab();
+ void z180_device_dd_ac();
+ void z180_device_dd_ad();
+ void z180_device_dd_ae();
+ void z180_device_dd_af();
+ void z180_device_dd_b0();
+ void z180_device_dd_b1();
+ void z180_device_dd_b2();
+ void z180_device_dd_b3();
+ void z180_device_dd_b4();
+ void z180_device_dd_b5();
+ void z180_device_dd_b6();
+ void z180_device_dd_b7();
+ void z180_device_dd_b8();
+ void z180_device_dd_b9();
+ void z180_device_dd_ba();
+ void z180_device_dd_bb();
+ void z180_device_dd_bc();
+ void z180_device_dd_bd();
+ void z180_device_dd_be();
+ void z180_device_dd_bf();
+ void z180_device_dd_c0();
+ void z180_device_dd_c1();
+ void z180_device_dd_c2();
+ void z180_device_dd_c3();
+ void z180_device_dd_c4();
+ void z180_device_dd_c5();
+ void z180_device_dd_c6();
+ void z180_device_dd_c7();
+ void z180_device_dd_c8();
+ void z180_device_dd_c9();
+ void z180_device_dd_ca();
+ void z180_device_dd_cb();
+ void z180_device_dd_cc();
+ void z180_device_dd_cd();
+ void z180_device_dd_ce();
+ void z180_device_dd_cf();
+ void z180_device_dd_d0();
+ void z180_device_dd_d1();
+ void z180_device_dd_d2();
+ void z180_device_dd_d3();
+ void z180_device_dd_d4();
+ void z180_device_dd_d5();
+ void z180_device_dd_d6();
+ void z180_device_dd_d7();
+ void z180_device_dd_d8();
+ void z180_device_dd_d9();
+ void z180_device_dd_da();
+ void z180_device_dd_db();
+ void z180_device_dd_dc();
+ void z180_device_dd_dd();
+ void z180_device_dd_de();
+ void z180_device_dd_df();
+ void z180_device_dd_e0();
+ void z180_device_dd_e1();
+ void z180_device_dd_e2();
+ void z180_device_dd_e3();
+ void z180_device_dd_e4();
+ void z180_device_dd_e5();
+ void z180_device_dd_e6();
+ void z180_device_dd_e7();
+ void z180_device_dd_e8();
+ void z180_device_dd_e9();
+ void z180_device_dd_ea();
+ void z180_device_dd_eb();
+ void z180_device_dd_ec();
+ void z180_device_dd_ed();
+ void z180_device_dd_ee();
+ void z180_device_dd_ef();
+ void z180_device_dd_f0();
+ void z180_device_dd_f1();
+ void z180_device_dd_f2();
+ void z180_device_dd_f3();
+ void z180_device_dd_f4();
+ void z180_device_dd_f5();
+ void z180_device_dd_f6();
+ void z180_device_dd_f7();
+ void z180_device_dd_f8();
+ void z180_device_dd_f9();
+ void z180_device_dd_fa();
+ void z180_device_dd_fb();
+ void z180_device_dd_fc();
+ void z180_device_dd_fd();
+ void z180_device_dd_fe();
+ void z180_device_dd_ff();
+ void z180_device_illegal_2();
+ void z180_device_ed_00();
+ void z180_device_ed_01();
+ void z180_device_ed_02();
+ void z180_device_ed_03();
+ void z180_device_ed_04();
+ void z180_device_ed_05();
+ void z180_device_ed_06();
+ void z180_device_ed_07();
+ void z180_device_ed_08();
+ void z180_device_ed_09();
+ void z180_device_ed_0a();
+ void z180_device_ed_0b();
+ void z180_device_ed_0c();
+ void z180_device_ed_0d();
+ void z180_device_ed_0e();
+ void z180_device_ed_0f();
+ void z180_device_ed_10();
+ void z180_device_ed_11();
+ void z180_device_ed_12();
+ void z180_device_ed_13();
+ void z180_device_ed_14();
+ void z180_device_ed_15();
+ void z180_device_ed_16();
+ void z180_device_ed_17();
+ void z180_device_ed_18();
+ void z180_device_ed_19();
+ void z180_device_ed_1a();
+ void z180_device_ed_1b();
+ void z180_device_ed_1c();
+ void z180_device_ed_1d();
+ void z180_device_ed_1e();
+ void z180_device_ed_1f();
+ void z180_device_ed_20();
+ void z180_device_ed_21();
+ void z180_device_ed_22();
+ void z180_device_ed_23();
+ void z180_device_ed_24();
+ void z180_device_ed_25();
+ void z180_device_ed_26();
+ void z180_device_ed_27();
+ void z180_device_ed_28();
+ void z180_device_ed_29();
+ void z180_device_ed_2a();
+ void z180_device_ed_2b();
+ void z180_device_ed_2c();
+ void z180_device_ed_2d();
+ void z180_device_ed_2e();
+ void z180_device_ed_2f();
+ void z180_device_ed_30();
+ void z180_device_ed_31();
+ void z180_device_ed_32();
+ void z180_device_ed_33();
+ void z180_device_ed_34();
+ void z180_device_ed_35();
+ void z180_device_ed_36();
+ void z180_device_ed_37();
+ void z180_device_ed_38();
+ void z180_device_ed_39();
+ void z180_device_ed_3a();
+ void z180_device_ed_3b();
+ void z180_device_ed_3c();
+ void z180_device_ed_3d();
+ void z180_device_ed_3e();
+ void z180_device_ed_3f();
+ void z180_device_ed_40();
+ void z180_device_ed_41();
+ void z180_device_ed_42();
+ void z180_device_ed_43();
+ void z180_device_ed_44();
+ void z180_device_ed_45();
+ void z180_device_ed_46();
+ void z180_device_ed_47();
+ void z180_device_ed_48();
+ void z180_device_ed_49();
+ void z180_device_ed_4a();
+ void z180_device_ed_4b();
+ void z180_device_ed_4c();
+ void z180_device_ed_4d();
+ void z180_device_ed_4e();
+ void z180_device_ed_4f();
+ void z180_device_ed_50();
+ void z180_device_ed_51();
+ void z180_device_ed_52();
+ void z180_device_ed_53();
+ void z180_device_ed_54();
+ void z180_device_ed_55();
+ void z180_device_ed_56();
+ void z180_device_ed_57();
+ void z180_device_ed_58();
+ void z180_device_ed_59();
+ void z180_device_ed_5a();
+ void z180_device_ed_5b();
+ void z180_device_ed_5c();
+ void z180_device_ed_5d();
+ void z180_device_ed_5e();
+ void z180_device_ed_5f();
+ void z180_device_ed_60();
+ void z180_device_ed_61();
+ void z180_device_ed_62();
+ void z180_device_ed_63();
+ void z180_device_ed_64();
+ void z180_device_ed_65();
+ void z180_device_ed_66();
+ void z180_device_ed_67();
+ void z180_device_ed_68();
+ void z180_device_ed_69();
+ void z180_device_ed_6a();
+ void z180_device_ed_6b();
+ void z180_device_ed_6c();
+ void z180_device_ed_6d();
+ void z180_device_ed_6e();
+ void z180_device_ed_6f();
+ void z180_device_ed_70();
+ void z180_device_ed_71();
+ void z180_device_ed_72();
+ void z180_device_ed_73();
+ void z180_device_ed_74();
+ void z180_device_ed_75();
+ void z180_device_ed_76();
+ void z180_device_ed_77();
+ void z180_device_ed_78();
+ void z180_device_ed_79();
+ void z180_device_ed_7a();
+ void z180_device_ed_7b();
+ void z180_device_ed_7c();
+ void z180_device_ed_7d();
+ void z180_device_ed_7e();
+ void z180_device_ed_7f();
+ void z180_device_ed_80();
+ void z180_device_ed_81();
+ void z180_device_ed_82();
+ void z180_device_ed_83();
+ void z180_device_ed_84();
+ void z180_device_ed_85();
+ void z180_device_ed_86();
+ void z180_device_ed_87();
+ void z180_device_ed_88();
+ void z180_device_ed_89();
+ void z180_device_ed_8a();
+ void z180_device_ed_8b();
+ void z180_device_ed_8c();
+ void z180_device_ed_8d();
+ void z180_device_ed_8e();
+ void z180_device_ed_8f();
+ void z180_device_ed_90();
+ void z180_device_ed_91();
+ void z180_device_ed_92();
+ void z180_device_ed_93();
+ void z180_device_ed_94();
+ void z180_device_ed_95();
+ void z180_device_ed_96();
+ void z180_device_ed_97();
+ void z180_device_ed_98();
+ void z180_device_ed_99();
+ void z180_device_ed_9a();
+ void z180_device_ed_9b();
+ void z180_device_ed_9c();
+ void z180_device_ed_9d();
+ void z180_device_ed_9e();
+ void z180_device_ed_9f();
+ void z180_device_ed_a0();
+ void z180_device_ed_a1();
+ void z180_device_ed_a2();
+ void z180_device_ed_a3();
+ void z180_device_ed_a4();
+ void z180_device_ed_a5();
+ void z180_device_ed_a6();
+ void z180_device_ed_a7();
+ void z180_device_ed_a8();
+ void z180_device_ed_a9();
+ void z180_device_ed_aa();
+ void z180_device_ed_ab();
+ void z180_device_ed_ac();
+ void z180_device_ed_ad();
+ void z180_device_ed_ae();
+ void z180_device_ed_af();
+ void z180_device_ed_b0();
+ void z180_device_ed_b1();
+ void z180_device_ed_b2();
+ void z180_device_ed_b3();
+ void z180_device_ed_b4();
+ void z180_device_ed_b5();
+ void z180_device_ed_b6();
+ void z180_device_ed_b7();
+ void z180_device_ed_b8();
+ void z180_device_ed_b9();
+ void z180_device_ed_ba();
+ void z180_device_ed_bb();
+ void z180_device_ed_bc();
+ void z180_device_ed_bd();
+ void z180_device_ed_be();
+ void z180_device_ed_bf();
+ void z180_device_ed_c0();
+ void z180_device_ed_c1();
+ void z180_device_ed_c2();
+ void z180_device_ed_c3();
+ void z180_device_ed_c4();
+ void z180_device_ed_c5();
+ void z180_device_ed_c6();
+ void z180_device_ed_c7();
+ void z180_device_ed_c8();
+ void z180_device_ed_c9();
+ void z180_device_ed_ca();
+ void z180_device_ed_cb();
+ void z180_device_ed_cc();
+ void z180_device_ed_cd();
+ void z180_device_ed_ce();
+ void z180_device_ed_cf();
+ void z180_device_ed_d0();
+ void z180_device_ed_d1();
+ void z180_device_ed_d2();
+ void z180_device_ed_d3();
+ void z180_device_ed_d4();
+ void z180_device_ed_d5();
+ void z180_device_ed_d6();
+ void z180_device_ed_d7();
+ void z180_device_ed_d8();
+ void z180_device_ed_d9();
+ void z180_device_ed_da();
+ void z180_device_ed_db();
+ void z180_device_ed_dc();
+ void z180_device_ed_dd();
+ void z180_device_ed_de();
+ void z180_device_ed_df();
+ void z180_device_ed_e0();
+ void z180_device_ed_e1();
+ void z180_device_ed_e2();
+ void z180_device_ed_e3();
+ void z180_device_ed_e4();
+ void z180_device_ed_e5();
+ void z180_device_ed_e6();
+ void z180_device_ed_e7();
+ void z180_device_ed_e8();
+ void z180_device_ed_e9();
+ void z180_device_ed_ea();
+ void z180_device_ed_eb();
+ void z180_device_ed_ec();
+ void z180_device_ed_ed();
+ void z180_device_ed_ee();
+ void z180_device_ed_ef();
+ void z180_device_ed_f0();
+ void z180_device_ed_f1();
+ void z180_device_ed_f2();
+ void z180_device_ed_f3();
+ void z180_device_ed_f4();
+ void z180_device_ed_f5();
+ void z180_device_ed_f6();
+ void z180_device_ed_f7();
+ void z180_device_ed_f8();
+ void z180_device_ed_f9();
+ void z180_device_ed_fa();
+ void z180_device_ed_fb();
+ void z180_device_ed_fc();
+ void z180_device_ed_fd();
+ void z180_device_ed_fe();
+ void z180_device_ed_ff();
+ void z180_device_fd_00();
+ void z180_device_fd_01();
+ void z180_device_fd_02();
+ void z180_device_fd_03();
+ void z180_device_fd_04();
+ void z180_device_fd_05();
+ void z180_device_fd_06();
+ void z180_device_fd_07();
+ void z180_device_fd_08();
+ void z180_device_fd_09();
+ void z180_device_fd_0a();
+ void z180_device_fd_0b();
+ void z180_device_fd_0c();
+ void z180_device_fd_0d();
+ void z180_device_fd_0e();
+ void z180_device_fd_0f();
+ void z180_device_fd_10();
+ void z180_device_fd_11();
+ void z180_device_fd_12();
+ void z180_device_fd_13();
+ void z180_device_fd_14();
+ void z180_device_fd_15();
+ void z180_device_fd_16();
+ void z180_device_fd_17();
+ void z180_device_fd_18();
+ void z180_device_fd_19();
+ void z180_device_fd_1a();
+ void z180_device_fd_1b();
+ void z180_device_fd_1c();
+ void z180_device_fd_1d();
+ void z180_device_fd_1e();
+ void z180_device_fd_1f();
+ void z180_device_fd_20();
+ void z180_device_fd_21();
+ void z180_device_fd_22();
+ void z180_device_fd_23();
+ void z180_device_fd_24();
+ void z180_device_fd_25();
+ void z180_device_fd_26();
+ void z180_device_fd_27();
+ void z180_device_fd_28();
+ void z180_device_fd_29();
+ void z180_device_fd_2a();
+ void z180_device_fd_2b();
+ void z180_device_fd_2c();
+ void z180_device_fd_2d();
+ void z180_device_fd_2e();
+ void z180_device_fd_2f();
+ void z180_device_fd_30();
+ void z180_device_fd_31();
+ void z180_device_fd_32();
+ void z180_device_fd_33();
+ void z180_device_fd_34();
+ void z180_device_fd_35();
+ void z180_device_fd_36();
+ void z180_device_fd_37();
+ void z180_device_fd_38();
+ void z180_device_fd_39();
+ void z180_device_fd_3a();
+ void z180_device_fd_3b();
+ void z180_device_fd_3c();
+ void z180_device_fd_3d();
+ void z180_device_fd_3e();
+ void z180_device_fd_3f();
+ void z180_device_fd_40();
+ void z180_device_fd_41();
+ void z180_device_fd_42();
+ void z180_device_fd_43();
+ void z180_device_fd_44();
+ void z180_device_fd_45();
+ void z180_device_fd_46();
+ void z180_device_fd_47();
+ void z180_device_fd_48();
+ void z180_device_fd_49();
+ void z180_device_fd_4a();
+ void z180_device_fd_4b();
+ void z180_device_fd_4c();
+ void z180_device_fd_4d();
+ void z180_device_fd_4e();
+ void z180_device_fd_4f();
+ void z180_device_fd_50();
+ void z180_device_fd_51();
+ void z180_device_fd_52();
+ void z180_device_fd_53();
+ void z180_device_fd_54();
+ void z180_device_fd_55();
+ void z180_device_fd_56();
+ void z180_device_fd_57();
+ void z180_device_fd_58();
+ void z180_device_fd_59();
+ void z180_device_fd_5a();
+ void z180_device_fd_5b();
+ void z180_device_fd_5c();
+ void z180_device_fd_5d();
+ void z180_device_fd_5e();
+ void z180_device_fd_5f();
+ void z180_device_fd_60();
+ void z180_device_fd_61();
+ void z180_device_fd_62();
+ void z180_device_fd_63();
+ void z180_device_fd_64();
+ void z180_device_fd_65();
+ void z180_device_fd_66();
+ void z180_device_fd_67();
+ void z180_device_fd_68();
+ void z180_device_fd_69();
+ void z180_device_fd_6a();
+ void z180_device_fd_6b();
+ void z180_device_fd_6c();
+ void z180_device_fd_6d();
+ void z180_device_fd_6e();
+ void z180_device_fd_6f();
+ void z180_device_fd_70();
+ void z180_device_fd_71();
+ void z180_device_fd_72();
+ void z180_device_fd_73();
+ void z180_device_fd_74();
+ void z180_device_fd_75();
+ void z180_device_fd_76();
+ void z180_device_fd_77();
+ void z180_device_fd_78();
+ void z180_device_fd_79();
+ void z180_device_fd_7a();
+ void z180_device_fd_7b();
+ void z180_device_fd_7c();
+ void z180_device_fd_7d();
+ void z180_device_fd_7e();
+ void z180_device_fd_7f();
+ void z180_device_fd_80();
+ void z180_device_fd_81();
+ void z180_device_fd_82();
+ void z180_device_fd_83();
+ void z180_device_fd_84();
+ void z180_device_fd_85();
+ void z180_device_fd_86();
+ void z180_device_fd_87();
+ void z180_device_fd_88();
+ void z180_device_fd_89();
+ void z180_device_fd_8a();
+ void z180_device_fd_8b();
+ void z180_device_fd_8c();
+ void z180_device_fd_8d();
+ void z180_device_fd_8e();
+ void z180_device_fd_8f();
+ void z180_device_fd_90();
+ void z180_device_fd_91();
+ void z180_device_fd_92();
+ void z180_device_fd_93();
+ void z180_device_fd_94();
+ void z180_device_fd_95();
+ void z180_device_fd_96();
+ void z180_device_fd_97();
+ void z180_device_fd_98();
+ void z180_device_fd_99();
+ void z180_device_fd_9a();
+ void z180_device_fd_9b();
+ void z180_device_fd_9c();
+ void z180_device_fd_9d();
+ void z180_device_fd_9e();
+ void z180_device_fd_9f();
+ void z180_device_fd_a0();
+ void z180_device_fd_a1();
+ void z180_device_fd_a2();
+ void z180_device_fd_a3();
+ void z180_device_fd_a4();
+ void z180_device_fd_a5();
+ void z180_device_fd_a6();
+ void z180_device_fd_a7();
+ void z180_device_fd_a8();
+ void z180_device_fd_a9();
+ void z180_device_fd_aa();
+ void z180_device_fd_ab();
+ void z180_device_fd_ac();
+ void z180_device_fd_ad();
+ void z180_device_fd_ae();
+ void z180_device_fd_af();
+ void z180_device_fd_b0();
+ void z180_device_fd_b1();
+ void z180_device_fd_b2();
+ void z180_device_fd_b3();
+ void z180_device_fd_b4();
+ void z180_device_fd_b5();
+ void z180_device_fd_b6();
+ void z180_device_fd_b7();
+ void z180_device_fd_b8();
+ void z180_device_fd_b9();
+ void z180_device_fd_ba();
+ void z180_device_fd_bb();
+ void z180_device_fd_bc();
+ void z180_device_fd_bd();
+ void z180_device_fd_be();
+ void z180_device_fd_bf();
+ void z180_device_fd_c0();
+ void z180_device_fd_c1();
+ void z180_device_fd_c2();
+ void z180_device_fd_c3();
+ void z180_device_fd_c4();
+ void z180_device_fd_c5();
+ void z180_device_fd_c6();
+ void z180_device_fd_c7();
+ void z180_device_fd_c8();
+ void z180_device_fd_c9();
+ void z180_device_fd_ca();
+ void z180_device_fd_cb();
+ void z180_device_fd_cc();
+ void z180_device_fd_cd();
+ void z180_device_fd_ce();
+ void z180_device_fd_cf();
+ void z180_device_fd_d0();
+ void z180_device_fd_d1();
+ void z180_device_fd_d2();
+ void z180_device_fd_d3();
+ void z180_device_fd_d4();
+ void z180_device_fd_d5();
+ void z180_device_fd_d6();
+ void z180_device_fd_d7();
+ void z180_device_fd_d8();
+ void z180_device_fd_d9();
+ void z180_device_fd_da();
+ void z180_device_fd_db();
+ void z180_device_fd_dc();
+ void z180_device_fd_dd();
+ void z180_device_fd_de();
+ void z180_device_fd_df();
+ void z180_device_fd_e0();
+ void z180_device_fd_e1();
+ void z180_device_fd_e2();
+ void z180_device_fd_e3();
+ void z180_device_fd_e4();
+ void z180_device_fd_e5();
+ void z180_device_fd_e6();
+ void z180_device_fd_e7();
+ void z180_device_fd_e8();
+ void z180_device_fd_e9();
+ void z180_device_fd_ea();
+ void z180_device_fd_eb();
+ void z180_device_fd_ec();
+ void z180_device_fd_ed();
+ void z180_device_fd_ee();
+ void z180_device_fd_ef();
+ void z180_device_fd_f0();
+ void z180_device_fd_f1();
+ void z180_device_fd_f2();
+ void z180_device_fd_f3();
+ void z180_device_fd_f4();
+ void z180_device_fd_f5();
+ void z180_device_fd_f6();
+ void z180_device_fd_f7();
+ void z180_device_fd_f8();
+ void z180_device_fd_f9();
+ void z180_device_fd_fa();
+ void z180_device_fd_fb();
+ void z180_device_fd_fc();
+ void z180_device_fd_fd();
+ void z180_device_fd_fe();
+ void z180_device_fd_ff();
+ void z180_device_xycb_00();
+ void z180_device_xycb_01();
+ void z180_device_xycb_02();
+ void z180_device_xycb_03();
+ void z180_device_xycb_04();
+ void z180_device_xycb_05();
+ void z180_device_xycb_06();
+ void z180_device_xycb_07();
+ void z180_device_xycb_08();
+ void z180_device_xycb_09();
+ void z180_device_xycb_0a();
+ void z180_device_xycb_0b();
+ void z180_device_xycb_0c();
+ void z180_device_xycb_0d();
+ void z180_device_xycb_0e();
+ void z180_device_xycb_0f();
+ void z180_device_xycb_10();
+ void z180_device_xycb_11();
+ void z180_device_xycb_12();
+ void z180_device_xycb_13();
+ void z180_device_xycb_14();
+ void z180_device_xycb_15();
+ void z180_device_xycb_16();
+ void z180_device_xycb_17();
+ void z180_device_xycb_18();
+ void z180_device_xycb_19();
+ void z180_device_xycb_1a();
+ void z180_device_xycb_1b();
+ void z180_device_xycb_1c();
+ void z180_device_xycb_1d();
+ void z180_device_xycb_1e();
+ void z180_device_xycb_1f();
+ void z180_device_xycb_20();
+ void z180_device_xycb_21();
+ void z180_device_xycb_22();
+ void z180_device_xycb_23();
+ void z180_device_xycb_24();
+ void z180_device_xycb_25();
+ void z180_device_xycb_26();
+ void z180_device_xycb_27();
+ void z180_device_xycb_28();
+ void z180_device_xycb_29();
+ void z180_device_xycb_2a();
+ void z180_device_xycb_2b();
+ void z180_device_xycb_2c();
+ void z180_device_xycb_2d();
+ void z180_device_xycb_2e();
+ void z180_device_xycb_2f();
+ void z180_device_xycb_30();
+ void z180_device_xycb_31();
+ void z180_device_xycb_32();
+ void z180_device_xycb_33();
+ void z180_device_xycb_34();
+ void z180_device_xycb_35();
+ void z180_device_xycb_36();
+ void z180_device_xycb_37();
+ void z180_device_xycb_38();
+ void z180_device_xycb_39();
+ void z180_device_xycb_3a();
+ void z180_device_xycb_3b();
+ void z180_device_xycb_3c();
+ void z180_device_xycb_3d();
+ void z180_device_xycb_3e();
+ void z180_device_xycb_3f();
+ void z180_device_xycb_40();
+ void z180_device_xycb_41();
+ void z180_device_xycb_42();
+ void z180_device_xycb_43();
+ void z180_device_xycb_44();
+ void z180_device_xycb_45();
+ void z180_device_xycb_46();
+ void z180_device_xycb_47();
+ void z180_device_xycb_48();
+ void z180_device_xycb_49();
+ void z180_device_xycb_4a();
+ void z180_device_xycb_4b();
+ void z180_device_xycb_4c();
+ void z180_device_xycb_4d();
+ void z180_device_xycb_4e();
+ void z180_device_xycb_4f();
+ void z180_device_xycb_50();
+ void z180_device_xycb_51();
+ void z180_device_xycb_52();
+ void z180_device_xycb_53();
+ void z180_device_xycb_54();
+ void z180_device_xycb_55();
+ void z180_device_xycb_56();
+ void z180_device_xycb_57();
+ void z180_device_xycb_58();
+ void z180_device_xycb_59();
+ void z180_device_xycb_5a();
+ void z180_device_xycb_5b();
+ void z180_device_xycb_5c();
+ void z180_device_xycb_5d();
+ void z180_device_xycb_5e();
+ void z180_device_xycb_5f();
+ void z180_device_xycb_60();
+ void z180_device_xycb_61();
+ void z180_device_xycb_62();
+ void z180_device_xycb_63();
+ void z180_device_xycb_64();
+ void z180_device_xycb_65();
+ void z180_device_xycb_66();
+ void z180_device_xycb_67();
+ void z180_device_xycb_68();
+ void z180_device_xycb_69();
+ void z180_device_xycb_6a();
+ void z180_device_xycb_6b();
+ void z180_device_xycb_6c();
+ void z180_device_xycb_6d();
+ void z180_device_xycb_6e();
+ void z180_device_xycb_6f();
+ void z180_device_xycb_70();
+ void z180_device_xycb_71();
+ void z180_device_xycb_72();
+ void z180_device_xycb_73();
+ void z180_device_xycb_74();
+ void z180_device_xycb_75();
+ void z180_device_xycb_76();
+ void z180_device_xycb_77();
+ void z180_device_xycb_78();
+ void z180_device_xycb_79();
+ void z180_device_xycb_7a();
+ void z180_device_xycb_7b();
+ void z180_device_xycb_7c();
+ void z180_device_xycb_7d();
+ void z180_device_xycb_7e();
+ void z180_device_xycb_7f();
+ void z180_device_xycb_80();
+ void z180_device_xycb_81();
+ void z180_device_xycb_82();
+ void z180_device_xycb_83();
+ void z180_device_xycb_84();
+ void z180_device_xycb_85();
+ void z180_device_xycb_86();
+ void z180_device_xycb_87();
+ void z180_device_xycb_88();
+ void z180_device_xycb_89();
+ void z180_device_xycb_8a();
+ void z180_device_xycb_8b();
+ void z180_device_xycb_8c();
+ void z180_device_xycb_8d();
+ void z180_device_xycb_8e();
+ void z180_device_xycb_8f();
+ void z180_device_xycb_90();
+ void z180_device_xycb_91();
+ void z180_device_xycb_92();
+ void z180_device_xycb_93();
+ void z180_device_xycb_94();
+ void z180_device_xycb_95();
+ void z180_device_xycb_96();
+ void z180_device_xycb_97();
+ void z180_device_xycb_98();
+ void z180_device_xycb_99();
+ void z180_device_xycb_9a();
+ void z180_device_xycb_9b();
+ void z180_device_xycb_9c();
+ void z180_device_xycb_9d();
+ void z180_device_xycb_9e();
+ void z180_device_xycb_9f();
+ void z180_device_xycb_a0();
+ void z180_device_xycb_a1();
+ void z180_device_xycb_a2();
+ void z180_device_xycb_a3();
+ void z180_device_xycb_a4();
+ void z180_device_xycb_a5();
+ void z180_device_xycb_a6();
+ void z180_device_xycb_a7();
+ void z180_device_xycb_a8();
+ void z180_device_xycb_a9();
+ void z180_device_xycb_aa();
+ void z180_device_xycb_ab();
+ void z180_device_xycb_ac();
+ void z180_device_xycb_ad();
+ void z180_device_xycb_ae();
+ void z180_device_xycb_af();
+ void z180_device_xycb_b0();
+ void z180_device_xycb_b1();
+ void z180_device_xycb_b2();
+ void z180_device_xycb_b3();
+ void z180_device_xycb_b4();
+ void z180_device_xycb_b5();
+ void z180_device_xycb_b6();
+ void z180_device_xycb_b7();
+ void z180_device_xycb_b8();
+ void z180_device_xycb_b9();
+ void z180_device_xycb_ba();
+ void z180_device_xycb_bb();
+ void z180_device_xycb_bc();
+ void z180_device_xycb_bd();
+ void z180_device_xycb_be();
+ void z180_device_xycb_bf();
+ void z180_device_xycb_c0();
+ void z180_device_xycb_c1();
+ void z180_device_xycb_c2();
+ void z180_device_xycb_c3();
+ void z180_device_xycb_c4();
+ void z180_device_xycb_c5();
+ void z180_device_xycb_c6();
+ void z180_device_xycb_c7();
+ void z180_device_xycb_c8();
+ void z180_device_xycb_c9();
+ void z180_device_xycb_ca();
+ void z180_device_xycb_cb();
+ void z180_device_xycb_cc();
+ void z180_device_xycb_cd();
+ void z180_device_xycb_ce();
+ void z180_device_xycb_cf();
+ void z180_device_xycb_d0();
+ void z180_device_xycb_d1();
+ void z180_device_xycb_d2();
+ void z180_device_xycb_d3();
+ void z180_device_xycb_d4();
+ void z180_device_xycb_d5();
+ void z180_device_xycb_d6();
+ void z180_device_xycb_d7();
+ void z180_device_xycb_d8();
+ void z180_device_xycb_d9();
+ void z180_device_xycb_da();
+ void z180_device_xycb_db();
+ void z180_device_xycb_dc();
+ void z180_device_xycb_dd();
+ void z180_device_xycb_de();
+ void z180_device_xycb_df();
+ void z180_device_xycb_e0();
+ void z180_device_xycb_e1();
+ void z180_device_xycb_e2();
+ void z180_device_xycb_e3();
+ void z180_device_xycb_e4();
+ void z180_device_xycb_e5();
+ void z180_device_xycb_e6();
+ void z180_device_xycb_e7();
+ void z180_device_xycb_e8();
+ void z180_device_xycb_e9();
+ void z180_device_xycb_ea();
+ void z180_device_xycb_eb();
+ void z180_device_xycb_ec();
+ void z180_device_xycb_ed();
+ void z180_device_xycb_ee();
+ void z180_device_xycb_ef();
+ void z180_device_xycb_f0();
+ void z180_device_xycb_f1();
+ void z180_device_xycb_f2();
+ void z180_device_xycb_f3();
+ void z180_device_xycb_f4();
+ void z180_device_xycb_f5();
+ void z180_device_xycb_f6();
+ void z180_device_xycb_f7();
+ void z180_device_xycb_f8();
+ void z180_device_xycb_f9();
+ void z180_device_xycb_fa();
+ void z180_device_xycb_fb();
+ void z180_device_xycb_fc();
+ void z180_device_xycb_fd();
+ void z180_device_xycb_fe();
+ void z180_device_xycb_ff();
//};
* opcodes with CB prefix
* rotate, shift and bit operations
**********************************************************/
-OP(cb,00) { _B = RLC(_B); } /* RLC B */
-OP(cb,01) { _C = RLC(_C); } /* RLC C */
-OP(cb,02) { _D = RLC(_D); } /* RLC D */
-OP(cb,03) { _E = RLC(_E); } /* RLC E */
-OP(cb,04) { _H = RLC(_H); } /* RLC H */
-OP(cb,05) { _L = RLC(_L); } /* RLC L */
-OP(cb,06) { WM( _HL, RLC(RM(_HL)) ); } /* RLC (HL) */
-OP(cb,07) { _A = RLC(_A); } /* RLC A */
+OP(cb,00) { _B = z180_device_RLC(_B); } /* RLC B */
+OP(cb,01) { _C = z180_device_RLC(_C); } /* RLC C */
+OP(cb,02) { _D = z180_device_RLC(_D); } /* RLC D */
+OP(cb,03) { _E = z180_device_RLC(_E); } /* RLC E */
+OP(cb,04) { _H = z180_device_RLC(_H); } /* RLC H */
+OP(cb,05) { _L = z180_device_RLC(_L); } /* RLC L */
+OP(cb,06) { WM( _HL, z180_device_RLC(z180_device_RM(_HL)) ); } /* RLC (HL) */
+OP(cb,07) { _A = z180_device_RLC(_A); } /* RLC A */
-OP(cb,08) { _B = RRC(_B); } /* RRC B */
-OP(cb,09) { _C = RRC(_C); } /* RRC C */
-OP(cb,0a) { _D = RRC(_D); } /* RRC D */
-OP(cb,0b) { _E = RRC(_E); } /* RRC E */
-OP(cb,0c) { _H = RRC(_H); } /* RRC H */
-OP(cb,0d) { _L = RRC(_L); } /* RRC L */
-OP(cb,0e) { WM( _HL, RRC(RM(_HL)) ); } /* RRC (HL) */
-OP(cb,0f) { _A = RRC(_A); } /* RRC A */
+OP(cb,08) { _B = z180_device_RRC(_B); } /* RRC B */
+OP(cb,09) { _C = z180_device_RRC(_C); } /* RRC C */
+OP(cb,0a) { _D = z180_device_RRC(_D); } /* RRC D */
+OP(cb,0b) { _E = z180_device_RRC(_E); } /* RRC E */
+OP(cb,0c) { _H = z180_device_RRC(_H); } /* RRC H */
+OP(cb,0d) { _L = z180_device_RRC(_L); } /* RRC L */
+OP(cb,0e) { WM( _HL, z180_device_RRC(z180_device_RM(_HL)) ); } /* RRC (HL) */
+OP(cb,0f) { _A = z180_device_RRC(_A); } /* RRC A */
-OP(cb,10) { _B = RL(_B); } /* RL B */
-OP(cb,11) { _C = RL(_C); } /* RL C */
-OP(cb,12) { _D = RL(_D); } /* RL D */
-OP(cb,13) { _E = RL(_E); } /* RL E */
-OP(cb,14) { _H = RL(_H); } /* RL H */
-OP(cb,15) { _L = RL(_L); } /* RL L */
-OP(cb,16) { WM( _HL, RL(RM(_HL)) ); } /* RL (HL) */
-OP(cb,17) { _A = RL(_A); } /* RL A */
+OP(cb,10) { _B = z180_device_RL(_B); } /* RL B */
+OP(cb,11) { _C = z180_device_RL(_C); } /* RL C */
+OP(cb,12) { _D = z180_device_RL(_D); } /* RL D */
+OP(cb,13) { _E = z180_device_RL(_E); } /* RL E */
+OP(cb,14) { _H = z180_device_RL(_H); } /* RL H */
+OP(cb,15) { _L = z180_device_RL(_L); } /* RL L */
+OP(cb,16) { WM( _HL, z180_device_RL(z180_device_RM(_HL)) ); } /* RL (HL) */
+OP(cb,17) { _A = z180_device_RL(_A); } /* RL A */
-OP(cb,18) { _B = RR(_B); } /* RR B */
-OP(cb,19) { _C = RR(_C); } /* RR C */
-OP(cb,1a) { _D = RR(_D); } /* RR D */
-OP(cb,1b) { _E = RR(_E); } /* RR E */
-OP(cb,1c) { _H = RR(_H); } /* RR H */
-OP(cb,1d) { _L = RR(_L); } /* RR L */
-OP(cb,1e) { WM( _HL, RR(RM(_HL)) ); } /* RR (HL) */
-OP(cb,1f) { _A = RR(_A); } /* RR A */
+OP(cb,18) { _B = z180_device_RR(_B); } /* RR B */
+OP(cb,19) { _C = z180_device_RR(_C); } /* RR C */
+OP(cb,1a) { _D = z180_device_RR(_D); } /* RR D */
+OP(cb,1b) { _E = z180_device_RR(_E); } /* RR E */
+OP(cb,1c) { _H = z180_device_RR(_H); } /* RR H */
+OP(cb,1d) { _L = z180_device_RR(_L); } /* RR L */
+OP(cb,1e) { WM( _HL, z180_device_RR(z180_device_RM(_HL)) ); } /* RR (HL) */
+OP(cb,1f) { _A = z180_device_RR(_A); } /* RR A */
-OP(cb,20) { _B = SLA(_B); } /* SLA B */
-OP(cb,21) { _C = SLA(_C); } /* SLA C */
-OP(cb,22) { _D = SLA(_D); } /* SLA D */
-OP(cb,23) { _E = SLA(_E); } /* SLA E */
-OP(cb,24) { _H = SLA(_H); } /* SLA H */
-OP(cb,25) { _L = SLA(_L); } /* SLA L */
-OP(cb,26) { WM( _HL, SLA(RM(_HL)) ); } /* SLA (HL) */
-OP(cb,27) { _A = SLA(_A); } /* SLA A */
+OP(cb,20) { _B = z180_device_SLA(_B); } /* SLA B */
+OP(cb,21) { _C = z180_device_SLA(_C); } /* SLA C */
+OP(cb,22) { _D = z180_device_SLA(_D); } /* SLA D */
+OP(cb,23) { _E = z180_device_SLA(_E); } /* SLA E */
+OP(cb,24) { _H = z180_device_SLA(_H); } /* SLA H */
+OP(cb,25) { _L = z180_device_SLA(_L); } /* SLA L */
+OP(cb,26) { WM( _HL, z180_device_SLA(z180_device_RM(_HL)) ); } /* SLA (HL) */
+OP(cb,27) { _A = z180_device_SLA(_A); } /* SLA A */
-OP(cb,28) { _B = SRA(_B); } /* SRA B */
-OP(cb,29) { _C = SRA(_C); } /* SRA C */
-OP(cb,2a) { _D = SRA(_D); } /* SRA D */
-OP(cb,2b) { _E = SRA(_E); } /* SRA E */
-OP(cb,2c) { _H = SRA(_H); } /* SRA H */
-OP(cb,2d) { _L = SRA(_L); } /* SRA L */
-OP(cb,2e) { WM( _HL, SRA(RM(_HL)) ); } /* SRA (HL) */
-OP(cb,2f) { _A = SRA(_A); } /* SRA A */
+OP(cb,28) { _B = z180_device_SRA(_B); } /* SRA B */
+OP(cb,29) { _C = z180_device_SRA(_C); } /* SRA C */
+OP(cb,2a) { _D = z180_device_SRA(_D); } /* SRA D */
+OP(cb,2b) { _E = z180_device_SRA(_E); } /* SRA E */
+OP(cb,2c) { _H = z180_device_SRA(_H); } /* SRA H */
+OP(cb,2d) { _L = z180_device_SRA(_L); } /* SRA L */
+OP(cb,2e) { WM( _HL, z180_device_SRA(z180_device_RM(_HL)) ); } /* SRA (HL) */
+OP(cb,2f) { _A = z180_device_SRA(_A); } /* SRA A */
-OP(cb,30) { _B = SLL(_B); } /* SLL B */
-OP(cb,31) { _C = SLL(_C); } /* SLL C */
-OP(cb,32) { _D = SLL(_D); } /* SLL D */
-OP(cb,33) { _E = SLL(_E); } /* SLL E */
-OP(cb,34) { _H = SLL(_H); } /* SLL H */
-OP(cb,35) { _L = SLL(_L); } /* SLL L */
-OP(cb,36) { WM( _HL, SLL(RM(_HL)) ); } /* SLL (HL) */
-OP(cb,37) { _A = SLL(_A); } /* SLL A */
+OP(cb,30) { _B = z180_device_SLL(_B); } /* SLL B */
+OP(cb,31) { _C = z180_device_SLL(_C); } /* SLL C */
+OP(cb,32) { _D = z180_device_SLL(_D); } /* SLL D */
+OP(cb,33) { _E = z180_device_SLL(_E); } /* SLL E */
+OP(cb,34) { _H = z180_device_SLL(_H); } /* SLL H */
+OP(cb,35) { _L = z180_device_SLL(_L); } /* SLL L */
+OP(cb,36) { WM( _HL, z180_device_SLL(z180_device_RM(_HL)) ); } /* SLL (HL) */
+OP(cb,37) { _A = z180_device_SLL(_A); } /* SLL A */
-OP(cb,38) { _B = SRL(_B); } /* SRL B */
-OP(cb,39) { _C = SRL(_C); } /* SRL C */
-OP(cb,3a) { _D = SRL(_D); } /* SRL D */
-OP(cb,3b) { _E = SRL(_E); } /* SRL E */
-OP(cb,3c) { _H = SRL(_H); } /* SRL H */
-OP(cb,3d) { _L = SRL(_L); } /* SRL L */
-OP(cb,3e) { WM( _HL, SRL(RM(_HL)) ); } /* SRL (HL) */
-OP(cb,3f) { _A = SRL(_A); } /* SRL A */
+OP(cb,38) { _B = z180_device_SRL(_B); } /* SRL B */
+OP(cb,39) { _C = z180_device_SRL(_C); } /* SRL C */
+OP(cb,3a) { _D = z180_device_SRL(_D); } /* SRL D */
+OP(cb,3b) { _E = z180_device_SRL(_E); } /* SRL E */
+OP(cb,3c) { _H = z180_device_SRL(_H); } /* SRL H */
+OP(cb,3d) { _L = z180_device_SRL(_L); } /* SRL L */
+OP(cb,3e) { WM( _HL, z180_device_SRL(z180_device_RM(_HL)) ); } /* SRL (HL) */
+OP(cb,3f) { _A = z180_device_SRL(_A); } /* SRL A */
OP(cb,40) { BIT(0,_B); } /* BIT 0,B */
OP(cb,41) { BIT(0,_C); } /* BIT 0,C */
OP(cb,43) { BIT(0,_E); } /* BIT 0,E */
OP(cb,44) { BIT(0,_H); } /* BIT 0,H */
OP(cb,45) { BIT(0,_L); } /* BIT 0,L */
-OP(cb,46) { BIT(0,RM(_HL)); } /* BIT 0,(HL) */
+OP(cb,46) { BIT(0,z180_device_RM(_HL)); } /* BIT 0,(HL) */
OP(cb,47) { BIT(0,_A); } /* BIT 0,A */
OP(cb,48) { BIT(1,_B); } /* BIT 1,B */
OP(cb,4b) { BIT(1,_E); } /* BIT 1,E */
OP(cb,4c) { BIT(1,_H); } /* BIT 1,H */
OP(cb,4d) { BIT(1,_L); } /* BIT 1,L */
-OP(cb,4e) { BIT(1,RM(_HL)); } /* BIT 1,(HL) */
+OP(cb,4e) { BIT(1,z180_device_RM(_HL)); } /* BIT 1,(HL) */
OP(cb,4f) { BIT(1,_A); } /* BIT 1,A */
OP(cb,50) { BIT(2,_B); } /* BIT 2,B */
OP(cb,53) { BIT(2,_E); } /* BIT 2,E */
OP(cb,54) { BIT(2,_H); } /* BIT 2,H */
OP(cb,55) { BIT(2,_L); } /* BIT 2,L */
-OP(cb,56) { BIT(2,RM(_HL)); } /* BIT 2,(HL) */
+OP(cb,56) { BIT(2,z180_device_RM(_HL)); } /* BIT 2,(HL) */
OP(cb,57) { BIT(2,_A); } /* BIT 2,A */
OP(cb,58) { BIT(3,_B); } /* BIT 3,B */
OP(cb,5b) { BIT(3,_E); } /* BIT 3,E */
OP(cb,5c) { BIT(3,_H); } /* BIT 3,H */
OP(cb,5d) { BIT(3,_L); } /* BIT 3,L */
-OP(cb,5e) { BIT(3,RM(_HL)); } /* BIT 3,(HL) */
+OP(cb,5e) { BIT(3,z180_device_RM(_HL)); } /* BIT 3,(HL) */
OP(cb,5f) { BIT(3,_A); } /* BIT 3,A */
OP(cb,60) { BIT(4,_B); } /* BIT 4,B */
OP(cb,63) { BIT(4,_E); } /* BIT 4,E */
OP(cb,64) { BIT(4,_H); } /* BIT 4,H */
OP(cb,65) { BIT(4,_L); } /* BIT 4,L */
-OP(cb,66) { BIT(4,RM(_HL)); } /* BIT 4,(HL) */
+OP(cb,66) { BIT(4,z180_device_RM(_HL)); } /* BIT 4,(HL) */
OP(cb,67) { BIT(4,_A); } /* BIT 4,A */
OP(cb,68) { BIT(5,_B); } /* BIT 5,B */
OP(cb,6b) { BIT(5,_E); } /* BIT 5,E */
OP(cb,6c) { BIT(5,_H); } /* BIT 5,H */
OP(cb,6d) { BIT(5,_L); } /* BIT 5,L */
-OP(cb,6e) { BIT(5,RM(_HL)); } /* BIT 5,(HL) */
+OP(cb,6e) { BIT(5,z180_device_RM(_HL)); } /* BIT 5,(HL) */
OP(cb,6f) { BIT(5,_A); } /* BIT 5,A */
OP(cb,70) { BIT(6,_B); } /* BIT 6,B */
OP(cb,73) { BIT(6,_E); } /* BIT 6,E */
OP(cb,74) { BIT(6,_H); } /* BIT 6,H */
OP(cb,75) { BIT(6,_L); } /* BIT 6,L */
-OP(cb,76) { BIT(6,RM(_HL)); } /* BIT 6,(HL) */
+OP(cb,76) { BIT(6,z180_device_RM(_HL)); } /* BIT 6,(HL) */
OP(cb,77) { BIT(6,_A); } /* BIT 6,A */
OP(cb,78) { BIT(7,_B); } /* BIT 7,B */
OP(cb,7b) { BIT(7,_E); } /* BIT 7,E */
OP(cb,7c) { BIT(7,_H); } /* BIT 7,H */
OP(cb,7d) { BIT(7,_L); } /* BIT 7,L */
-OP(cb,7e) { BIT(7,RM(_HL)); } /* BIT 7,(HL) */
+OP(cb,7e) { BIT(7,z180_device_RM(_HL)); } /* BIT 7,(HL) */
OP(cb,7f) { BIT(7,_A); } /* BIT 7,A */
-OP(cb,80) { _B = RES(0,_B); } /* RES 0,B */
-OP(cb,81) { _C = RES(0,_C); } /* RES 0,C */
-OP(cb,82) { _D = RES(0,_D); } /* RES 0,D */
-OP(cb,83) { _E = RES(0,_E); } /* RES 0,E */
-OP(cb,84) { _H = RES(0,_H); } /* RES 0,H */
-OP(cb,85) { _L = RES(0,_L); } /* RES 0,L */
-OP(cb,86) { WM( _HL, RES(0,RM(_HL)) ); } /* RES 0,(HL) */
-OP(cb,87) { _A = RES(0,_A); } /* RES 0,A */
+OP(cb,80) { _B = z180_device_RES(0,_B); } /* RES 0,B */
+OP(cb,81) { _C = z180_device_RES(0,_C); } /* RES 0,C */
+OP(cb,82) { _D = z180_device_RES(0,_D); } /* RES 0,D */
+OP(cb,83) { _E = z180_device_RES(0,_E); } /* RES 0,E */
+OP(cb,84) { _H = z180_device_RES(0,_H); } /* RES 0,H */
+OP(cb,85) { _L = z180_device_RES(0,_L); } /* RES 0,L */
+OP(cb,86) { WM( _HL, z180_device_RES(0,z180_device_RM(_HL)) ); } /* RES 0,(HL) */
+OP(cb,87) { _A = z180_device_RES(0,_A); } /* RES 0,A */
-OP(cb,88) { _B = RES(1,_B); } /* RES 1,B */
-OP(cb,89) { _C = RES(1,_C); } /* RES 1,C */
-OP(cb,8a) { _D = RES(1,_D); } /* RES 1,D */
-OP(cb,8b) { _E = RES(1,_E); } /* RES 1,E */
-OP(cb,8c) { _H = RES(1,_H); } /* RES 1,H */
-OP(cb,8d) { _L = RES(1,_L); } /* RES 1,L */
-OP(cb,8e) { WM( _HL, RES(1,RM(_HL)) ); } /* RES 1,(HL) */
-OP(cb,8f) { _A = RES(1,_A); } /* RES 1,A */
+OP(cb,88) { _B = z180_device_RES(1,_B); } /* RES 1,B */
+OP(cb,89) { _C = z180_device_RES(1,_C); } /* RES 1,C */
+OP(cb,8a) { _D = z180_device_RES(1,_D); } /* RES 1,D */
+OP(cb,8b) { _E = z180_device_RES(1,_E); } /* RES 1,E */
+OP(cb,8c) { _H = z180_device_RES(1,_H); } /* RES 1,H */
+OP(cb,8d) { _L = z180_device_RES(1,_L); } /* RES 1,L */
+OP(cb,8e) { WM( _HL, z180_device_RES(1,z180_device_RM(_HL)) ); } /* RES 1,(HL) */
+OP(cb,8f) { _A = z180_device_RES(1,_A); } /* RES 1,A */
-OP(cb,90) { _B = RES(2,_B); } /* RES 2,B */
-OP(cb,91) { _C = RES(2,_C); } /* RES 2,C */
-OP(cb,92) { _D = RES(2,_D); } /* RES 2,D */
-OP(cb,93) { _E = RES(2,_E); } /* RES 2,E */
-OP(cb,94) { _H = RES(2,_H); } /* RES 2,H */
-OP(cb,95) { _L = RES(2,_L); } /* RES 2,L */
-OP(cb,96) { WM( _HL, RES(2,RM(_HL)) ); } /* RES 2,(HL) */
-OP(cb,97) { _A = RES(2,_A); } /* RES 2,A */
+OP(cb,90) { _B = z180_device_RES(2,_B); } /* RES 2,B */
+OP(cb,91) { _C = z180_device_RES(2,_C); } /* RES 2,C */
+OP(cb,92) { _D = z180_device_RES(2,_D); } /* RES 2,D */
+OP(cb,93) { _E = z180_device_RES(2,_E); } /* RES 2,E */
+OP(cb,94) { _H = z180_device_RES(2,_H); } /* RES 2,H */
+OP(cb,95) { _L = z180_device_RES(2,_L); } /* RES 2,L */
+OP(cb,96) { WM( _HL, z180_device_RES(2,z180_device_RM(_HL)) ); } /* RES 2,(HL) */
+OP(cb,97) { _A = z180_device_RES(2,_A); } /* RES 2,A */
-OP(cb,98) { _B = RES(3,_B); } /* RES 3,B */
-OP(cb,99) { _C = RES(3,_C); } /* RES 3,C */
-OP(cb,9a) { _D = RES(3,_D); } /* RES 3,D */
-OP(cb,9b) { _E = RES(3,_E); } /* RES 3,E */
-OP(cb,9c) { _H = RES(3,_H); } /* RES 3,H */
-OP(cb,9d) { _L = RES(3,_L); } /* RES 3,L */
-OP(cb,9e) { WM( _HL, RES(3,RM(_HL)) ); } /* RES 3,(HL) */
-OP(cb,9f) { _A = RES(3,_A); } /* RES 3,A */
+OP(cb,98) { _B = z180_device_RES(3,_B); } /* RES 3,B */
+OP(cb,99) { _C = z180_device_RES(3,_C); } /* RES 3,C */
+OP(cb,9a) { _D = z180_device_RES(3,_D); } /* RES 3,D */
+OP(cb,9b) { _E = z180_device_RES(3,_E); } /* RES 3,E */
+OP(cb,9c) { _H = z180_device_RES(3,_H); } /* RES 3,H */
+OP(cb,9d) { _L = z180_device_RES(3,_L); } /* RES 3,L */
+OP(cb,9e) { WM( _HL, z180_device_RES(3,z180_device_RM(_HL)) ); } /* RES 3,(HL) */
+OP(cb,9f) { _A = z180_device_RES(3,_A); } /* RES 3,A */
-OP(cb,a0) { _B = RES(4,_B); } /* RES 4,B */
-OP(cb,a1) { _C = RES(4,_C); } /* RES 4,C */
-OP(cb,a2) { _D = RES(4,_D); } /* RES 4,D */
-OP(cb,a3) { _E = RES(4,_E); } /* RES 4,E */
-OP(cb,a4) { _H = RES(4,_H); } /* RES 4,H */
-OP(cb,a5) { _L = RES(4,_L); } /* RES 4,L */
-OP(cb,a6) { WM( _HL, RES(4,RM(_HL)) ); } /* RES 4,(HL) */
-OP(cb,a7) { _A = RES(4,_A); } /* RES 4,A */
+OP(cb,a0) { _B = z180_device_RES(4,_B); } /* RES 4,B */
+OP(cb,a1) { _C = z180_device_RES(4,_C); } /* RES 4,C */
+OP(cb,a2) { _D = z180_device_RES(4,_D); } /* RES 4,D */
+OP(cb,a3) { _E = z180_device_RES(4,_E); } /* RES 4,E */
+OP(cb,a4) { _H = z180_device_RES(4,_H); } /* RES 4,H */
+OP(cb,a5) { _L = z180_device_RES(4,_L); } /* RES 4,L */
+OP(cb,a6) { WM( _HL, z180_device_RES(4,z180_device_RM(_HL)) ); } /* RES 4,(HL) */
+OP(cb,a7) { _A = z180_device_RES(4,_A); } /* RES 4,A */
-OP(cb,a8) { _B = RES(5,_B); } /* RES 5,B */
-OP(cb,a9) { _C = RES(5,_C); } /* RES 5,C */
-OP(cb,aa) { _D = RES(5,_D); } /* RES 5,D */
-OP(cb,ab) { _E = RES(5,_E); } /* RES 5,E */
-OP(cb,ac) { _H = RES(5,_H); } /* RES 5,H */
-OP(cb,ad) { _L = RES(5,_L); } /* RES 5,L */
-OP(cb,ae) { WM( _HL, RES(5,RM(_HL)) ); } /* RES 5,(HL) */
-OP(cb,af) { _A = RES(5,_A); } /* RES 5,A */
+OP(cb,a8) { _B = z180_device_RES(5,_B); } /* RES 5,B */
+OP(cb,a9) { _C = z180_device_RES(5,_C); } /* RES 5,C */
+OP(cb,aa) { _D = z180_device_RES(5,_D); } /* RES 5,D */
+OP(cb,ab) { _E = z180_device_RES(5,_E); } /* RES 5,E */
+OP(cb,ac) { _H = z180_device_RES(5,_H); } /* RES 5,H */
+OP(cb,ad) { _L = z180_device_RES(5,_L); } /* RES 5,L */
+OP(cb,ae) { WM( _HL, z180_device_RES(5,z180_device_RM(_HL)) ); } /* RES 5,(HL) */
+OP(cb,af) { _A = z180_device_RES(5,_A); } /* RES 5,A */
-OP(cb,b0) { _B = RES(6,_B); } /* RES 6,B */
-OP(cb,b1) { _C = RES(6,_C); } /* RES 6,C */
-OP(cb,b2) { _D = RES(6,_D); } /* RES 6,D */
-OP(cb,b3) { _E = RES(6,_E); } /* RES 6,E */
-OP(cb,b4) { _H = RES(6,_H); } /* RES 6,H */
-OP(cb,b5) { _L = RES(6,_L); } /* RES 6,L */
-OP(cb,b6) { WM( _HL, RES(6,RM(_HL)) ); } /* RES 6,(HL) */
-OP(cb,b7) { _A = RES(6,_A); } /* RES 6,A */
+OP(cb,b0) { _B = z180_device_RES(6,_B); } /* RES 6,B */
+OP(cb,b1) { _C = z180_device_RES(6,_C); } /* RES 6,C */
+OP(cb,b2) { _D = z180_device_RES(6,_D); } /* RES 6,D */
+OP(cb,b3) { _E = z180_device_RES(6,_E); } /* RES 6,E */
+OP(cb,b4) { _H = z180_device_RES(6,_H); } /* RES 6,H */
+OP(cb,b5) { _L = z180_device_RES(6,_L); } /* RES 6,L */
+OP(cb,b6) { WM( _HL, z180_device_RES(6,z180_device_RM(_HL)) ); } /* RES 6,(HL) */
+OP(cb,b7) { _A = z180_device_RES(6,_A); } /* RES 6,A */
-OP(cb,b8) { _B = RES(7,_B); } /* RES 7,B */
-OP(cb,b9) { _C = RES(7,_C); } /* RES 7,C */
-OP(cb,ba) { _D = RES(7,_D); } /* RES 7,D */
-OP(cb,bb) { _E = RES(7,_E); } /* RES 7,E */
-OP(cb,bc) { _H = RES(7,_H); } /* RES 7,H */
-OP(cb,bd) { _L = RES(7,_L); } /* RES 7,L */
-OP(cb,be) { WM( _HL, RES(7,RM(_HL)) ); } /* RES 7,(HL) */
-OP(cb,bf) { _A = RES(7,_A); } /* RES 7,A */
+OP(cb,b8) { _B = z180_device_RES(7,_B); } /* RES 7,B */
+OP(cb,b9) { _C = z180_device_RES(7,_C); } /* RES 7,C */
+OP(cb,ba) { _D = z180_device_RES(7,_D); } /* RES 7,D */
+OP(cb,bb) { _E = z180_device_RES(7,_E); } /* RES 7,E */
+OP(cb,bc) { _H = z180_device_RES(7,_H); } /* RES 7,H */
+OP(cb,bd) { _L = z180_device_RES(7,_L); } /* RES 7,L */
+OP(cb,be) { WM( _HL, z180_device_RES(7,z180_device_RM(_HL)) ); } /* RES 7,(HL) */
+OP(cb,bf) { _A = z180_device_RES(7,_A); } /* RES 7,A */
-OP(cb,c0) { _B = SET(0,_B); } /* SET 0,B */
-OP(cb,c1) { _C = SET(0,_C); } /* SET 0,C */
-OP(cb,c2) { _D = SET(0,_D); } /* SET 0,D */
-OP(cb,c3) { _E = SET(0,_E); } /* SET 0,E */
-OP(cb,c4) { _H = SET(0,_H); } /* SET 0,H */
-OP(cb,c5) { _L = SET(0,_L); } /* SET 0,L */
-OP(cb,c6) { WM( _HL, SET(0,RM(_HL)) ); } /* SET 0,(HL) */
-OP(cb,c7) { _A = SET(0,_A); } /* SET 0,A */
+OP(cb,c0) { _B = z180_device_SET(0,_B); } /* SET 0,B */
+OP(cb,c1) { _C = z180_device_SET(0,_C); } /* SET 0,C */
+OP(cb,c2) { _D = z180_device_SET(0,_D); } /* SET 0,D */
+OP(cb,c3) { _E = z180_device_SET(0,_E); } /* SET 0,E */
+OP(cb,c4) { _H = z180_device_SET(0,_H); } /* SET 0,H */
+OP(cb,c5) { _L = z180_device_SET(0,_L); } /* SET 0,L */
+OP(cb,c6) { WM( _HL, z180_device_SET(0,z180_device_RM(_HL)) ); } /* SET 0,(HL) */
+OP(cb,c7) { _A = z180_device_SET(0,_A); } /* SET 0,A */
-OP(cb,c8) { _B = SET(1,_B); } /* SET 1,B */
-OP(cb,c9) { _C = SET(1,_C); } /* SET 1,C */
-OP(cb,ca) { _D = SET(1,_D); } /* SET 1,D */
-OP(cb,cb) { _E = SET(1,_E); } /* SET 1,E */
-OP(cb,cc) { _H = SET(1,_H); } /* SET 1,H */
-OP(cb,cd) { _L = SET(1,_L); } /* SET 1,L */
-OP(cb,ce) { WM( _HL, SET(1,RM(_HL)) ); } /* SET 1,(HL) */
-OP(cb,cf) { _A = SET(1,_A); } /* SET 1,A */
+OP(cb,c8) { _B = z180_device_SET(1,_B); } /* SET 1,B */
+OP(cb,c9) { _C = z180_device_SET(1,_C); } /* SET 1,C */
+OP(cb,ca) { _D = z180_device_SET(1,_D); } /* SET 1,D */
+OP(cb,cb) { _E = z180_device_SET(1,_E); } /* SET 1,E */
+OP(cb,cc) { _H = z180_device_SET(1,_H); } /* SET 1,H */
+OP(cb,cd) { _L = z180_device_SET(1,_L); } /* SET 1,L */
+OP(cb,ce) { WM( _HL, z180_device_SET(1,z180_device_RM(_HL)) ); } /* SET 1,(HL) */
+OP(cb,cf) { _A = z180_device_SET(1,_A); } /* SET 1,A */
-OP(cb,d0) { _B = SET(2,_B); } /* SET 2,B */
-OP(cb,d1) { _C = SET(2,_C); } /* SET 2,C */
-OP(cb,d2) { _D = SET(2,_D); } /* SET 2,D */
-OP(cb,d3) { _E = SET(2,_E); } /* SET 2,E */
-OP(cb,d4) { _H = SET(2,_H); } /* SET 2,H */
-OP(cb,d5) { _L = SET(2,_L); } /* SET 2,L */
-OP(cb,d6) { WM( _HL, SET(2,RM(_HL)) ); }/* SET 2,(HL) */
-OP(cb,d7) { _A = SET(2,_A); } /* SET 2,A */
+OP(cb,d0) { _B = z180_device_SET(2,_B); } /* SET 2,B */
+OP(cb,d1) { _C = z180_device_SET(2,_C); } /* SET 2,C */
+OP(cb,d2) { _D = z180_device_SET(2,_D); } /* SET 2,D */
+OP(cb,d3) { _E = z180_device_SET(2,_E); } /* SET 2,E */
+OP(cb,d4) { _H = z180_device_SET(2,_H); } /* SET 2,H */
+OP(cb,d5) { _L = z180_device_SET(2,_L); } /* SET 2,L */
+OP(cb,d6) { WM( _HL, z180_device_SET(2,z180_device_RM(_HL)) ); }/* SET 2,(HL) */
+OP(cb,d7) { _A = z180_device_SET(2,_A); } /* SET 2,A */
-OP(cb,d8) { _B = SET(3,_B); } /* SET 3,B */
-OP(cb,d9) { _C = SET(3,_C); } /* SET 3,C */
-OP(cb,da) { _D = SET(3,_D); } /* SET 3,D */
-OP(cb,db) { _E = SET(3,_E); } /* SET 3,E */
-OP(cb,dc) { _H = SET(3,_H); } /* SET 3,H */
-OP(cb,dd) { _L = SET(3,_L); } /* SET 3,L */
-OP(cb,de) { WM( _HL, SET(3,RM(_HL)) ); } /* SET 3,(HL) */
-OP(cb,df) { _A = SET(3,_A); } /* SET 3,A */
+OP(cb,d8) { _B = z180_device_SET(3,_B); } /* SET 3,B */
+OP(cb,d9) { _C = z180_device_SET(3,_C); } /* SET 3,C */
+OP(cb,da) { _D = z180_device_SET(3,_D); } /* SET 3,D */
+OP(cb,db) { _E = z180_device_SET(3,_E); } /* SET 3,E */
+OP(cb,dc) { _H = z180_device_SET(3,_H); } /* SET 3,H */
+OP(cb,dd) { _L = z180_device_SET(3,_L); } /* SET 3,L */
+OP(cb,de) { WM( _HL, z180_device_SET(3,z180_device_RM(_HL)) ); } /* SET 3,(HL) */
+OP(cb,df) { _A = z180_device_SET(3,_A); } /* SET 3,A */
-OP(cb,e0) { _B = SET(4,_B); } /* SET 4,B */
-OP(cb,e1) { _C = SET(4,_C); } /* SET 4,C */
-OP(cb,e2) { _D = SET(4,_D); } /* SET 4,D */
-OP(cb,e3) { _E = SET(4,_E); } /* SET 4,E */
-OP(cb,e4) { _H = SET(4,_H); } /* SET 4,H */
-OP(cb,e5) { _L = SET(4,_L); } /* SET 4,L */
-OP(cb,e6) { WM( _HL, SET(4,RM(_HL)) ); } /* SET 4,(HL) */
-OP(cb,e7) { _A = SET(4,_A); } /* SET 4,A */
+OP(cb,e0) { _B = z180_device_SET(4,_B); } /* SET 4,B */
+OP(cb,e1) { _C = z180_device_SET(4,_C); } /* SET 4,C */
+OP(cb,e2) { _D = z180_device_SET(4,_D); } /* SET 4,D */
+OP(cb,e3) { _E = z180_device_SET(4,_E); } /* SET 4,E */
+OP(cb,e4) { _H = z180_device_SET(4,_H); } /* SET 4,H */
+OP(cb,e5) { _L = z180_device_SET(4,_L); } /* SET 4,L */
+OP(cb,e6) { WM( _HL, z180_device_SET(4,z180_device_RM(_HL)) ); } /* SET 4,(HL) */
+OP(cb,e7) { _A = z180_device_SET(4,_A); } /* SET 4,A */
-OP(cb,e8) { _B = SET(5,_B); } /* SET 5,B */
-OP(cb,e9) { _C = SET(5,_C); } /* SET 5,C */
-OP(cb,ea) { _D = SET(5,_D); } /* SET 5,D */
-OP(cb,eb) { _E = SET(5,_E); } /* SET 5,E */
-OP(cb,ec) { _H = SET(5,_H); } /* SET 5,H */
-OP(cb,ed) { _L = SET(5,_L); } /* SET 5,L */
-OP(cb,ee) { WM( _HL, SET(5,RM(_HL)) ); } /* SET 5,(HL) */
-OP(cb,ef) { _A = SET(5,_A); } /* SET 5,A */
+OP(cb,e8) { _B = z180_device_SET(5,_B); } /* SET 5,B */
+OP(cb,e9) { _C = z180_device_SET(5,_C); } /* SET 5,C */
+OP(cb,ea) { _D = z180_device_SET(5,_D); } /* SET 5,D */
+OP(cb,eb) { _E = z180_device_SET(5,_E); } /* SET 5,E */
+OP(cb,ec) { _H = z180_device_SET(5,_H); } /* SET 5,H */
+OP(cb,ed) { _L = z180_device_SET(5,_L); } /* SET 5,L */
+OP(cb,ee) { WM( _HL, z180_device_SET(5,z180_device_RM(_HL)) ); } /* SET 5,(HL) */
+OP(cb,ef) { _A = z180_device_SET(5,_A); } /* SET 5,A */
-OP(cb,f0) { _B = SET(6,_B); } /* SET 6,B */
-OP(cb,f1) { _C = SET(6,_C); } /* SET 6,C */
-OP(cb,f2) { _D = SET(6,_D); } /* SET 6,D */
-OP(cb,f3) { _E = SET(6,_E); } /* SET 6,E */
-OP(cb,f4) { _H = SET(6,_H); } /* SET 6,H */
-OP(cb,f5) { _L = SET(6,_L); } /* SET 6,L */
-OP(cb,f6) { WM( _HL, SET(6,RM(_HL)) ); } /* SET 6,(HL) */
-OP(cb,f7) { _A = SET(6,_A); } /* SET 6,A */
+OP(cb,f0) { _B = z180_device_SET(6,_B); } /* SET 6,B */
+OP(cb,f1) { _C = z180_device_SET(6,_C); } /* SET 6,C */
+OP(cb,f2) { _D = z180_device_SET(6,_D); } /* SET 6,D */
+OP(cb,f3) { _E = z180_device_SET(6,_E); } /* SET 6,E */
+OP(cb,f4) { _H = z180_device_SET(6,_H); } /* SET 6,H */
+OP(cb,f5) { _L = z180_device_SET(6,_L); } /* SET 6,L */
+OP(cb,f6) { WM( _HL, z180_device_SET(6,z180_device_RM(_HL)) ); } /* SET 6,(HL) */
+OP(cb,f7) { _A = z180_device_SET(6,_A); } /* SET 6,A */
-OP(cb,f8) { _B = SET(7,_B); } /* SET 7,B */
-OP(cb,f9) { _C = SET(7,_C); } /* SET 7,C */
-OP(cb,fa) { _D = SET(7,_D); } /* SET 7,D */
-OP(cb,fb) { _E = SET(7,_E); } /* SET 7,E */
-OP(cb,fc) { _H = SET(7,_H); } /* SET 7,H */
-OP(cb,fd) { _L = SET(7,_L); } /* SET 7,L */
-OP(cb,fe) { WM( _HL, SET(7,RM(_HL)) ); } /* SET 7,(HL) */
-OP(cb,ff) { _A = SET(7,_A); } /* SET 7,A */
+OP(cb,f8) { _B = z180_device_SET(7,_B); } /* SET 7,B */
+OP(cb,f9) { _C = z180_device_SET(7,_C); } /* SET 7,C */
+OP(cb,fa) { _D = z180_device_SET(7,_D); } /* SET 7,D */
+OP(cb,fb) { _E = z180_device_SET(7,_E); } /* SET 7,E */
+OP(cb,fc) { _H = z180_device_SET(7,_H); } /* SET 7,H */
+OP(cb,fd) { _L = z180_device_SET(7,_L); } /* SET 7,L */
+OP(cb,fe) { WM( _HL, z180_device_SET(7,z180_device_RM(_HL)) ); } /* SET 7,(HL) */
+OP(cb,ff) { _A = z180_device_SET(7,_A); } /* SET 7,A */
#include "emu.h"
#include "z180dasm.h"
-const char *const /*z180_disassembler::*/s_mnemonic[] = {
+const char *const z180_disassembler_s_mnemonic[] = {
"adc" ,"add" ,"and" ,"bit" ,"call" ,"ccf" ,"cp" ,"cpd" ,
"cpdr" ,"cpi" ,"cpir" ,"cpl" ,"daa" ,"db" ,"dec" ,"di" ,
"djnz" ,"ei" ,"ex" ,"exx" ,"halt" ,"im" ,"in" ,"in0" ,
"slp" ,"sra" ,"srl" ,"sub" ,"tst" ,"tstio","xor "
};
-const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_xx_cb[256]= {
+const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx_cb[256]= {
{zRLC,"b=Y"}, {zRLC,"c=Y"}, {zRLC,"d=Y"}, {zRLC,"e=Y"},
{zRLC,"h=Y"}, {zRLC,"l=Y"}, {zRLC,"Y"}, {zRLC,"a=Y"},
{zRRC,"b=Y"}, {zRRC,"c=Y"}, {zRRC,"d=Y"}, {zRRC,"e=Y"},
{zSET,"h=7,Y"}, {zSET,"l=7,Y"}, {zSET,"7,Y"}, {zSET,"a=7,Y"}
};
-const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_cb[256] = {
+const z180_disassembler_z80dasm z180_disassembler_mnemonic_cb[256] = {
{zRLC,"b"}, {zRLC,"c"}, {zRLC,"d"}, {zRLC,"e"},
{zRLC,"h"}, {zRLC,"l"}, {zRLC,"(hl)"}, {zRLC,"a"},
{zRRC,"b"}, {zRRC,"c"}, {zRRC,"d"}, {zRRC,"e"},
{zSET,"7,h"}, {zSET,"7,l"}, {zSET,"7,(hl)"},{zSET,"7,a"}
};
-const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_ed[256]= {
+const z180_disassembler_z80dasm z180_disassembler_mnemonic_ed[256]= {
{zIN0,"b,(B)"}, {zOUT0,"(B),b"},{zDB,"?"}, {zDB,"?"},
{zTST,"b"}, {zDB,"?"}, {zDB,"?"}, {zDB,"?"},
{zIN0,"c,(B)"}, {zOUT0,"(B),c"},{zDB,"?"}, {zDB,"?"},
{zDB,"?"}, {zDB,"?"}, {zDB,"?"}, {zDB,"?"}
};
-const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_xx[256]= {
+const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx[256]= {
{zDB,"?"}, {zDB,"?"}, {zDB,"?"}, {zDB,"?"},
{zDB,"?"}, {zDB,"?"}, {zDB,"?"}, {zDB,"?"},
{zDB,"?"}, {zADD,"I,bc"}, {zDB,"?"}, {zDB,"?"},
{zDB,"?"}, {zDB,"?"}, {zDB,"?"}, {zDB,"?"}
};
-const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_main[256]= {
+const z180_disassembler_z80dasm z180_disassembler_mnemonic_main[256]= {
{zNOP,/*nullptr*/NULL}, {zLD,"bc,N"}, {zLD,"(bc),a"}, {zINC,"bc"},
{zINC,"b"}, {zDEC,"b"}, {zLD,"b,B"}, {zRLCA,/*nullptr*/NULL},
{zEX,"af,af'"}, {zADD,"hl,bc"}, {zLD,"a,(bc)"}, {zDEC,"bc"},
{zCALL,"m,A"}, {zDB,"fd"}, {zCP,"B"}, {zRST,"V"}
};
-char /*z180_disassembler::*/sign(int8_t offset)
+char z180_disassembler_sign(int8_t offset)
{
return (offset < 0)? '-':'+';
}
-int /*z180_disassembler::*/offs(int8_t offset)
+int z180_disassembler_offs(int8_t offset)
{
if (offset < 0) return -offset;
return offset;
/****************************************************************************
* Disassemble opcode at PC and return number of bytes it takes
****************************************************************************/
-//offs_t /*z180_disassembler::*/disassemble(std::ostream &stream, offs_t pc, const data_buffer &opcodes, const data_buffer ¶ms)
-offs_t /*z180_disassembler::*/disassemble(FILE *stream, offs_t pc)
+//offs_t z180_disassembler_disassemble(std_ostream &stream, offs_t pc, const data_buffer &opcodes, const data_buffer ¶ms)
+offs_t z180_disassembler_disassemble(FILE *stream, offs_t pc)
{
- const z80dasm *d;
+ const z180_disassembler_z80dasm *d;
const char *src, *ixy;
int8_t offset = 0;
uint8_t op, op1 = 0;
{
case 0xcb:
op = opcodes_r8(pos++);
- d = &mnemonic_cb[op];
+ d = &z180_disassembler_mnemonic_cb[op];
break;
case 0xed:
op1 = opcodes_r8(pos++);
- d = &mnemonic_ed[op1];
+ d = &z180_disassembler_mnemonic_ed[op1];
break;
case 0xdd:
ixy = "ix";
{
offset = (int8_t) params_r8(pos++);
op1 = params_r8(pos++); /* fourth byte from opbase.ram! */
- d = &mnemonic_xx_cb[op1];
+ d = &z180_disassembler_mnemonic_xx_cb[op1];
}
- else d = &mnemonic_xx[op1];
+ else d = &z180_disassembler_mnemonic_xx[op1];
break;
case 0xfd:
ixy = "iy";
{
offset = (int8_t) params_r8(pos++);
op1 = params_r8(pos++); /* fourth byte from opbase.ram! */
- d = &mnemonic_xx_cb[op1];
+ d = &z180_disassembler_mnemonic_xx_cb[op1];
}
- else d = &mnemonic_xx[op1];
+ else d = &z180_disassembler_mnemonic_xx[op1];
break;
default:
- d = &mnemonic_main[op];
+ d = &z180_disassembler_mnemonic_main[op];
break;
}
if( d->arguments )
{
- fprintf(stream, "%-5s ", s_mnemonic[d->mnemonic]);
+ fprintf(stream, "%-5s ", z180_disassembler_s_mnemonic[d->mnemonic]);
src = d->arguments;
while( *src )
{
case 'X':
offset = (int8_t) params_r8(pos++);
case 'Y':
- fprintf(stream,"(%s%c$%02x)", ixy, sign(offset), offs(offset));
+ fprintf(stream,"(%s%c$%02x)", ixy, z180_disassembler_sign(offset), z180_disassembler_offs(offset));
break;
case 'I':
fprintf(stream, "%s", ixy);
}
else
{
- fprintf(stream, "%s", s_mnemonic[d->mnemonic]);
+ fprintf(stream, "%s", z180_disassembler_s_mnemonic[d->mnemonic]);
}
if (d->mnemonic == zCALL || d->mnemonic == zCPDR || d->mnemonic == zCPIR || d->mnemonic == zDJNZ ||
return (pos - pc) | flags | SUPPORTED;
}
-//u32 /*z180_disassembler::*/opcode_alignment() const
+//u32 z180_disassembler_opcode_alignment() const
//{
// return 1;
//}
//#pragma once
#include <stdio.h>
-//class z180_disassembler : public util::disasm_interface
+//class z180_disassembler : public util_disasm_interface
//{
//public:
// z180_disassembler() = default;
// virtual ~z180_disassembler() = default;
//
-// virtual u32 opcode_alignment() const override;
-// virtual offs_t disassemble(std::ostream &stream, offs_t pc, const data_buffer &opcodes, const data_buffer ¶ms) override;
-offs_t disassemble(FILE *stream, offs_t pc);
+// virtual u32 z180_disassembler_opcode_alignment() const override;
+// virtual offs_t z180_disassembler_disassemble(std_ostream &stream, offs_t pc, const data_buffer &opcodes, const data_buffer ¶ms) override;
+offs_t z180_disassembler_disassemble(FILE *stream, offs_t pc);
//
//private:
- typedef struct z80dasm {
+ typedef struct z180_disassembler_z80dasm {
uint8_t mnemonic;
const char *arguments;
- } z80dasm;
+ } z180_disassembler_z80dasm;
enum e_mnemonics {
zADC ,zADD ,zAND ,zBIT ,zCALL ,zCCF ,zCP ,zCPD ,
zSLP ,zSRA ,zSRL ,zSUB ,zTST ,zTSTIO ,zXOR
};
-// static const char *const s_mnemonic[];
-extern const char *const /*z180_disassembler::*/s_mnemonic[];
-// static const z80dasm mnemonic_xx_cb[256];
-extern const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_xx_cb[256];
-// static const z80dasm mnemonic_cb[256];
-extern const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_cb[256];
-// static const z80dasm mnemonic_ed[256];
-extern const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_ed[256];
-// static const z80dasm mnemonic_xx[256];
-extern const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_xx[256];
-// static const z80dasm mnemonic_main[256];
-extern const /*z180_disassembler::*/z80dasm /*z180_disassembler::*/mnemonic_main[256];
+// static const char *const z180_disassembler_s_mnemonic[];
+extern const char *const z180_disassembler_s_mnemonic[];
+// static const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx_cb[256];
+extern const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx_cb[256];
+// static const z180_disassembler_z80dasm z180_disassembler_mnemonic_cb[256];
+extern const z180_disassembler_z80dasm z180_disassembler_mnemonic_cb[256];
+// static const z180_disassembler_z80dasm z180_disassembler_mnemonic_ed[256];
+extern const z180_disassembler_z80dasm z180_disassembler_mnemonic_ed[256];
+// static const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx[256];
+extern const z180_disassembler_z80dasm z180_disassembler_mnemonic_xx[256];
+// static const z180_disassembler_z80dasm z180_disassembler_mnemonic_main[256];
+extern const z180_disassembler_z80dasm z180_disassembler_mnemonic_main[256];
-// static char sign(int8_t offset);
-// static int offs(int8_t offset);
+// static char z180_disassembler_sign(int8_t offset);
+// static int z180_disassembler_offs(int8_t offset);
//};
#endif
/**********************************************************
* IX register related opcodes (DD prefix)
**********************************************************/
-OP(dd,00) { illegal_1(); op_00(); } /* DB DD */
-OP(dd,01) { illegal_1(); op_01(); } /* DB DD */
-OP(dd,02) { illegal_1(); op_02(); } /* DB DD */
-OP(dd,03) { illegal_1(); op_03(); } /* DB DD */
-OP(dd,04) { illegal_1(); op_04(); } /* DB DD */
-OP(dd,05) { illegal_1(); op_05(); } /* DB DD */
-OP(dd,06) { illegal_1(); op_06(); } /* DB DD */
-OP(dd,07) { illegal_1(); op_07(); } /* DB DD */
-
-OP(dd,08) { illegal_1(); op_08(); } /* DB DD */
+OP(dd,00) { z180_device_illegal_1(); z180_device_op_00(); } /* DB DD */
+OP(dd,01) { z180_device_illegal_1(); z180_device_op_01(); } /* DB DD */
+OP(dd,02) { z180_device_illegal_1(); z180_device_op_02(); } /* DB DD */
+OP(dd,03) { z180_device_illegal_1(); z180_device_op_03(); } /* DB DD */
+OP(dd,04) { z180_device_illegal_1(); z180_device_op_04(); } /* DB DD */
+OP(dd,05) { z180_device_illegal_1(); z180_device_op_05(); } /* DB DD */
+OP(dd,06) { z180_device_illegal_1(); z180_device_op_06(); } /* DB DD */
+OP(dd,07) { z180_device_illegal_1(); z180_device_op_07(); } /* DB DD */
+
+OP(dd,08) { z180_device_illegal_1(); z180_device_op_08(); } /* DB DD */
OP(dd,09) { m_R++; ADD16(IX,BC); } /* ADD IX,BC */
-OP(dd,0a) { illegal_1(); op_0a(); } /* DB DD */
-OP(dd,0b) { illegal_1(); op_0b(); } /* DB DD */
-OP(dd,0c) { illegal_1(); op_0c(); } /* DB DD */
-OP(dd,0d) { illegal_1(); op_0d(); } /* DB DD */
-OP(dd,0e) { illegal_1(); op_0e(); } /* DB DD */
-OP(dd,0f) { illegal_1(); op_0f(); } /* DB DD */
-
-OP(dd,10) { illegal_1(); op_10(); } /* DB DD */
-OP(dd,11) { illegal_1(); op_11(); } /* DB DD */
-OP(dd,12) { illegal_1(); op_12(); } /* DB DD */
-OP(dd,13) { illegal_1(); op_13(); } /* DB DD */
-OP(dd,14) { illegal_1(); op_14(); } /* DB DD */
-OP(dd,15) { illegal_1(); op_15(); } /* DB DD */
-OP(dd,16) { illegal_1(); op_16(); } /* DB DD */
-OP(dd,17) { illegal_1(); op_17(); } /* DB DD */
-
-OP(dd,18) { illegal_1(); op_18(); } /* DB DD */
+OP(dd,0a) { z180_device_illegal_1(); z180_device_op_0a(); } /* DB DD */
+OP(dd,0b) { z180_device_illegal_1(); z180_device_op_0b(); } /* DB DD */
+OP(dd,0c) { z180_device_illegal_1(); z180_device_op_0c(); } /* DB DD */
+OP(dd,0d) { z180_device_illegal_1(); z180_device_op_0d(); } /* DB DD */
+OP(dd,0e) { z180_device_illegal_1(); z180_device_op_0e(); } /* DB DD */
+OP(dd,0f) { z180_device_illegal_1(); z180_device_op_0f(); } /* DB DD */
+
+OP(dd,10) { z180_device_illegal_1(); z180_device_op_10(); } /* DB DD */
+OP(dd,11) { z180_device_illegal_1(); z180_device_op_11(); } /* DB DD */
+OP(dd,12) { z180_device_illegal_1(); z180_device_op_12(); } /* DB DD */
+OP(dd,13) { z180_device_illegal_1(); z180_device_op_13(); } /* DB DD */
+OP(dd,14) { z180_device_illegal_1(); z180_device_op_14(); } /* DB DD */
+OP(dd,15) { z180_device_illegal_1(); z180_device_op_15(); } /* DB DD */
+OP(dd,16) { z180_device_illegal_1(); z180_device_op_16(); } /* DB DD */
+OP(dd,17) { z180_device_illegal_1(); z180_device_op_17(); } /* DB DD */
+
+OP(dd,18) { z180_device_illegal_1(); z180_device_op_18(); } /* DB DD */
OP(dd,19) { m_R++; ADD16(IX,DE); } /* ADD IX,DE */
-OP(dd,1a) { illegal_1(); op_1a(); } /* DB DD */
-OP(dd,1b) { illegal_1(); op_1b(); } /* DB DD */
-OP(dd,1c) { illegal_1(); op_1c(); } /* DB DD */
-OP(dd,1d) { illegal_1(); op_1d(); } /* DB DD */
-OP(dd,1e) { illegal_1(); op_1e(); } /* DB DD */
-OP(dd,1f) { illegal_1(); op_1f(); } /* DB DD */
-
-OP(dd,20) { illegal_1(); op_20(); } /* DB DD */
-OP(dd,21) { m_R++; _IX = ARG16(); } /* LD IX,w */
-OP(dd,22) { m_R++; m_ea = ARG16(); WM16( m_ea, &m_IX ); } /* LD (w),IX */
+OP(dd,1a) { z180_device_illegal_1(); z180_device_op_1a(); } /* DB DD */
+OP(dd,1b) { z180_device_illegal_1(); z180_device_op_1b(); } /* DB DD */
+OP(dd,1c) { z180_device_illegal_1(); z180_device_op_1c(); } /* DB DD */
+OP(dd,1d) { z180_device_illegal_1(); z180_device_op_1d(); } /* DB DD */
+OP(dd,1e) { z180_device_illegal_1(); z180_device_op_1e(); } /* DB DD */
+OP(dd,1f) { z180_device_illegal_1(); z180_device_op_1f(); } /* DB DD */
+
+OP(dd,20) { z180_device_illegal_1(); z180_device_op_20(); } /* DB DD */
+OP(dd,21) { m_R++; _IX = z180_device_ARG16(); } /* LD IX,w */
+OP(dd,22) { m_R++; m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_IX ); } /* LD (w),IX */
OP(dd,23) { m_R++; _IX++; } /* INC IX */
-OP(dd,24) { m_R++; _HX = INC(_HX); } /* INC HX */
-OP(dd,25) { m_R++; _HX = DEC(_HX); } /* DEC HX */
-OP(dd,26) { m_R++; _HX = ARG(); } /* LD HX,n */
-OP(dd,27) { illegal_1(); op_27(); } /* DB DD */
+OP(dd,24) { m_R++; _HX = z180_device_INC(_HX); } /* INC HX */
+OP(dd,25) { m_R++; _HX = z180_device_DEC(_HX); } /* DEC HX */
+OP(dd,26) { m_R++; _HX = z180_device_ARG(); } /* LD HX,n */
+OP(dd,27) { z180_device_illegal_1(); z180_device_op_27(); } /* DB DD */
-OP(dd,28) { illegal_1(); op_28(); } /* DB DD */
+OP(dd,28) { z180_device_illegal_1(); z180_device_op_28(); } /* DB DD */
OP(dd,29) { m_R++; ADD16(IX,IX); } /* ADD IX,IX */
-OP(dd,2a) { m_R++; m_ea = ARG16(); RM16( m_ea, &m_IX ); } /* LD IX,(w) */
+OP(dd,2a) { m_R++; m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_IX ); } /* LD IX,(w) */
OP(dd,2b) { m_R++; _IX--; } /* DEC IX */
-OP(dd,2c) { m_R++; _LX = INC(_LX); } /* INC LX */
-OP(dd,2d) { m_R++; _LX = DEC(_LX); } /* DEC LX */
-OP(dd,2e) { m_R++; _LX = ARG(); } /* LD LX,n */
-OP(dd,2f) { illegal_1(); op_2f(); } /* DB DD */
-
-OP(dd,30) { illegal_1(); op_30(); } /* DB DD */
-OP(dd,31) { illegal_1(); op_31(); } /* DB DD */
-OP(dd,32) { illegal_1(); op_32(); } /* DB DD */
-OP(dd,33) { illegal_1(); op_33(); } /* DB DD */
-OP(dd,34) { m_R++; EAX(); WM( m_ea, INC(RM(m_ea)) ); } /* INC (IX+o) */
-OP(dd,35) { m_R++; EAX(); WM( m_ea, DEC(RM(m_ea)) ); } /* DEC (IX+o) */
-OP(dd,36) { m_R++; EAX(); WM( m_ea, ARG() ); } /* LD (IX+o),n */
-OP(dd,37) { illegal_1(); op_37(); } /* DB DD */
-
-OP(dd,38) { illegal_1(); op_38(); } /* DB DD */
+OP(dd,2c) { m_R++; _LX = z180_device_INC(_LX); } /* INC LX */
+OP(dd,2d) { m_R++; _LX = z180_device_DEC(_LX); } /* DEC LX */
+OP(dd,2e) { m_R++; _LX = z180_device_ARG(); } /* LD LX,n */
+OP(dd,2f) { z180_device_illegal_1(); z180_device_op_2f(); } /* DB DD */
+
+OP(dd,30) { z180_device_illegal_1(); z180_device_op_30(); } /* DB DD */
+OP(dd,31) { z180_device_illegal_1(); z180_device_op_31(); } /* DB DD */
+OP(dd,32) { z180_device_illegal_1(); z180_device_op_32(); } /* DB DD */
+OP(dd,33) { z180_device_illegal_1(); z180_device_op_33(); } /* DB DD */
+OP(dd,34) { m_R++; EAX(); WM( m_ea, z180_device_INC(z180_device_RM(m_ea)) ); } /* INC (IX+o) */
+OP(dd,35) { m_R++; EAX(); WM( m_ea, z180_device_DEC(z180_device_RM(m_ea)) ); } /* DEC (IX+o) */
+OP(dd,36) { m_R++; EAX(); WM( m_ea, z180_device_ARG() ); } /* LD (IX+o),n */
+OP(dd,37) { z180_device_illegal_1(); z180_device_op_37(); } /* DB DD */
+
+OP(dd,38) { z180_device_illegal_1(); z180_device_op_38(); } /* DB DD */
OP(dd,39) { m_R++; ADD16(IX,SP); } /* ADD IX,SP */
-OP(dd,3a) { illegal_1(); op_3a(); } /* DB DD */
-OP(dd,3b) { illegal_1(); op_3b(); } /* DB DD */
-OP(dd,3c) { illegal_1(); op_3c(); } /* DB DD */
-OP(dd,3d) { illegal_1(); op_3d(); } /* DB DD */
-OP(dd,3e) { illegal_1(); op_3e(); } /* DB DD */
-OP(dd,3f) { illegal_1(); op_3f(); } /* DB DD */
-
-OP(dd,40) { illegal_1(); op_40(); } /* DB DD */
-OP(dd,41) { illegal_1(); op_41(); } /* DB DD */
-OP(dd,42) { illegal_1(); op_42(); } /* DB DD */
-OP(dd,43) { illegal_1(); op_43(); } /* DB DD */
+OP(dd,3a) { z180_device_illegal_1(); z180_device_op_3a(); } /* DB DD */
+OP(dd,3b) { z180_device_illegal_1(); z180_device_op_3b(); } /* DB DD */
+OP(dd,3c) { z180_device_illegal_1(); z180_device_op_3c(); } /* DB DD */
+OP(dd,3d) { z180_device_illegal_1(); z180_device_op_3d(); } /* DB DD */
+OP(dd,3e) { z180_device_illegal_1(); z180_device_op_3e(); } /* DB DD */
+OP(dd,3f) { z180_device_illegal_1(); z180_device_op_3f(); } /* DB DD */
+
+OP(dd,40) { z180_device_illegal_1(); z180_device_op_40(); } /* DB DD */
+OP(dd,41) { z180_device_illegal_1(); z180_device_op_41(); } /* DB DD */
+OP(dd,42) { z180_device_illegal_1(); z180_device_op_42(); } /* DB DD */
+OP(dd,43) { z180_device_illegal_1(); z180_device_op_43(); } /* DB DD */
OP(dd,44) { m_R++; _B = _HX; } /* LD B,HX */
OP(dd,45) { m_R++; _B = _LX; } /* LD B,LX */
-OP(dd,46) { m_R++; EAX(); _B = RM(m_ea); } /* LD B,(IX+o) */
-OP(dd,47) { illegal_1(); op_47(); } /* DB DD */
+OP(dd,46) { m_R++; EAX(); _B = z180_device_RM(m_ea); } /* LD B,(IX+o) */
+OP(dd,47) { z180_device_illegal_1(); z180_device_op_47(); } /* DB DD */
-OP(dd,48) { illegal_1(); op_48(); } /* DB DD */
-OP(dd,49) { illegal_1(); op_49(); } /* DB DD */
-OP(dd,4a) { illegal_1(); op_4a(); } /* DB DD */
-OP(dd,4b) { illegal_1(); op_4b(); } /* DB DD */
+OP(dd,48) { z180_device_illegal_1(); z180_device_op_48(); } /* DB DD */
+OP(dd,49) { z180_device_illegal_1(); z180_device_op_49(); } /* DB DD */
+OP(dd,4a) { z180_device_illegal_1(); z180_device_op_4a(); } /* DB DD */
+OP(dd,4b) { z180_device_illegal_1(); z180_device_op_4b(); } /* DB DD */
OP(dd,4c) { m_R++; _C = _HX; } /* LD C,HX */
OP(dd,4d) { m_R++; _C = _LX; } /* LD C,LX */
-OP(dd,4e) { m_R++; EAX(); _C = RM(m_ea); } /* LD C,(IX+o) */
-OP(dd,4f) { illegal_1(); op_4f(); } /* DB DD */
+OP(dd,4e) { m_R++; EAX(); _C = z180_device_RM(m_ea); } /* LD C,(IX+o) */
+OP(dd,4f) { z180_device_illegal_1(); z180_device_op_4f(); } /* DB DD */
-OP(dd,50) { illegal_1(); op_50(); } /* DB DD */
-OP(dd,51) { illegal_1(); op_51(); } /* DB DD */
-OP(dd,52) { illegal_1(); op_52(); } /* DB DD */
-OP(dd,53) { illegal_1(); op_53(); } /* DB DD */
+OP(dd,50) { z180_device_illegal_1(); z180_device_op_50(); } /* DB DD */
+OP(dd,51) { z180_device_illegal_1(); z180_device_op_51(); } /* DB DD */
+OP(dd,52) { z180_device_illegal_1(); z180_device_op_52(); } /* DB DD */
+OP(dd,53) { z180_device_illegal_1(); z180_device_op_53(); } /* DB DD */
OP(dd,54) { m_R++; _D = _HX; } /* LD D,HX */
OP(dd,55) { m_R++; _D = _LX; } /* LD D,LX */
-OP(dd,56) { m_R++; EAX(); _D = RM(m_ea); } /* LD D,(IX+o) */
-OP(dd,57) { illegal_1(); op_57(); } /* DB DD */
+OP(dd,56) { m_R++; EAX(); _D = z180_device_RM(m_ea); } /* LD D,(IX+o) */
+OP(dd,57) { z180_device_illegal_1(); z180_device_op_57(); } /* DB DD */
-OP(dd,58) { illegal_1(); op_58(); } /* DB DD */
-OP(dd,59) { illegal_1(); op_59(); } /* DB DD */
-OP(dd,5a) { illegal_1(); op_5a(); } /* DB DD */
-OP(dd,5b) { illegal_1(); op_5b(); } /* DB DD */
+OP(dd,58) { z180_device_illegal_1(); z180_device_op_58(); } /* DB DD */
+OP(dd,59) { z180_device_illegal_1(); z180_device_op_59(); } /* DB DD */
+OP(dd,5a) { z180_device_illegal_1(); z180_device_op_5a(); } /* DB DD */
+OP(dd,5b) { z180_device_illegal_1(); z180_device_op_5b(); } /* DB DD */
OP(dd,5c) { m_R++; _E = _HX; } /* LD E,HX */
OP(dd,5d) { m_R++; _E = _LX; } /* LD E,LX */
-OP(dd,5e) { m_R++; EAX(); _E = RM(m_ea); } /* LD E,(IX+o) */
-OP(dd,5f) { illegal_1(); op_5f(); } /* DB DD */
+OP(dd,5e) { m_R++; EAX(); _E = z180_device_RM(m_ea); } /* LD E,(IX+o) */
+OP(dd,5f) { z180_device_illegal_1(); z180_device_op_5f(); } /* DB DD */
OP(dd,60) { m_R++; _HX = _B; } /* LD HX,B */
OP(dd,61) { m_R++; _HX = _C; } /* LD HX,C */
OP(dd,63) { m_R++; _HX = _E; } /* LD HX,E */
OP(dd,64) { } /* LD HX,HX */
OP(dd,65) { m_R++; _HX = _LX; } /* LD HX,LX */
-OP(dd,66) { m_R++; EAX(); _H = RM(m_ea); } /* LD H,(IX+o) */
+OP(dd,66) { m_R++; EAX(); _H = z180_device_RM(m_ea); } /* LD H,(IX+o) */
OP(dd,67) { m_R++; _HX = _A; } /* LD HX,A */
OP(dd,68) { m_R++; _LX = _B; } /* LD LX,B */
OP(dd,6b) { m_R++; _LX = _E; } /* LD LX,E */
OP(dd,6c) { m_R++; _LX = _HX; } /* LD LX,HX */
OP(dd,6d) { } /* LD LX,LX */
-OP(dd,6e) { m_R++; EAX(); _L = RM(m_ea); } /* LD L,(IX+o) */
+OP(dd,6e) { m_R++; EAX(); _L = z180_device_RM(m_ea); } /* LD L,(IX+o) */
OP(dd,6f) { m_R++; _LX = _A; } /* LD LX,A */
OP(dd,70) { m_R++; EAX(); WM( m_ea, _B ); } /* LD (IX+o),B */
OP(dd,73) { m_R++; EAX(); WM( m_ea, _E ); } /* LD (IX+o),E */
OP(dd,74) { m_R++; EAX(); WM( m_ea, _H ); } /* LD (IX+o),H */
OP(dd,75) { m_R++; EAX(); WM( m_ea, _L ); } /* LD (IX+o),L */
-OP(dd,76) { illegal_1(); op_76(); } /* DB DD */
+OP(dd,76) { z180_device_illegal_1(); z180_device_op_76(); } /* DB DD */
OP(dd,77) { m_R++; EAX(); WM( m_ea, _A ); } /* LD (IX+o),A */
-OP(dd,78) { illegal_1(); op_78(); } /* DB DD */
-OP(dd,79) { illegal_1(); op_79(); } /* DB DD */
-OP(dd,7a) { illegal_1(); op_7a(); } /* DB DD */
-OP(dd,7b) { illegal_1(); op_7b(); } /* DB DD */
+OP(dd,78) { z180_device_illegal_1(); z180_device_op_78(); } /* DB DD */
+OP(dd,79) { z180_device_illegal_1(); z180_device_op_79(); } /* DB DD */
+OP(dd,7a) { z180_device_illegal_1(); z180_device_op_7a(); } /* DB DD */
+OP(dd,7b) { z180_device_illegal_1(); z180_device_op_7b(); } /* DB DD */
OP(dd,7c) { m_R++; _A = _HX; } /* LD A,HX */
OP(dd,7d) { m_R++; _A = _LX; } /* LD A,LX */
-OP(dd,7e) { m_R++; EAX(); _A = RM(m_ea); } /* LD A,(IX+o) */
-OP(dd,7f) { illegal_1(); op_7f(); } /* DB DD */
+OP(dd,7e) { m_R++; EAX(); _A = z180_device_RM(m_ea); } /* LD A,(IX+o) */
+OP(dd,7f) { z180_device_illegal_1(); z180_device_op_7f(); } /* DB DD */
-OP(dd,80) { illegal_1(); op_80(); } /* DB DD */
-OP(dd,81) { illegal_1(); op_81(); } /* DB DD */
-OP(dd,82) { illegal_1(); op_82(); } /* DB DD */
-OP(dd,83) { illegal_1(); op_83(); } /* DB DD */
+OP(dd,80) { z180_device_illegal_1(); z180_device_op_80(); } /* DB DD */
+OP(dd,81) { z180_device_illegal_1(); z180_device_op_81(); } /* DB DD */
+OP(dd,82) { z180_device_illegal_1(); z180_device_op_82(); } /* DB DD */
+OP(dd,83) { z180_device_illegal_1(); z180_device_op_83(); } /* DB DD */
OP(dd,84) { m_R++; ADD(_HX); } /* ADD A,HX */
OP(dd,85) { m_R++; ADD(_LX); } /* ADD A,LX */
-OP(dd,86) { m_R++; EAX(); ADD(RM(m_ea)); } /* ADD A,(IX+o) */
-OP(dd,87) { illegal_1(); op_87(); } /* DB DD */
+OP(dd,86) { m_R++; EAX(); ADD(z180_device_RM(m_ea)); } /* ADD A,(IX+o) */
+OP(dd,87) { z180_device_illegal_1(); z180_device_op_87(); } /* DB DD */
-OP(dd,88) { illegal_1(); op_88(); } /* DB DD */
-OP(dd,89) { illegal_1(); op_89(); } /* DB DD */
-OP(dd,8a) { illegal_1(); op_8a(); } /* DB DD */
-OP(dd,8b) { illegal_1(); op_8b(); } /* DB DD */
+OP(dd,88) { z180_device_illegal_1(); z180_device_op_88(); } /* DB DD */
+OP(dd,89) { z180_device_illegal_1(); z180_device_op_89(); } /* DB DD */
+OP(dd,8a) { z180_device_illegal_1(); z180_device_op_8a(); } /* DB DD */
+OP(dd,8b) { z180_device_illegal_1(); z180_device_op_8b(); } /* DB DD */
OP(dd,8c) { m_R++; ADC(_HX); } /* ADC A,HX */
OP(dd,8d) { m_R++; ADC(_LX); } /* ADC A,LX */
-OP(dd,8e) { m_R++; EAX(); ADC(RM(m_ea)); } /* ADC A,(IX+o) */
-OP(dd,8f) { illegal_1(); op_8f(); } /* DB DD */
+OP(dd,8e) { m_R++; EAX(); ADC(z180_device_RM(m_ea)); } /* ADC A,(IX+o) */
+OP(dd,8f) { z180_device_illegal_1(); z180_device_op_8f(); } /* DB DD */
-OP(dd,90) { illegal_1(); op_90(); } /* DB DD */
-OP(dd,91) { illegal_1(); op_91(); } /* DB DD */
-OP(dd,92) { illegal_1(); op_92(); } /* DB DD */
-OP(dd,93) { illegal_1(); op_93(); } /* DB DD */
+OP(dd,90) { z180_device_illegal_1(); z180_device_op_90(); } /* DB DD */
+OP(dd,91) { z180_device_illegal_1(); z180_device_op_91(); } /* DB DD */
+OP(dd,92) { z180_device_illegal_1(); z180_device_op_92(); } /* DB DD */
+OP(dd,93) { z180_device_illegal_1(); z180_device_op_93(); } /* DB DD */
OP(dd,94) { m_R++; SUB(_HX); } /* SUB HX */
OP(dd,95) { m_R++; SUB(_LX); } /* SUB LX */
-OP(dd,96) { m_R++; EAX(); SUB(RM(m_ea)); } /* SUB (IX+o) */
-OP(dd,97) { illegal_1(); op_97(); } /* DB DD */
+OP(dd,96) { m_R++; EAX(); SUB(z180_device_RM(m_ea)); } /* SUB (IX+o) */
+OP(dd,97) { z180_device_illegal_1(); z180_device_op_97(); } /* DB DD */
-OP(dd,98) { illegal_1(); op_98(); } /* DB DD */
-OP(dd,99) { illegal_1(); op_99(); } /* DB DD */
-OP(dd,9a) { illegal_1(); op_9a(); } /* DB DD */
-OP(dd,9b) { illegal_1(); op_9b(); } /* DB DD */
+OP(dd,98) { z180_device_illegal_1(); z180_device_op_98(); } /* DB DD */
+OP(dd,99) { z180_device_illegal_1(); z180_device_op_99(); } /* DB DD */
+OP(dd,9a) { z180_device_illegal_1(); z180_device_op_9a(); } /* DB DD */
+OP(dd,9b) { z180_device_illegal_1(); z180_device_op_9b(); } /* DB DD */
OP(dd,9c) { m_R++; SBC(_HX); } /* SBC A,HX */
OP(dd,9d) { m_R++; SBC(_LX); } /* SBC A,LX */
-OP(dd,9e) { m_R++; EAX(); SBC(RM(m_ea)); } /* SBC A,(IX+o) */
-OP(dd,9f) { illegal_1(); op_9f(); } /* DB DD */
+OP(dd,9e) { m_R++; EAX(); SBC(z180_device_RM(m_ea)); } /* SBC A,(IX+o) */
+OP(dd,9f) { z180_device_illegal_1(); z180_device_op_9f(); } /* DB DD */
-OP(dd,a0) { illegal_1(); op_a0(); } /* DB DD */
-OP(dd,a1) { illegal_1(); op_a1(); } /* DB DD */
-OP(dd,a2) { illegal_1(); op_a2(); } /* DB DD */
-OP(dd,a3) { illegal_1(); op_a3(); } /* DB DD */
+OP(dd,a0) { z180_device_illegal_1(); z180_device_op_a0(); } /* DB DD */
+OP(dd,a1) { z180_device_illegal_1(); z180_device_op_a1(); } /* DB DD */
+OP(dd,a2) { z180_device_illegal_1(); z180_device_op_a2(); } /* DB DD */
+OP(dd,a3) { z180_device_illegal_1(); z180_device_op_a3(); } /* DB DD */
OP(dd,a4) { m_R++; AND(_HX); } /* AND HX */
OP(dd,a5) { m_R++; AND(_LX); } /* AND LX */
-OP(dd,a6) { m_R++; EAX(); AND(RM(m_ea)); } /* AND (IX+o) */
-OP(dd,a7) { illegal_1(); op_a7(); } /* DB DD */
+OP(dd,a6) { m_R++; EAX(); AND(z180_device_RM(m_ea)); } /* AND (IX+o) */
+OP(dd,a7) { z180_device_illegal_1(); z180_device_op_a7(); } /* DB DD */
-OP(dd,a8) { illegal_1(); op_a8(); } /* DB DD */
-OP(dd,a9) { illegal_1(); op_a9(); } /* DB DD */
-OP(dd,aa) { illegal_1(); op_aa(); } /* DB DD */
-OP(dd,ab) { illegal_1(); op_ab(); } /* DB DD */
+OP(dd,a8) { z180_device_illegal_1(); z180_device_op_a8(); } /* DB DD */
+OP(dd,a9) { z180_device_illegal_1(); z180_device_op_a9(); } /* DB DD */
+OP(dd,aa) { z180_device_illegal_1(); z180_device_op_aa(); } /* DB DD */
+OP(dd,ab) { z180_device_illegal_1(); z180_device_op_ab(); } /* DB DD */
OP(dd,ac) { m_R++; XOR(_HX); } /* XOR HX */
OP(dd,ad) { m_R++; XOR(_LX); } /* XOR LX */
-OP(dd,ae) { m_R++; EAX(); XOR(RM(m_ea)); } /* XOR (IX+o) */
-OP(dd,af) { illegal_1(); op_af(); } /* DB DD */
+OP(dd,ae) { m_R++; EAX(); XOR(z180_device_RM(m_ea)); } /* XOR (IX+o) */
+OP(dd,af) { z180_device_illegal_1(); z180_device_op_af(); } /* DB DD */
-OP(dd,b0) { illegal_1(); op_b0(); } /* DB DD */
-OP(dd,b1) { illegal_1(); op_b1(); } /* DB DD */
-OP(dd,b2) { illegal_1(); op_b2(); } /* DB DD */
-OP(dd,b3) { illegal_1(); op_b3(); } /* DB DD */
+OP(dd,b0) { z180_device_illegal_1(); z180_device_op_b0(); } /* DB DD */
+OP(dd,b1) { z180_device_illegal_1(); z180_device_op_b1(); } /* DB DD */
+OP(dd,b2) { z180_device_illegal_1(); z180_device_op_b2(); } /* DB DD */
+OP(dd,b3) { z180_device_illegal_1(); z180_device_op_b3(); } /* DB DD */
OP(dd,b4) { m_R++; OR(_HX); } /* OR HX */
OP(dd,b5) { m_R++; OR(_LX); } /* OR LX */
-OP(dd,b6) { m_R++; EAX(); OR(RM(m_ea)); } /* OR (IX+o) */
-OP(dd,b7) { illegal_1(); op_b7(); } /* DB DD */
+OP(dd,b6) { m_R++; EAX(); OR(z180_device_RM(m_ea)); } /* OR (IX+o) */
+OP(dd,b7) { z180_device_illegal_1(); z180_device_op_b7(); } /* DB DD */
-OP(dd,b8) { illegal_1(); op_b8(); } /* DB DD */
-OP(dd,b9) { illegal_1(); op_b9(); } /* DB DD */
-OP(dd,ba) { illegal_1(); op_ba(); } /* DB DD */
-OP(dd,bb) { illegal_1(); op_bb(); } /* DB DD */
+OP(dd,b8) { z180_device_illegal_1(); z180_device_op_b8(); } /* DB DD */
+OP(dd,b9) { z180_device_illegal_1(); z180_device_op_b9(); } /* DB DD */
+OP(dd,ba) { z180_device_illegal_1(); z180_device_op_ba(); } /* DB DD */
+OP(dd,bb) { z180_device_illegal_1(); z180_device_op_bb(); } /* DB DD */
OP(dd,bc) { m_R++; CP(_HX); } /* CP HX */
OP(dd,bd) { m_R++; CP(_LX); } /* CP LX */
-OP(dd,be) { m_R++; EAX(); CP(RM(m_ea)); } /* CP (IX+o) */
-OP(dd,bf) { illegal_1(); op_bf(); } /* DB DD */
-
-OP(dd,c0) { illegal_1(); op_c0(); } /* DB DD */
-OP(dd,c1) { illegal_1(); op_c1(); } /* DB DD */
-OP(dd,c2) { illegal_1(); op_c2(); } /* DB DD */
-OP(dd,c3) { illegal_1(); op_c3(); } /* DB DD */
-OP(dd,c4) { illegal_1(); op_c4(); } /* DB DD */
-OP(dd,c5) { illegal_1(); op_c5(); } /* DB DD */
-OP(dd,c6) { illegal_1(); op_c6(); } /* DB DD */
-OP(dd,c7) { illegal_1(); op_c7(); } /* DB DD */
-
-OP(dd,c8) { illegal_1(); op_c8(); } /* DB DD */
-OP(dd,c9) { illegal_1(); op_c9(); } /* DB DD */
-OP(dd,ca) { illegal_1(); op_ca(); } /* DB DD */
-OP(dd,cb) { m_R++; EAX(); m_extra_cycles += exec_xycb(ARG()); } /* ** DD CB xx */
-OP(dd,cc) { illegal_1(); op_cc(); } /* DB DD */
-OP(dd,cd) { illegal_1(); op_cd(); } /* DB DD */
-OP(dd,ce) { illegal_1(); op_ce(); } /* DB DD */
-OP(dd,cf) { illegal_1(); op_cf(); } /* DB DD */
-
-OP(dd,d0) { illegal_1(); op_d0(); } /* DB DD */
-OP(dd,d1) { illegal_1(); op_d1(); } /* DB DD */
-OP(dd,d2) { illegal_1(); op_d2(); } /* DB DD */
-OP(dd,d3) { illegal_1(); op_d3(); } /* DB DD */
-OP(dd,d4) { illegal_1(); op_d4(); } /* DB DD */
-OP(dd,d5) { illegal_1(); op_d5(); } /* DB DD */
-OP(dd,d6) { illegal_1(); op_d6(); } /* DB DD */
-OP(dd,d7) { illegal_1(); op_d7(); } /* DB DD */
-
-OP(dd,d8) { illegal_1(); op_d8(); } /* DB DD */
-OP(dd,d9) { illegal_1(); op_d9(); } /* DB DD */
-OP(dd,da) { illegal_1(); op_da(); } /* DB DD */
-OP(dd,db) { illegal_1(); op_db(); } /* DB DD */
-OP(dd,dc) { illegal_1(); op_dc(); } /* DB DD */
-OP(dd,dd) { illegal_1(); op_dd(); } /* DB DD */
-OP(dd,de) { illegal_1(); op_de(); } /* DB DD */
-OP(dd,df) { illegal_1(); op_df(); } /* DB DD */
-
-OP(dd,e0) { illegal_1(); op_e0(); } /* DB DD */
+OP(dd,be) { m_R++; EAX(); CP(z180_device_RM(m_ea)); } /* CP (IX+o) */
+OP(dd,bf) { z180_device_illegal_1(); z180_device_op_bf(); } /* DB DD */
+
+OP(dd,c0) { z180_device_illegal_1(); z180_device_op_c0(); } /* DB DD */
+OP(dd,c1) { z180_device_illegal_1(); z180_device_op_c1(); } /* DB DD */
+OP(dd,c2) { z180_device_illegal_1(); z180_device_op_c2(); } /* DB DD */
+OP(dd,c3) { z180_device_illegal_1(); z180_device_op_c3(); } /* DB DD */
+OP(dd,c4) { z180_device_illegal_1(); z180_device_op_c4(); } /* DB DD */
+OP(dd,c5) { z180_device_illegal_1(); z180_device_op_c5(); } /* DB DD */
+OP(dd,c6) { z180_device_illegal_1(); z180_device_op_c6(); } /* DB DD */
+OP(dd,c7) { z180_device_illegal_1(); z180_device_op_c7(); } /* DB DD */
+
+OP(dd,c8) { z180_device_illegal_1(); z180_device_op_c8(); } /* DB DD */
+OP(dd,c9) { z180_device_illegal_1(); z180_device_op_c9(); } /* DB DD */
+OP(dd,ca) { z180_device_illegal_1(); z180_device_op_ca(); } /* DB DD */
+OP(dd,cb) { m_R++; EAX(); m_extra_cycles += z180_device_exec_xycb(z180_device_ARG()); } /* ** DD CB xx */
+OP(dd,cc) { z180_device_illegal_1(); z180_device_op_cc(); } /* DB DD */
+OP(dd,cd) { z180_device_illegal_1(); z180_device_op_cd(); } /* DB DD */
+OP(dd,ce) { z180_device_illegal_1(); z180_device_op_ce(); } /* DB DD */
+OP(dd,cf) { z180_device_illegal_1(); z180_device_op_cf(); } /* DB DD */
+
+OP(dd,d0) { z180_device_illegal_1(); z180_device_op_d0(); } /* DB DD */
+OP(dd,d1) { z180_device_illegal_1(); z180_device_op_d1(); } /* DB DD */
+OP(dd,d2) { z180_device_illegal_1(); z180_device_op_d2(); } /* DB DD */
+OP(dd,d3) { z180_device_illegal_1(); z180_device_op_d3(); } /* DB DD */
+OP(dd,d4) { z180_device_illegal_1(); z180_device_op_d4(); } /* DB DD */
+OP(dd,d5) { z180_device_illegal_1(); z180_device_op_d5(); } /* DB DD */
+OP(dd,d6) { z180_device_illegal_1(); z180_device_op_d6(); } /* DB DD */
+OP(dd,d7) { z180_device_illegal_1(); z180_device_op_d7(); } /* DB DD */
+
+OP(dd,d8) { z180_device_illegal_1(); z180_device_op_d8(); } /* DB DD */
+OP(dd,d9) { z180_device_illegal_1(); z180_device_op_d9(); } /* DB DD */
+OP(dd,da) { z180_device_illegal_1(); z180_device_op_da(); } /* DB DD */
+OP(dd,db) { z180_device_illegal_1(); z180_device_op_db(); } /* DB DD */
+OP(dd,dc) { z180_device_illegal_1(); z180_device_op_dc(); } /* DB DD */
+OP(dd,dd) { z180_device_illegal_1(); z180_device_op_dd(); } /* DB DD */
+OP(dd,de) { z180_device_illegal_1(); z180_device_op_de(); } /* DB DD */
+OP(dd,df) { z180_device_illegal_1(); z180_device_op_df(); } /* DB DD */
+
+OP(dd,e0) { z180_device_illegal_1(); z180_device_op_e0(); } /* DB DD */
OP(dd,e1) { m_R++; POP(IX); } /* POP IX */
-OP(dd,e2) { illegal_1(); op_e2(); } /* DB DD */
+OP(dd,e2) { z180_device_illegal_1(); z180_device_op_e2(); } /* DB DD */
OP(dd,e3) { m_R++; EXSP(IX); } /* EX (SP),IX */
-OP(dd,e4) { illegal_1(); op_e4(); } /* DB DD */
+OP(dd,e4) { z180_device_illegal_1(); z180_device_op_e4(); } /* DB DD */
OP(dd,e5) { m_R++; PUSH( IX ); } /* PUSH IX */
-OP(dd,e6) { illegal_1(); op_e6(); } /* DB DD */
-OP(dd,e7) { illegal_1(); op_e7(); } /* DB DD */
+OP(dd,e6) { z180_device_illegal_1(); z180_device_op_e6(); } /* DB DD */
+OP(dd,e7) { z180_device_illegal_1(); z180_device_op_e7(); } /* DB DD */
-OP(dd,e8) { illegal_1(); op_e8(); } /* DB DD */
+OP(dd,e8) { z180_device_illegal_1(); z180_device_op_e8(); } /* DB DD */
OP(dd,e9) { m_R++; _PC = _IX; } /* JP (IX) */
-OP(dd,ea) { illegal_1(); op_ea(); } /* DB DD */
-OP(dd,eb) { illegal_1(); op_eb(); } /* DB DD */
-OP(dd,ec) { illegal_1(); op_ec(); } /* DB DD */
-OP(dd,ed) { illegal_1(); op_ed(); } /* DB DD */
-OP(dd,ee) { illegal_1(); op_ee(); } /* DB DD */
-OP(dd,ef) { illegal_1(); op_ef(); } /* DB DD */
-
-OP(dd,f0) { illegal_1(); op_f0(); } /* DB DD */
-OP(dd,f1) { illegal_1(); op_f1(); } /* DB DD */
-OP(dd,f2) { illegal_1(); op_f2(); } /* DB DD */
-OP(dd,f3) { illegal_1(); op_f3(); } /* DB DD */
-OP(dd,f4) { illegal_1(); op_f4(); } /* DB DD */
-OP(dd,f5) { illegal_1(); op_f5(); } /* DB DD */
-OP(dd,f6) { illegal_1(); op_f6(); } /* DB DD */
-OP(dd,f7) { illegal_1(); op_f7(); } /* DB DD */
-
-OP(dd,f8) { illegal_1(); op_f8(); } /* DB DD */
+OP(dd,ea) { z180_device_illegal_1(); z180_device_op_ea(); } /* DB DD */
+OP(dd,eb) { z180_device_illegal_1(); z180_device_op_eb(); } /* DB DD */
+OP(dd,ec) { z180_device_illegal_1(); z180_device_op_ec(); } /* DB DD */
+OP(dd,ed) { z180_device_illegal_1(); z180_device_op_ed(); } /* DB DD */
+OP(dd,ee) { z180_device_illegal_1(); z180_device_op_ee(); } /* DB DD */
+OP(dd,ef) { z180_device_illegal_1(); z180_device_op_ef(); } /* DB DD */
+
+OP(dd,f0) { z180_device_illegal_1(); z180_device_op_f0(); } /* DB DD */
+OP(dd,f1) { z180_device_illegal_1(); z180_device_op_f1(); } /* DB DD */
+OP(dd,f2) { z180_device_illegal_1(); z180_device_op_f2(); } /* DB DD */
+OP(dd,f3) { z180_device_illegal_1(); z180_device_op_f3(); } /* DB DD */
+OP(dd,f4) { z180_device_illegal_1(); z180_device_op_f4(); } /* DB DD */
+OP(dd,f5) { z180_device_illegal_1(); z180_device_op_f5(); } /* DB DD */
+OP(dd,f6) { z180_device_illegal_1(); z180_device_op_f6(); } /* DB DD */
+OP(dd,f7) { z180_device_illegal_1(); z180_device_op_f7(); } /* DB DD */
+
+OP(dd,f8) { z180_device_illegal_1(); z180_device_op_f8(); } /* DB DD */
OP(dd,f9) { m_R++; _SP = _IX; } /* LD SP,IX */
-OP(dd,fa) { illegal_1(); op_fa(); } /* DB DD */
-OP(dd,fb) { illegal_1(); op_fb(); } /* DB DD */
-OP(dd,fc) { illegal_1(); op_fc(); } /* DB DD */
-OP(dd,fd) { illegal_1(); op_fd(); } /* DB DD */
-OP(dd,fe) { illegal_1(); op_fe(); } /* DB DD */
-OP(dd,ff) { illegal_1(); op_ff(); } /* DB DD */
+OP(dd,fa) { z180_device_illegal_1(); z180_device_op_fa(); } /* DB DD */
+OP(dd,fb) { z180_device_illegal_1(); z180_device_op_fb(); } /* DB DD */
+OP(dd,fc) { z180_device_illegal_1(); z180_device_op_fc(); } /* DB DD */
+OP(dd,fd) { z180_device_illegal_1(); z180_device_op_fd(); } /* DB DD */
+OP(dd,fe) { z180_device_illegal_1(); z180_device_op_fe(); } /* DB DD */
+OP(dd,ff) { z180_device_illegal_1(); z180_device_op_ff(); } /* DB DD */
/**********************************************************
* special opcodes (ED prefix)
**********************************************************/
-OP(ed,00) { unsigned n = ARG(); _B = IN( n ); } /* IN0 B,(n) */
-OP(ed,01) { unsigned n = ARG(); OUT( n, _B ); } /* OUT0 (n),B */
-OP(ed,02) { illegal_2(); } /* DB ED */
-OP(ed,03) { illegal_2(); } /* DB ED */
+OP(ed,00) { unsigned n = z180_device_ARG(); _B = z180_device_IN( n ); } /* IN0 B,(n) */
+OP(ed,01) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _B ); } /* OUT0 (n),B */
+OP(ed,02) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,03) { z180_device_illegal_2(); } /* DB ED */
OP(ed,04) { TST( _B ); } /* TST B */
-OP(ed,05) { illegal_2(); } /* DB ED */
-OP(ed,06) { illegal_2(); } /* DB ED */
-OP(ed,07) { illegal_2(); } /* DB ED */
-
-OP(ed,08) { unsigned n = ARG(); _C = IN( n ); } /* IN0 C,(n) */
-OP(ed,09) { unsigned n = ARG(); OUT( n, _C ); } /* OUT0 (n),C */
-OP(ed,0a) { illegal_2(); } /* DB ED */
-OP(ed,0b) { illegal_2(); } /* DB ED */
+OP(ed,05) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,06) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,07) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,08) { unsigned n = z180_device_ARG(); _C = z180_device_IN( n ); } /* IN0 C,(n) */
+OP(ed,09) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _C ); } /* OUT0 (n),C */
+OP(ed,0a) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,0b) { z180_device_illegal_2(); } /* DB ED */
OP(ed,0c) { TST( _C ); } /* TST C */
-OP(ed,0d) { illegal_2(); } /* DB ED */
-OP(ed,0e) { illegal_2(); } /* DB ED */
-OP(ed,0f) { illegal_2(); } /* DB ED */
-
-OP(ed,10) { unsigned n = ARG(); _D = IN( n ); } /* IN0 D,(n) */
-OP(ed,11) { unsigned n = ARG(); OUT( n, _D ); } /* OUT0 (n),D */
-OP(ed,12) { illegal_2(); } /* DB ED */
-OP(ed,13) { illegal_2(); } /* DB ED */
+OP(ed,0d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,0e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,0f) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,10) { unsigned n = z180_device_ARG(); _D = z180_device_IN( n ); } /* IN0 D,(n) */
+OP(ed,11) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _D ); } /* OUT0 (n),D */
+OP(ed,12) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,13) { z180_device_illegal_2(); } /* DB ED */
OP(ed,14) { TST( _D ); } /* TST D */
-OP(ed,15) { illegal_2(); } /* DB ED */
-OP(ed,16) { illegal_2(); } /* DB ED */
-OP(ed,17) { illegal_2(); } /* DB ED */
-
-OP(ed,18) { unsigned n = ARG(); _E = IN( n ); } /* IN0 E,(n) */
-OP(ed,19) { unsigned n = ARG(); OUT( n, _E ); } /* OUT0 (n),E */
-OP(ed,1a) { illegal_2(); } /* DB ED */
-OP(ed,1b) { illegal_2(); } /* DB ED */
+OP(ed,15) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,16) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,17) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,18) { unsigned n = z180_device_ARG(); _E = z180_device_IN( n ); } /* IN0 E,(n) */
+OP(ed,19) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _E ); } /* OUT0 (n),E */
+OP(ed,1a) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,1b) { z180_device_illegal_2(); } /* DB ED */
OP(ed,1c) { TST( _E ); } /* TST E */
-OP(ed,1d) { illegal_2(); } /* DB ED */
-OP(ed,1e) { illegal_2(); } /* DB ED */
-OP(ed,1f) { illegal_2(); } /* DB ED */
-
-OP(ed,20) { unsigned n = ARG(); _H = IN( n ); } /* IN0 H,(n) */
-OP(ed,21) { unsigned n = ARG(); OUT( n, _H ); } /* OUT0 (n),H */
-OP(ed,22) { illegal_2(); } /* DB ED */
-OP(ed,23) { illegal_2(); } /* DB ED */
+OP(ed,1d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,1e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,1f) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,20) { unsigned n = z180_device_ARG(); _H = z180_device_IN( n ); } /* IN0 H,(n) */
+OP(ed,21) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _H ); } /* OUT0 (n),H */
+OP(ed,22) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,23) { z180_device_illegal_2(); } /* DB ED */
OP(ed,24) { TST( _H ); } /* TST H */
-OP(ed,25) { illegal_2(); } /* DB ED */
-OP(ed,26) { illegal_2(); } /* DB ED */
-OP(ed,27) { illegal_2(); } /* DB ED */
-
-OP(ed,28) { unsigned n = ARG(); _L = IN( n ); } /* IN0 L,(n) */
-OP(ed,29) { unsigned n = ARG(); OUT( n, _L ); } /* OUT0 (n),L */
-OP(ed,2a) { illegal_2(); } /* DB ED */
-OP(ed,2b) { illegal_2(); } /* DB ED */
+OP(ed,25) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,26) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,27) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,28) { unsigned n = z180_device_ARG(); _L = z180_device_IN( n ); } /* IN0 L,(n) */
+OP(ed,29) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _L ); } /* OUT0 (n),L */
+OP(ed,2a) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,2b) { z180_device_illegal_2(); } /* DB ED */
OP(ed,2c) { TST( _L ); } /* TST L */
-OP(ed,2d) { illegal_2(); } /* DB ED */
-OP(ed,2e) { illegal_2(); } /* DB ED */
-OP(ed,2f) { illegal_2(); } /* DB ED */
-
-OP(ed,30) { unsigned n = ARG(); IN( n ); } /* IN0 (n) */
-OP(ed,31) { unsigned n = ARG(); OUT( n, 0 ); } /* OUT0 (n) */
-OP(ed,32) { illegal_2(); } /* DB ED */
-OP(ed,33) { illegal_2(); } /* DB ED */
-OP(ed,34) { TST( RM(_HL) ); } /* TST (HL) */
-OP(ed,35) { illegal_2(); } /* DB ED */
-OP(ed,36) { illegal_2(); } /* DB ED */
-OP(ed,37) { illegal_2(); } /* DB ED */
-
-OP(ed,38) { unsigned n = ARG(); _A = IN( n ); } /* IN0 A,(n) */
-OP(ed,39) { unsigned n = ARG(); OUT( n, _A ); } /* OUT0 (n),A */
-OP(ed,3a) { illegal_2(); } /* DB ED */
-OP(ed,3b) { illegal_2(); } /* DB ED */
+OP(ed,2d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,2e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,2f) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,30) { unsigned n = z180_device_ARG(); z180_device_IN( n ); } /* IN0 (n) */
+OP(ed,31) { unsigned n = z180_device_ARG(); z180_device_OUT( n, 0 ); } /* OUT0 (n) */
+OP(ed,32) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,33) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,34) { TST( z180_device_RM(_HL) ); } /* TST (HL) */
+OP(ed,35) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,36) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,37) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,38) { unsigned n = z180_device_ARG(); _A = z180_device_IN( n ); } /* IN0 A,(n) */
+OP(ed,39) { unsigned n = z180_device_ARG(); z180_device_OUT( n, _A ); } /* OUT0 (n),A */
+OP(ed,3a) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,3b) { z180_device_illegal_2(); } /* DB ED */
OP(ed,3c) { TST( _A ); } /* TST A */
-OP(ed,3d) { illegal_2(); } /* DB ED */
-OP(ed,3e) { illegal_2(); } /* DB ED */
-OP(ed,3f) { illegal_2(); } /* DB ED */
+OP(ed,3d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,3e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,3f) { z180_device_illegal_2(); } /* DB ED */
-OP(ed,40) { _B = IN(_BC); _F = (_F & CF) | SZP[_B]; } /* IN B,(C) */
-OP(ed,41) { OUT(_BC,_B); } /* OUT (C),B */
+OP(ed,40) { _B = z180_device_IN(_BC); _F = (_F & CF) | SZP[_B]; } /* IN B,(C) */
+OP(ed,41) { z180_device_OUT(_BC,_B); } /* OUT (C),B */
OP(ed,42) { SBC16( BC ); } /* SBC HL,BC */
-OP(ed,43) { m_ea = ARG16(); WM16( m_ea, &m_BC ); } /* LD (w),BC */
+OP(ed,43) { m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_BC ); } /* LD (w),BC */
OP(ed,44) { NEG; } /* NEG */
OP(ed,45) { RETN; } /* RETN; */
OP(ed,46) { m_IM = 0; } /* IM 0 */
OP(ed,47) { LD_I_A; } /* LD I,A */
-OP(ed,48) { _C = IN(_BC); _F = (_F & CF) | SZP[_C]; } /* IN C,(C) */
-OP(ed,49) { OUT(_BC,_C); } /* OUT (C),C */
+OP(ed,48) { _C = z180_device_IN(_BC); _F = (_F & CF) | SZP[_C]; } /* IN C,(C) */
+OP(ed,49) { z180_device_OUT(_BC,_C); } /* OUT (C),C */
OP(ed,4a) { ADC16( BC ); } /* ADC HL,BC */
-OP(ed,4b) { m_ea = ARG16(); RM16( m_ea, &m_BC ); } /* LD BC,(w) */
+OP(ed,4b) { m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_BC ); } /* LD BC,(w) */
OP(ed,4c) { MLT( BC ); } /* MLT BC */
OP(ed,4d) { RETI; } /* RETI */
OP(ed,4e) { m_IM = 0; } /* IM 0 */
OP(ed,4f) { LD_R_A; } /* LD R,A */
-OP(ed,50) { _D = IN(_BC); _F = (_F & CF) | SZP[_D]; } /* IN D,(C) */
-OP(ed,51) { OUT(_BC,_D); } /* OUT (C),D */
+OP(ed,50) { _D = z180_device_IN(_BC); _F = (_F & CF) | SZP[_D]; } /* IN D,(C) */
+OP(ed,51) { z180_device_OUT(_BC,_D); } /* OUT (C),D */
OP(ed,52) { SBC16( DE ); } /* SBC HL,DE */
-OP(ed,53) { m_ea = ARG16(); WM16( m_ea, &m_DE ); } /* LD (w),DE */
+OP(ed,53) { m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_DE ); } /* LD (w),DE */
OP(ed,54) { NEG; } /* NEG */
OP(ed,55) { RETN; } /* RETN; */
OP(ed,56) { m_IM = 1; } /* IM 1 */
OP(ed,57) { LD_A_I; } /* LD A,I */
-OP(ed,58) { _E = IN(_BC); _F = (_F & CF) | SZP[_E]; } /* IN E,(C) */
-OP(ed,59) { OUT(_BC,_E); } /* OUT (C),E */
+OP(ed,58) { _E = z180_device_IN(_BC); _F = (_F & CF) | SZP[_E]; } /* IN E,(C) */
+OP(ed,59) { z180_device_OUT(_BC,_E); } /* OUT (C),E */
OP(ed,5a) { ADC16( DE ); } /* ADC HL,DE */
-OP(ed,5b) { m_ea = ARG16(); RM16( m_ea, &m_DE ); } /* LD DE,(w) */
+OP(ed,5b) { m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_DE ); } /* LD DE,(w) */
OP(ed,5c) { MLT( DE ); } /* MLT DE */
OP(ed,5d) { RETI; } /* RETI */
OP(ed,5e) { m_IM = 2; } /* IM 2 */
OP(ed,5f) { LD_A_R; } /* LD A,R */
-OP(ed,60) { _H = IN(_BC); _F = (_F & CF) | SZP[_H]; } /* IN H,(C) */
-OP(ed,61) { OUT(_BC,_H); } /* OUT (C),H */
+OP(ed,60) { _H = z180_device_IN(_BC); _F = (_F & CF) | SZP[_H]; } /* IN H,(C) */
+OP(ed,61) { z180_device_OUT(_BC,_H); } /* OUT (C),H */
OP(ed,62) { SBC16( HL ); } /* SBC HL,HL */
-OP(ed,63) { m_ea = ARG16(); WM16( m_ea, &m_HL ); } /* LD (w),HL */
-OP(ed,64) { unsigned m = ARG(); TST( m ); } /* TST m */
+OP(ed,63) { m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_HL ); } /* LD (w),HL */
+OP(ed,64) { unsigned m = z180_device_ARG(); TST( m ); } /* TST m */
OP(ed,65) { RETN; } /* RETN; */
OP(ed,66) { m_IM = 0; } /* IM 0 */
OP(ed,67) { RRD; } /* RRD (HL) */
-OP(ed,68) { _L = IN(_BC); _F = (_F & CF) | SZP[_L]; } /* IN L,(C) */
-OP(ed,69) { OUT(_BC,_L); } /* OUT (C),L */
+OP(ed,68) { _L = z180_device_IN(_BC); _F = (_F & CF) | SZP[_L]; } /* IN L,(C) */
+OP(ed,69) { z180_device_OUT(_BC,_L); } /* OUT (C),L */
OP(ed,6a) { ADC16( HL ); } /* ADC HL,HL */
-OP(ed,6b) { m_ea = ARG16(); RM16( m_ea, &m_HL ); } /* LD HL,(w) */
+OP(ed,6b) { m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_HL ); } /* LD HL,(w) */
OP(ed,6c) { MLT( HL ); } /* MLT HL */
OP(ed,6d) { RETI; } /* RETI */
OP(ed,6e) { m_IM = 0; } /* IM 0 */
OP(ed,6f) { RLD; } /* RLD (HL) */
-OP(ed,70) { uint8_t res = IN(_BC); _F = (_F & CF) | SZP[res]; } /* IN 0,(C) */
-OP(ed,71) { OUT(_BC,0); } /* OUT (C),0 */
+OP(ed,70) { uint8_t res = z180_device_IN(_BC); _F = (_F & CF) | SZP[res]; } /* IN 0,(C) */
+OP(ed,71) { z180_device_OUT(_BC,0); } /* OUT (C),0 */
OP(ed,72) { SBC16( SP ); } /* SBC HL,SP */
-OP(ed,73) { m_ea = ARG16(); WM16( m_ea, &m_SP ); } /* LD (w),SP */
-OP(ed,74) { unsigned m = ARG(); _F = (_F & CF) | SZP[IN(_C) & m]; } /* TSTIO m */
+OP(ed,73) { m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_SP ); } /* LD (w),SP */
+OP(ed,74) { unsigned m = z180_device_ARG(); _F = (_F & CF) | SZP[z180_device_IN(_C) & m]; } /* TSTIO m */
OP(ed,75) { RETN; } /* RETN; */
OP(ed,76) { SLP; } /* SLP */
-OP(ed,77) { illegal_2(); } /* DB ED,77 */
+OP(ed,77) { z180_device_illegal_2(); } /* DB ED,77 */
-OP(ed,78) { _A = IN(_BC); _F = (_F & CF) | SZP[_A]; } /* IN E,(C) */
-OP(ed,79) { OUT(_BC,_A); } /* OUT (C),E */
+OP(ed,78) { _A = z180_device_IN(_BC); _F = (_F & CF) | SZP[_A]; } /* IN E,(C) */
+OP(ed,79) { z180_device_OUT(_BC,_A); } /* OUT (C),E */
OP(ed,7a) { ADC16( SP ); } /* ADC HL,SP */
-OP(ed,7b) { m_ea = ARG16(); RM16( m_ea, &m_SP ); } /* LD SP,(w) */
+OP(ed,7b) { m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_SP ); } /* LD SP,(w) */
OP(ed,7c) { MLT( SP ); } /* MLT SP */
OP(ed,7d) { RETI; } /* RETI */
OP(ed,7e) { m_IM = 2; } /* IM 2 */
-OP(ed,7f) { illegal_2(); } /* DB ED,7F */
+OP(ed,7f) { z180_device_illegal_2(); } /* DB ED,7F */
-OP(ed,80) { illegal_2(); } /* DB ED */
-OP(ed,81) { illegal_2(); } /* DB ED */
-OP(ed,82) { illegal_2(); } /* DB ED */
+OP(ed,80) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,81) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,82) { z180_device_illegal_2(); } /* DB ED */
OP(ed,83) { OTIM; } /* OTIM */
-OP(ed,84) { illegal_2(); } /* DB ED */
-OP(ed,85) { illegal_2(); } /* DB ED */
-OP(ed,86) { illegal_2(); } /* DB ED */
-OP(ed,87) { illegal_2(); } /* DB ED */
-
-OP(ed,88) { illegal_2(); } /* DB ED */
-OP(ed,89) { illegal_2(); } /* DB ED */
-OP(ed,8a) { illegal_2(); } /* DB ED */
+OP(ed,84) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,85) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,86) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,87) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,88) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,89) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,8a) { z180_device_illegal_2(); } /* DB ED */
OP(ed,8b) { OTDM; } /* OTDM */
-OP(ed,8c) { illegal_2(); } /* DB ED */
-OP(ed,8d) { illegal_2(); } /* DB ED */
-OP(ed,8e) { illegal_2(); } /* DB ED */
-OP(ed,8f) { illegal_2(); } /* DB ED */
-
-OP(ed,90) { illegal_2(); } /* DB ED */
-OP(ed,91) { illegal_2(); } /* DB ED */
-OP(ed,92) { illegal_2(); } /* DB ED */
+OP(ed,8c) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,8d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,8e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,8f) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,90) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,91) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,92) { z180_device_illegal_2(); } /* DB ED */
OP(ed,93) { OTIMR; } /* OTIMR */
-OP(ed,94) { illegal_2(); } /* DB ED */
-OP(ed,95) { illegal_2(); } /* DB ED */
-OP(ed,96) { illegal_2(); } /* DB ED */
-OP(ed,97) { illegal_2(); } /* DB ED */
-
-OP(ed,98) { illegal_2(); } /* DB ED */
-OP(ed,99) { illegal_2(); } /* DB ED */
-OP(ed,9a) { illegal_2(); } /* DB ED */
+OP(ed,94) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,95) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,96) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,97) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,98) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,99) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,9a) { z180_device_illegal_2(); } /* DB ED */
OP(ed,9b) { OTDMR; } /* OTDMR */
-OP(ed,9c) { illegal_2(); } /* DB ED */
-OP(ed,9d) { illegal_2(); } /* DB ED */
-OP(ed,9e) { illegal_2(); } /* DB ED */
-OP(ed,9f) { illegal_2(); } /* DB ED */
+OP(ed,9c) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,9d) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,9e) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,9f) { z180_device_illegal_2(); } /* DB ED */
OP(ed,a0) { LDI; } /* LDI */
OP(ed,a1) { CPI; } /* CPI */
OP(ed,a2) { INI; } /* INI */
OP(ed,a3) { OUTI; } /* OUTI */
-OP(ed,a4) { illegal_2(); } /* DB ED */
-OP(ed,a5) { illegal_2(); } /* DB ED */
-OP(ed,a6) { illegal_2(); } /* DB ED */
-OP(ed,a7) { illegal_2(); } /* DB ED */
+OP(ed,a4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,a5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,a6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,a7) { z180_device_illegal_2(); } /* DB ED */
OP(ed,a8) { LDD; } /* LDD */
OP(ed,a9) { CPD; } /* CPD */
OP(ed,aa) { IND; } /* IND */
OP(ed,ab) { OUTD; } /* OUTD */
-OP(ed,ac) { illegal_2(); } /* DB ED */
-OP(ed,ad) { illegal_2(); } /* DB ED */
-OP(ed,ae) { illegal_2(); } /* DB ED */
-OP(ed,af) { illegal_2(); } /* DB ED */
+OP(ed,ac) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ad) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ae) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,af) { z180_device_illegal_2(); } /* DB ED */
OP(ed,b0) { LDIR; } /* LDIR */
OP(ed,b1) { CPIR; } /* CPIR */
OP(ed,b2) { INIR; } /* INIR */
OP(ed,b3) { OTIR; } /* OTIR */
-OP(ed,b4) { illegal_2(); } /* DB ED */
-OP(ed,b5) { illegal_2(); } /* DB ED */
-OP(ed,b6) { illegal_2(); } /* DB ED */
-OP(ed,b7) { illegal_2(); } /* DB ED */
+OP(ed,b4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,b5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,b6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,b7) { z180_device_illegal_2(); } /* DB ED */
OP(ed,b8) { LDDR; } /* LDDR */
OP(ed,b9) { CPDR; } /* CPDR */
OP(ed,ba) { INDR; } /* INDR */
OP(ed,bb) { OTDR; } /* OTDR */
-OP(ed,bc) { illegal_2(); } /* DB ED */
-OP(ed,bd) { illegal_2(); } /* DB ED */
-OP(ed,be) { illegal_2(); } /* DB ED */
-OP(ed,bf) { illegal_2(); } /* DB ED */
-
-OP(ed,c0) { illegal_2(); } /* DB ED */
-OP(ed,c1) { illegal_2(); } /* DB ED */
-OP(ed,c2) { illegal_2(); } /* DB ED */
-OP(ed,c3) { illegal_2(); } /* DB ED */
-OP(ed,c4) { illegal_2(); } /* DB ED */
-OP(ed,c5) { illegal_2(); } /* DB ED */
-OP(ed,c6) { illegal_2(); } /* DB ED */
-OP(ed,c7) { illegal_2(); } /* DB ED */
-
-OP(ed,c8) { illegal_2(); } /* DB ED */
-OP(ed,c9) { illegal_2(); } /* DB ED */
-OP(ed,ca) { illegal_2(); } /* DB ED */
-OP(ed,cb) { illegal_2(); } /* DB ED */
-OP(ed,cc) { illegal_2(); } /* DB ED */
-OP(ed,cd) { illegal_2(); } /* DB ED */
-OP(ed,ce) { illegal_2(); } /* DB ED */
-OP(ed,cf) { illegal_2(); } /* DB ED */
-
-OP(ed,d0) { illegal_2(); } /* DB ED */
-OP(ed,d1) { illegal_2(); } /* DB ED */
-OP(ed,d2) { illegal_2(); } /* DB ED */
-OP(ed,d3) { illegal_2(); } /* DB ED */
-OP(ed,d4) { illegal_2(); } /* DB ED */
-OP(ed,d5) { illegal_2(); } /* DB ED */
-OP(ed,d6) { illegal_2(); } /* DB ED */
-OP(ed,d7) { illegal_2(); } /* DB ED */
-
-OP(ed,d8) { illegal_2(); } /* DB ED */
-OP(ed,d9) { illegal_2(); } /* DB ED */
-OP(ed,da) { illegal_2(); } /* DB ED */
-OP(ed,db) { illegal_2(); } /* DB ED */
-OP(ed,dc) { illegal_2(); } /* DB ED */
-OP(ed,dd) { illegal_2(); } /* DB ED */
-OP(ed,de) { illegal_2(); } /* DB ED */
-OP(ed,df) { illegal_2(); } /* DB ED */
-
-OP(ed,e0) { illegal_2(); } /* DB ED */
-OP(ed,e1) { illegal_2(); } /* DB ED */
-OP(ed,e2) { illegal_2(); } /* DB ED */
-OP(ed,e3) { illegal_2(); } /* DB ED */
-OP(ed,e4) { illegal_2(); } /* DB ED */
-OP(ed,e5) { illegal_2(); } /* DB ED */
-OP(ed,e6) { illegal_2(); } /* DB ED */
-OP(ed,e7) { illegal_2(); } /* DB ED */
-
-OP(ed,e8) { illegal_2(); } /* DB ED */
-OP(ed,e9) { illegal_2(); } /* DB ED */
-OP(ed,ea) { illegal_2(); } /* DB ED */
-OP(ed,eb) { illegal_2(); } /* DB ED */
-OP(ed,ec) { illegal_2(); } /* DB ED */
-OP(ed,ed) { illegal_2(); } /* DB ED */
-OP(ed,ee) { illegal_2(); } /* DB ED */
-OP(ed,ef) { illegal_2(); } /* DB ED */
-
-OP(ed,f0) { illegal_2(); } /* DB ED */
-OP(ed,f1) { illegal_2(); } /* DB ED */
-OP(ed,f2) { illegal_2(); } /* DB ED */
-OP(ed,f3) { illegal_2(); } /* DB ED */
-OP(ed,f4) { illegal_2(); } /* DB ED */
-OP(ed,f5) { illegal_2(); } /* DB ED */
-OP(ed,f6) { illegal_2(); } /* DB ED */
-OP(ed,f7) { illegal_2(); } /* DB ED */
-
-OP(ed,f8) { illegal_2(); } /* DB ED */
-OP(ed,f9) { illegal_2(); } /* DB ED */
-OP(ed,fa) { illegal_2(); } /* DB ED */
-OP(ed,fb) { illegal_2(); } /* DB ED */
-OP(ed,fc) { illegal_2(); } /* DB ED */
-OP(ed,fd) { illegal_2(); } /* DB ED */
-OP(ed,fe) { illegal_2(); } /* DB ED */
-OP(ed,ff) { illegal_2(); } /* DB ED */
+OP(ed,bc) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,bd) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,be) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,bf) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,c0) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c1) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c2) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c3) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c7) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,c8) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,c9) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ca) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,cb) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,cc) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,cd) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ce) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,cf) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,d0) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d1) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d2) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d3) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d7) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,d8) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,d9) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,da) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,db) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,dc) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,dd) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,de) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,df) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,e0) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e1) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e2) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e3) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e7) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,e8) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,e9) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ea) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,eb) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ec) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ed) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ee) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ef) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,f0) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f1) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f2) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f3) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f4) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f5) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f6) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f7) { z180_device_illegal_2(); } /* DB ED */
+
+OP(ed,f8) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,f9) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,fa) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,fb) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,fc) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,fd) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,fe) { z180_device_illegal_2(); } /* DB ED */
+OP(ed,ff) { z180_device_illegal_2(); } /* DB ED */
/**********************************************************
* IY register related opcodes (FD prefix)
**********************************************************/
-OP(fd,00) { illegal_1(); op_00(); } /* DB FD */
-OP(fd,01) { illegal_1(); op_01(); } /* DB FD */
-OP(fd,02) { illegal_1(); op_02(); } /* DB FD */
-OP(fd,03) { illegal_1(); op_03(); } /* DB FD */
-OP(fd,04) { illegal_1(); op_04(); } /* DB FD */
-OP(fd,05) { illegal_1(); op_05(); } /* DB FD */
-OP(fd,06) { illegal_1(); op_06(); } /* DB FD */
-OP(fd,07) { illegal_1(); op_07(); } /* DB FD */
+OP(fd,00) { z180_device_illegal_1(); z180_device_op_00(); } /* DB FD */
+OP(fd,01) { z180_device_illegal_1(); z180_device_op_01(); } /* DB FD */
+OP(fd,02) { z180_device_illegal_1(); z180_device_op_02(); } /* DB FD */
+OP(fd,03) { z180_device_illegal_1(); z180_device_op_03(); } /* DB FD */
+OP(fd,04) { z180_device_illegal_1(); z180_device_op_04(); } /* DB FD */
+OP(fd,05) { z180_device_illegal_1(); z180_device_op_05(); } /* DB FD */
+OP(fd,06) { z180_device_illegal_1(); z180_device_op_06(); } /* DB FD */
+OP(fd,07) { z180_device_illegal_1(); z180_device_op_07(); } /* DB FD */
-OP(fd,08) { illegal_1(); op_08(); } /* DB FD */
+OP(fd,08) { z180_device_illegal_1(); z180_device_op_08(); } /* DB FD */
OP(fd,09) { m_R++; ADD16(IY,BC); } /* ADD IY,BC */
-OP(fd,0a) { illegal_1(); op_0a(); } /* DB FD */
-OP(fd,0b) { illegal_1(); op_0b(); } /* DB FD */
-OP(fd,0c) { illegal_1(); op_0c(); } /* DB FD */
-OP(fd,0d) { illegal_1(); op_0d(); } /* DB FD */
-OP(fd,0e) { illegal_1(); op_0e(); } /* DB FD */
-OP(fd,0f) { illegal_1(); op_0f(); } /* DB FD */
+OP(fd,0a) { z180_device_illegal_1(); z180_device_op_0a(); } /* DB FD */
+OP(fd,0b) { z180_device_illegal_1(); z180_device_op_0b(); } /* DB FD */
+OP(fd,0c) { z180_device_illegal_1(); z180_device_op_0c(); } /* DB FD */
+OP(fd,0d) { z180_device_illegal_1(); z180_device_op_0d(); } /* DB FD */
+OP(fd,0e) { z180_device_illegal_1(); z180_device_op_0e(); } /* DB FD */
+OP(fd,0f) { z180_device_illegal_1(); z180_device_op_0f(); } /* DB FD */
-OP(fd,10) { illegal_1(); op_10(); } /* DB FD */
-OP(fd,11) { illegal_1(); op_11(); } /* DB FD */
-OP(fd,12) { illegal_1(); op_12(); } /* DB FD */
-OP(fd,13) { illegal_1(); op_13(); } /* DB FD */
-OP(fd,14) { illegal_1(); op_14(); } /* DB FD */
-OP(fd,15) { illegal_1(); op_15(); } /* DB FD */
-OP(fd,16) { illegal_1(); op_16(); } /* DB FD */
-OP(fd,17) { illegal_1(); op_17(); } /* DB FD */
+OP(fd,10) { z180_device_illegal_1(); z180_device_op_10(); } /* DB FD */
+OP(fd,11) { z180_device_illegal_1(); z180_device_op_11(); } /* DB FD */
+OP(fd,12) { z180_device_illegal_1(); z180_device_op_12(); } /* DB FD */
+OP(fd,13) { z180_device_illegal_1(); z180_device_op_13(); } /* DB FD */
+OP(fd,14) { z180_device_illegal_1(); z180_device_op_14(); } /* DB FD */
+OP(fd,15) { z180_device_illegal_1(); z180_device_op_15(); } /* DB FD */
+OP(fd,16) { z180_device_illegal_1(); z180_device_op_16(); } /* DB FD */
+OP(fd,17) { z180_device_illegal_1(); z180_device_op_17(); } /* DB FD */
-OP(fd,18) { illegal_1(); op_18(); } /* DB FD */
+OP(fd,18) { z180_device_illegal_1(); z180_device_op_18(); } /* DB FD */
OP(fd,19) { m_R++; ADD16(IY,DE); } /* ADD IY,DE */
-OP(fd,1a) { illegal_1(); op_1a(); } /* DB FD */
-OP(fd,1b) { illegal_1(); op_1b(); } /* DB FD */
-OP(fd,1c) { illegal_1(); op_1c(); } /* DB FD */
-OP(fd,1d) { illegal_1(); op_1d(); } /* DB FD */
-OP(fd,1e) { illegal_1(); op_1e(); } /* DB FD */
-OP(fd,1f) { illegal_1(); op_1f(); } /* DB FD */
+OP(fd,1a) { z180_device_illegal_1(); z180_device_op_1a(); } /* DB FD */
+OP(fd,1b) { z180_device_illegal_1(); z180_device_op_1b(); } /* DB FD */
+OP(fd,1c) { z180_device_illegal_1(); z180_device_op_1c(); } /* DB FD */
+OP(fd,1d) { z180_device_illegal_1(); z180_device_op_1d(); } /* DB FD */
+OP(fd,1e) { z180_device_illegal_1(); z180_device_op_1e(); } /* DB FD */
+OP(fd,1f) { z180_device_illegal_1(); z180_device_op_1f(); } /* DB FD */
-OP(fd,20) { illegal_1(); op_20(); } /* DB FD */
-OP(fd,21) { m_R++; _IY = ARG16(); } /* LD IY,w */
-OP(fd,22) { m_R++; m_ea = ARG16(); WM16( m_ea, &m_IY ); } /* LD (w),IY */
+OP(fd,20) { z180_device_illegal_1(); z180_device_op_20(); } /* DB FD */
+OP(fd,21) { m_R++; _IY = z180_device_ARG16(); } /* LD IY,w */
+OP(fd,22) { m_R++; m_ea = z180_device_ARG16(); z180_device_WM16( m_ea, &m_IY ); } /* LD (w),IY */
OP(fd,23) { m_R++; _IY++; } /* INC IY */
-OP(fd,24) { m_R++; _HY = INC(_HY); } /* INC HY */
-OP(fd,25) { m_R++; _HY = DEC(_HY); } /* DEC HY */
-OP(fd,26) { m_R++; _HY = ARG(); } /* LD HY,n */
-OP(fd,27) { illegal_1(); op_27(); } /* DB FD */
+OP(fd,24) { m_R++; _HY = z180_device_INC(_HY); } /* INC HY */
+OP(fd,25) { m_R++; _HY = z180_device_DEC(_HY); } /* DEC HY */
+OP(fd,26) { m_R++; _HY = z180_device_ARG(); } /* LD HY,n */
+OP(fd,27) { z180_device_illegal_1(); z180_device_op_27(); } /* DB FD */
-OP(fd,28) { illegal_1(); op_28(); } /* DB FD */
+OP(fd,28) { z180_device_illegal_1(); z180_device_op_28(); } /* DB FD */
OP(fd,29) { m_R++; ADD16(IY,IY); } /* ADD IY,IY */
-OP(fd,2a) { m_R++; m_ea = ARG16(); RM16( m_ea, &m_IY ); } /* LD IY,(w) */
+OP(fd,2a) { m_R++; m_ea = z180_device_ARG16(); z180_device_RM16( m_ea, &m_IY ); } /* LD IY,(w) */
OP(fd,2b) { m_R++; _IY--; } /* DEC IY */
-OP(fd,2c) { m_R++; _LY = INC(_LY); } /* INC LY */
-OP(fd,2d) { m_R++; _LY = DEC(_LY); } /* DEC LY */
-OP(fd,2e) { m_R++; _LY = ARG(); } /* LD LY,n */
-OP(fd,2f) { illegal_1(); op_2f(); } /* DB FD */
+OP(fd,2c) { m_R++; _LY = z180_device_INC(_LY); } /* INC LY */
+OP(fd,2d) { m_R++; _LY = z180_device_DEC(_LY); } /* DEC LY */
+OP(fd,2e) { m_R++; _LY = z180_device_ARG(); } /* LD LY,n */
+OP(fd,2f) { z180_device_illegal_1(); z180_device_op_2f(); } /* DB FD */
-OP(fd,30) { illegal_1(); op_30(); } /* DB FD */
-OP(fd,31) { illegal_1(); op_31(); } /* DB FD */
-OP(fd,32) { illegal_1(); op_32(); } /* DB FD */
-OP(fd,33) { illegal_1(); op_33(); } /* DB FD */
-OP(fd,34) { m_R++; EAY(); WM( m_ea, INC(RM(m_ea)) ); } /* INC (IY+o) */
-OP(fd,35) { m_R++; EAY(); WM( m_ea, DEC(RM(m_ea)) ); } /* DEC (IY+o) */
-OP(fd,36) { m_R++; EAY(); WM( m_ea, ARG() ); } /* LD (IY+o),n */
-OP(fd,37) { illegal_1(); op_37(); } /* DB FD */
+OP(fd,30) { z180_device_illegal_1(); z180_device_op_30(); } /* DB FD */
+OP(fd,31) { z180_device_illegal_1(); z180_device_op_31(); } /* DB FD */
+OP(fd,32) { z180_device_illegal_1(); z180_device_op_32(); } /* DB FD */
+OP(fd,33) { z180_device_illegal_1(); z180_device_op_33(); } /* DB FD */
+OP(fd,34) { m_R++; EAY(); WM( m_ea, z180_device_INC(z180_device_RM(m_ea)) ); } /* INC (IY+o) */
+OP(fd,35) { m_R++; EAY(); WM( m_ea, z180_device_DEC(z180_device_RM(m_ea)) ); } /* DEC (IY+o) */
+OP(fd,36) { m_R++; EAY(); WM( m_ea, z180_device_ARG() ); } /* LD (IY+o),n */
+OP(fd,37) { z180_device_illegal_1(); z180_device_op_37(); } /* DB FD */
-OP(fd,38) { illegal_1(); op_38(); } /* DB FD */
+OP(fd,38) { z180_device_illegal_1(); z180_device_op_38(); } /* DB FD */
OP(fd,39) { m_R++; ADD16(IY,SP); } /* ADD IY,SP */
-OP(fd,3a) { illegal_1(); op_3a(); } /* DB FD */
-OP(fd,3b) { illegal_1(); op_3b(); } /* DB FD */
-OP(fd,3c) { illegal_1(); op_3c(); } /* DB FD */
-OP(fd,3d) { illegal_1(); op_3d(); } /* DB FD */
-OP(fd,3e) { illegal_1(); op_3e(); } /* DB FD */
-OP(fd,3f) { illegal_1(); op_3f(); } /* DB FD */
+OP(fd,3a) { z180_device_illegal_1(); z180_device_op_3a(); } /* DB FD */
+OP(fd,3b) { z180_device_illegal_1(); z180_device_op_3b(); } /* DB FD */
+OP(fd,3c) { z180_device_illegal_1(); z180_device_op_3c(); } /* DB FD */
+OP(fd,3d) { z180_device_illegal_1(); z180_device_op_3d(); } /* DB FD */
+OP(fd,3e) { z180_device_illegal_1(); z180_device_op_3e(); } /* DB FD */
+OP(fd,3f) { z180_device_illegal_1(); z180_device_op_3f(); } /* DB FD */
-OP(fd,40) { illegal_1(); op_40(); } /* DB FD */
-OP(fd,41) { illegal_1(); op_41(); } /* DB FD */
-OP(fd,42) { illegal_1(); op_42(); } /* DB FD */
-OP(fd,43) { illegal_1(); op_43(); } /* DB FD */
+OP(fd,40) { z180_device_illegal_1(); z180_device_op_40(); } /* DB FD */
+OP(fd,41) { z180_device_illegal_1(); z180_device_op_41(); } /* DB FD */
+OP(fd,42) { z180_device_illegal_1(); z180_device_op_42(); } /* DB FD */
+OP(fd,43) { z180_device_illegal_1(); z180_device_op_43(); } /* DB FD */
OP(fd,44) { m_R++; _B = _HY; } /* LD B,HY */
OP(fd,45) { m_R++; _B = _LY; } /* LD B,LY */
-OP(fd,46) { m_R++; EAY(); _B = RM(m_ea); } /* LD B,(IY+o) */
-OP(fd,47) { illegal_1(); op_47(); } /* DB FD */
+OP(fd,46) { m_R++; EAY(); _B = z180_device_RM(m_ea); } /* LD B,(IY+o) */
+OP(fd,47) { z180_device_illegal_1(); z180_device_op_47(); } /* DB FD */
-OP(fd,48) { illegal_1(); op_48(); } /* DB FD */
-OP(fd,49) { illegal_1(); op_49(); } /* DB FD */
-OP(fd,4a) { illegal_1(); op_4a(); } /* DB FD */
-OP(fd,4b) { illegal_1(); op_4b(); } /* DB FD */
+OP(fd,48) { z180_device_illegal_1(); z180_device_op_48(); } /* DB FD */
+OP(fd,49) { z180_device_illegal_1(); z180_device_op_49(); } /* DB FD */
+OP(fd,4a) { z180_device_illegal_1(); z180_device_op_4a(); } /* DB FD */
+OP(fd,4b) { z180_device_illegal_1(); z180_device_op_4b(); } /* DB FD */
OP(fd,4c) { m_R++; _C = _HY; } /* LD C,HY */
OP(fd,4d) { m_R++; _C = _LY; } /* LD C,LY */
-OP(fd,4e) { m_R++; EAY(); _C = RM(m_ea); } /* LD C,(IY+o) */
-OP(fd,4f) { illegal_1(); op_4f(); } /* DB FD */
+OP(fd,4e) { m_R++; EAY(); _C = z180_device_RM(m_ea); } /* LD C,(IY+o) */
+OP(fd,4f) { z180_device_illegal_1(); z180_device_op_4f(); } /* DB FD */
-OP(fd,50) { illegal_1(); op_50(); } /* DB FD */
-OP(fd,51) { illegal_1(); op_51(); } /* DB FD */
-OP(fd,52) { illegal_1(); op_52(); } /* DB FD */
-OP(fd,53) { illegal_1(); op_53(); } /* DB FD */
+OP(fd,50) { z180_device_illegal_1(); z180_device_op_50(); } /* DB FD */
+OP(fd,51) { z180_device_illegal_1(); z180_device_op_51(); } /* DB FD */
+OP(fd,52) { z180_device_illegal_1(); z180_device_op_52(); } /* DB FD */
+OP(fd,53) { z180_device_illegal_1(); z180_device_op_53(); } /* DB FD */
OP(fd,54) { m_R++; _D = _HY; } /* LD D,HY */
OP(fd,55) { m_R++; _D = _LY; } /* LD D,LY */
-OP(fd,56) { m_R++; EAY(); _D = RM(m_ea); } /* LD D,(IY+o) */
-OP(fd,57) { illegal_1(); op_57(); } /* DB FD */
+OP(fd,56) { m_R++; EAY(); _D = z180_device_RM(m_ea); } /* LD D,(IY+o) */
+OP(fd,57) { z180_device_illegal_1(); z180_device_op_57(); } /* DB FD */
-OP(fd,58) { illegal_1(); op_58(); } /* DB FD */
-OP(fd,59) { illegal_1(); op_59(); } /* DB FD */
-OP(fd,5a) { illegal_1(); op_5a(); } /* DB FD */
-OP(fd,5b) { illegal_1(); op_5b(); } /* DB FD */
+OP(fd,58) { z180_device_illegal_1(); z180_device_op_58(); } /* DB FD */
+OP(fd,59) { z180_device_illegal_1(); z180_device_op_59(); } /* DB FD */
+OP(fd,5a) { z180_device_illegal_1(); z180_device_op_5a(); } /* DB FD */
+OP(fd,5b) { z180_device_illegal_1(); z180_device_op_5b(); } /* DB FD */
OP(fd,5c) { m_R++; _E = _HY; } /* LD E,HY */
OP(fd,5d) { m_R++; _E = _LY; } /* LD E,LY */
-OP(fd,5e) { m_R++; EAY(); _E = RM(m_ea); } /* LD E,(IY+o) */
-OP(fd,5f) { illegal_1(); op_5f(); } /* DB FD */
+OP(fd,5e) { m_R++; EAY(); _E = z180_device_RM(m_ea); } /* LD E,(IY+o) */
+OP(fd,5f) { z180_device_illegal_1(); z180_device_op_5f(); } /* DB FD */
OP(fd,60) { m_R++; _HY = _B; } /* LD HY,B */
OP(fd,61) { m_R++; _HY = _C; } /* LD HY,C */
OP(fd,63) { m_R++; _HY = _E; } /* LD HY,E */
OP(fd,64) { m_R++; } /* LD HY,HY */
OP(fd,65) { m_R++; _HY = _LY; } /* LD HY,LY */
-OP(fd,66) { m_R++; EAY(); _H = RM(m_ea); } /* LD H,(IY+o) */
+OP(fd,66) { m_R++; EAY(); _H = z180_device_RM(m_ea); } /* LD H,(IY+o) */
OP(fd,67) { m_R++; _HY = _A; } /* LD HY,A */
OP(fd,68) { m_R++; _LY = _B; } /* LD LY,B */
OP(fd,6b) { m_R++; _LY = _E; } /* LD LY,E */
OP(fd,6c) { m_R++; _LY = _HY; } /* LD LY,HY */
OP(fd,6d) { m_R++; } /* LD LY,LY */
-OP(fd,6e) { m_R++; EAY(); _L = RM(m_ea); } /* LD L,(IY+o) */
+OP(fd,6e) { m_R++; EAY(); _L = z180_device_RM(m_ea); } /* LD L,(IY+o) */
OP(fd,6f) { m_R++; _LY = _A; } /* LD LY,A */
OP(fd,70) { m_R++; EAY(); WM( m_ea, _B ); } /* LD (IY+o),B */
OP(fd,73) { m_R++; EAY(); WM( m_ea, _E ); } /* LD (IY+o),E */
OP(fd,74) { m_R++; EAY(); WM( m_ea, _H ); } /* LD (IY+o),H */
OP(fd,75) { m_R++; EAY(); WM( m_ea, _L ); } /* LD (IY+o),L */
-OP(fd,76) { illegal_1(); op_76(); } /* DB FD */
+OP(fd,76) { z180_device_illegal_1(); z180_device_op_76(); } /* DB FD */
OP(fd,77) { m_R++; EAY(); WM( m_ea, _A ); } /* LD (IY+o),A */
-OP(fd,78) { illegal_1(); op_78(); } /* DB FD */
-OP(fd,79) { illegal_1(); op_79(); } /* DB FD */
-OP(fd,7a) { illegal_1(); op_7a(); } /* DB FD */
-OP(fd,7b) { illegal_1(); op_7b(); } /* DB FD */
+OP(fd,78) { z180_device_illegal_1(); z180_device_op_78(); } /* DB FD */
+OP(fd,79) { z180_device_illegal_1(); z180_device_op_79(); } /* DB FD */
+OP(fd,7a) { z180_device_illegal_1(); z180_device_op_7a(); } /* DB FD */
+OP(fd,7b) { z180_device_illegal_1(); z180_device_op_7b(); } /* DB FD */
OP(fd,7c) { m_R++; _A = _HY; } /* LD A,HY */
OP(fd,7d) { m_R++; _A = _LY; } /* LD A,LY */
-OP(fd,7e) { m_R++; EAY(); _A = RM(m_ea); } /* LD A,(IY+o) */
-OP(fd,7f) { illegal_1(); op_7f(); } /* DB FD */
+OP(fd,7e) { m_R++; EAY(); _A = z180_device_RM(m_ea); } /* LD A,(IY+o) */
+OP(fd,7f) { z180_device_illegal_1(); z180_device_op_7f(); } /* DB FD */
-OP(fd,80) { illegal_1(); op_80(); } /* DB FD */
-OP(fd,81) { illegal_1(); op_81(); } /* DB FD */
-OP(fd,82) { illegal_1(); op_82(); } /* DB FD */
-OP(fd,83) { illegal_1(); op_83(); } /* DB FD */
+OP(fd,80) { z180_device_illegal_1(); z180_device_op_80(); } /* DB FD */
+OP(fd,81) { z180_device_illegal_1(); z180_device_op_81(); } /* DB FD */
+OP(fd,82) { z180_device_illegal_1(); z180_device_op_82(); } /* DB FD */
+OP(fd,83) { z180_device_illegal_1(); z180_device_op_83(); } /* DB FD */
OP(fd,84) { m_R++; ADD(_HY); } /* ADD A,HY */
OP(fd,85) { m_R++; ADD(_LY); } /* ADD A,LY */
-OP(fd,86) { m_R++; EAY(); ADD(RM(m_ea)); } /* ADD A,(IY+o) */
-OP(fd,87) { illegal_1(); op_87(); } /* DB FD */
+OP(fd,86) { m_R++; EAY(); ADD(z180_device_RM(m_ea)); } /* ADD A,(IY+o) */
+OP(fd,87) { z180_device_illegal_1(); z180_device_op_87(); } /* DB FD */
-OP(fd,88) { illegal_1(); op_88(); } /* DB FD */
-OP(fd,89) { illegal_1(); op_89(); } /* DB FD */
-OP(fd,8a) { illegal_1(); op_8a(); } /* DB FD */
-OP(fd,8b) { illegal_1(); op_8b(); } /* DB FD */
+OP(fd,88) { z180_device_illegal_1(); z180_device_op_88(); } /* DB FD */
+OP(fd,89) { z180_device_illegal_1(); z180_device_op_89(); } /* DB FD */
+OP(fd,8a) { z180_device_illegal_1(); z180_device_op_8a(); } /* DB FD */
+OP(fd,8b) { z180_device_illegal_1(); z180_device_op_8b(); } /* DB FD */
OP(fd,8c) { m_R++; ADC(_HY); } /* ADC A,HY */
OP(fd,8d) { m_R++; ADC(_LY); } /* ADC A,LY */
-OP(fd,8e) { m_R++; EAY(); ADC(RM(m_ea)); } /* ADC A,(IY+o) */
-OP(fd,8f) { illegal_1(); op_8f(); } /* DB FD */
+OP(fd,8e) { m_R++; EAY(); ADC(z180_device_RM(m_ea)); } /* ADC A,(IY+o) */
+OP(fd,8f) { z180_device_illegal_1(); z180_device_op_8f(); } /* DB FD */
-OP(fd,90) { illegal_1(); op_90(); } /* DB FD */
-OP(fd,91) { illegal_1(); op_91(); } /* DB FD */
-OP(fd,92) { illegal_1(); op_92(); } /* DB FD */
-OP(fd,93) { illegal_1(); op_93(); } /* DB FD */
+OP(fd,90) { z180_device_illegal_1(); z180_device_op_90(); } /* DB FD */
+OP(fd,91) { z180_device_illegal_1(); z180_device_op_91(); } /* DB FD */
+OP(fd,92) { z180_device_illegal_1(); z180_device_op_92(); } /* DB FD */
+OP(fd,93) { z180_device_illegal_1(); z180_device_op_93(); } /* DB FD */
OP(fd,94) { m_R++; SUB(_HY); } /* SUB HY */
OP(fd,95) { m_R++; SUB(_LY); } /* SUB LY */
-OP(fd,96) { m_R++; EAY(); SUB(RM(m_ea)); } /* SUB (IY+o) */
-OP(fd,97) { illegal_1(); op_97(); } /* DB FD */
+OP(fd,96) { m_R++; EAY(); SUB(z180_device_RM(m_ea)); } /* SUB (IY+o) */
+OP(fd,97) { z180_device_illegal_1(); z180_device_op_97(); } /* DB FD */
-OP(fd,98) { illegal_1(); op_98(); } /* DB FD */
-OP(fd,99) { illegal_1(); op_99(); } /* DB FD */
-OP(fd,9a) { illegal_1(); op_9a(); } /* DB FD */
-OP(fd,9b) { illegal_1(); op_9b(); } /* DB FD */
+OP(fd,98) { z180_device_illegal_1(); z180_device_op_98(); } /* DB FD */
+OP(fd,99) { z180_device_illegal_1(); z180_device_op_99(); } /* DB FD */
+OP(fd,9a) { z180_device_illegal_1(); z180_device_op_9a(); } /* DB FD */
+OP(fd,9b) { z180_device_illegal_1(); z180_device_op_9b(); } /* DB FD */
OP(fd,9c) { m_R++; SBC(_HY); } /* SBC A,HY */
OP(fd,9d) { m_R++; SBC(_LY); } /* SBC A,LY */
-OP(fd,9e) { m_R++; EAY(); SBC(RM(m_ea)); } /* SBC A,(IY+o) */
-OP(fd,9f) { illegal_1(); op_9f(); } /* DB FD */
+OP(fd,9e) { m_R++; EAY(); SBC(z180_device_RM(m_ea)); } /* SBC A,(IY+o) */
+OP(fd,9f) { z180_device_illegal_1(); z180_device_op_9f(); } /* DB FD */
-OP(fd,a0) { illegal_1(); op_a0(); } /* DB FD */
-OP(fd,a1) { illegal_1(); op_a1(); } /* DB FD */
-OP(fd,a2) { illegal_1(); op_a2(); } /* DB FD */
-OP(fd,a3) { illegal_1(); op_a3(); } /* DB FD */
+OP(fd,a0) { z180_device_illegal_1(); z180_device_op_a0(); } /* DB FD */
+OP(fd,a1) { z180_device_illegal_1(); z180_device_op_a1(); } /* DB FD */
+OP(fd,a2) { z180_device_illegal_1(); z180_device_op_a2(); } /* DB FD */
+OP(fd,a3) { z180_device_illegal_1(); z180_device_op_a3(); } /* DB FD */
OP(fd,a4) { m_R++; AND(_HY); } /* AND HY */
OP(fd,a5) { m_R++; AND(_LY); } /* AND LY */
-OP(fd,a6) { m_R++; EAY(); AND(RM(m_ea)); } /* AND (IY+o) */
-OP(fd,a7) { illegal_1(); op_a7(); } /* DB FD */
+OP(fd,a6) { m_R++; EAY(); AND(z180_device_RM(m_ea)); } /* AND (IY+o) */
+OP(fd,a7) { z180_device_illegal_1(); z180_device_op_a7(); } /* DB FD */
-OP(fd,a8) { illegal_1(); op_a8(); } /* DB FD */
-OP(fd,a9) { illegal_1(); op_a9(); } /* DB FD */
-OP(fd,aa) { illegal_1(); op_aa(); } /* DB FD */
-OP(fd,ab) { illegal_1(); op_ab(); } /* DB FD */
+OP(fd,a8) { z180_device_illegal_1(); z180_device_op_a8(); } /* DB FD */
+OP(fd,a9) { z180_device_illegal_1(); z180_device_op_a9(); } /* DB FD */
+OP(fd,aa) { z180_device_illegal_1(); z180_device_op_aa(); } /* DB FD */
+OP(fd,ab) { z180_device_illegal_1(); z180_device_op_ab(); } /* DB FD */
OP(fd,ac) { m_R++; XOR(_HY); } /* XOR HY */
OP(fd,ad) { m_R++; XOR(_LY); } /* XOR LY */
-OP(fd,ae) { m_R++; EAY(); XOR(RM(m_ea)); } /* XOR (IY+o) */
-OP(fd,af) { illegal_1(); op_af(); } /* DB FD */
+OP(fd,ae) { m_R++; EAY(); XOR(z180_device_RM(m_ea)); } /* XOR (IY+o) */
+OP(fd,af) { z180_device_illegal_1(); z180_device_op_af(); } /* DB FD */
-OP(fd,b0) { illegal_1(); op_b0(); } /* DB FD */
-OP(fd,b1) { illegal_1(); op_b1(); } /* DB FD */
-OP(fd,b2) { illegal_1(); op_b2(); } /* DB FD */
-OP(fd,b3) { illegal_1(); op_b3(); } /* DB FD */
+OP(fd,b0) { z180_device_illegal_1(); z180_device_op_b0(); } /* DB FD */
+OP(fd,b1) { z180_device_illegal_1(); z180_device_op_b1(); } /* DB FD */
+OP(fd,b2) { z180_device_illegal_1(); z180_device_op_b2(); } /* DB FD */
+OP(fd,b3) { z180_device_illegal_1(); z180_device_op_b3(); } /* DB FD */
OP(fd,b4) { m_R++; OR(_HY); } /* OR HY */
OP(fd,b5) { m_R++; OR(_LY); } /* OR LY */
-OP(fd,b6) { m_R++; EAY(); OR(RM(m_ea)); } /* OR (IY+o) */
-OP(fd,b7) { illegal_1(); op_b7(); } /* DB FD */
+OP(fd,b6) { m_R++; EAY(); OR(z180_device_RM(m_ea)); } /* OR (IY+o) */
+OP(fd,b7) { z180_device_illegal_1(); z180_device_op_b7(); } /* DB FD */
-OP(fd,b8) { illegal_1(); op_b8(); } /* DB FD */
-OP(fd,b9) { illegal_1(); op_b9(); } /* DB FD */
-OP(fd,ba) { illegal_1(); op_ba(); } /* DB FD */
-OP(fd,bb) { illegal_1(); op_bb(); } /* DB FD */
+OP(fd,b8) { z180_device_illegal_1(); z180_device_op_b8(); } /* DB FD */
+OP(fd,b9) { z180_device_illegal_1(); z180_device_op_b9(); } /* DB FD */
+OP(fd,ba) { z180_device_illegal_1(); z180_device_op_ba(); } /* DB FD */
+OP(fd,bb) { z180_device_illegal_1(); z180_device_op_bb(); } /* DB FD */
OP(fd,bc) { m_R++; CP(_HY); } /* CP HY */
OP(fd,bd) { m_R++; CP(_LY); } /* CP LY */
-OP(fd,be) { m_R++; EAY(); CP(RM(m_ea)); } /* CP (IY+o) */
-OP(fd,bf) { illegal_1(); op_bf(); } /* DB FD */
+OP(fd,be) { m_R++; EAY(); CP(z180_device_RM(m_ea)); } /* CP (IY+o) */
+OP(fd,bf) { z180_device_illegal_1(); z180_device_op_bf(); } /* DB FD */
-OP(fd,c0) { illegal_1(); op_c0(); } /* DB FD */
-OP(fd,c1) { illegal_1(); op_c1(); } /* DB FD */
-OP(fd,c2) { illegal_1(); op_c2(); } /* DB FD */
-OP(fd,c3) { illegal_1(); op_c3(); } /* DB FD */
-OP(fd,c4) { illegal_1(); op_c4(); } /* DB FD */
-OP(fd,c5) { illegal_1(); op_c5(); } /* DB FD */
-OP(fd,c6) { illegal_1(); op_c6(); } /* DB FD */
-OP(fd,c7) { illegal_1(); op_c7(); } /* DB FD */
+OP(fd,c0) { z180_device_illegal_1(); z180_device_op_c0(); } /* DB FD */
+OP(fd,c1) { z180_device_illegal_1(); z180_device_op_c1(); } /* DB FD */
+OP(fd,c2) { z180_device_illegal_1(); z180_device_op_c2(); } /* DB FD */
+OP(fd,c3) { z180_device_illegal_1(); z180_device_op_c3(); } /* DB FD */
+OP(fd,c4) { z180_device_illegal_1(); z180_device_op_c4(); } /* DB FD */
+OP(fd,c5) { z180_device_illegal_1(); z180_device_op_c5(); } /* DB FD */
+OP(fd,c6) { z180_device_illegal_1(); z180_device_op_c6(); } /* DB FD */
+OP(fd,c7) { z180_device_illegal_1(); z180_device_op_c7(); } /* DB FD */
-OP(fd,c8) { illegal_1(); op_c8(); } /* DB FD */
-OP(fd,c9) { illegal_1(); op_c9(); } /* DB FD */
-OP(fd,ca) { illegal_1(); op_ca(); } /* DB FD */
-OP(fd,cb) { m_R++; EAY(); m_extra_cycles += exec_xycb(ARG()); } /* ** FD CB xx */
-OP(fd,cc) { illegal_1(); op_cc(); } /* DB FD */
-OP(fd,cd) { illegal_1(); op_cd(); } /* DB FD */
-OP(fd,ce) { illegal_1(); op_ce(); } /* DB FD */
-OP(fd,cf) { illegal_1(); op_cf(); } /* DB FD */
+OP(fd,c8) { z180_device_illegal_1(); z180_device_op_c8(); } /* DB FD */
+OP(fd,c9) { z180_device_illegal_1(); z180_device_op_c9(); } /* DB FD */
+OP(fd,ca) { z180_device_illegal_1(); z180_device_op_ca(); } /* DB FD */
+OP(fd,cb) { m_R++; EAY(); m_extra_cycles += z180_device_exec_xycb(z180_device_ARG()); } /* ** FD CB xx */
+OP(fd,cc) { z180_device_illegal_1(); z180_device_op_cc(); } /* DB FD */
+OP(fd,cd) { z180_device_illegal_1(); z180_device_op_cd(); } /* DB FD */
+OP(fd,ce) { z180_device_illegal_1(); z180_device_op_ce(); } /* DB FD */
+OP(fd,cf) { z180_device_illegal_1(); z180_device_op_cf(); } /* DB FD */
-OP(fd,d0) { illegal_1(); op_d0(); } /* DB FD */
-OP(fd,d1) { illegal_1(); op_d1(); } /* DB FD */
-OP(fd,d2) { illegal_1(); op_d2(); } /* DB FD */
-OP(fd,d3) { illegal_1(); op_d3(); } /* DB FD */
-OP(fd,d4) { illegal_1(); op_d4(); } /* DB FD */
-OP(fd,d5) { illegal_1(); op_d5(); } /* DB FD */
-OP(fd,d6) { illegal_1(); op_d6(); } /* DB FD */
-OP(fd,d7) { illegal_1(); op_d7(); } /* DB FD */
+OP(fd,d0) { z180_device_illegal_1(); z180_device_op_d0(); } /* DB FD */
+OP(fd,d1) { z180_device_illegal_1(); z180_device_op_d1(); } /* DB FD */
+OP(fd,d2) { z180_device_illegal_1(); z180_device_op_d2(); } /* DB FD */
+OP(fd,d3) { z180_device_illegal_1(); z180_device_op_d3(); } /* DB FD */
+OP(fd,d4) { z180_device_illegal_1(); z180_device_op_d4(); } /* DB FD */
+OP(fd,d5) { z180_device_illegal_1(); z180_device_op_d5(); } /* DB FD */
+OP(fd,d6) { z180_device_illegal_1(); z180_device_op_d6(); } /* DB FD */
+OP(fd,d7) { z180_device_illegal_1(); z180_device_op_d7(); } /* DB FD */
-OP(fd,d8) { illegal_1(); op_d8(); } /* DB FD */
-OP(fd,d9) { illegal_1(); op_d9(); } /* DB FD */
-OP(fd,da) { illegal_1(); op_da(); } /* DB FD */
-OP(fd,db) { illegal_1(); op_db(); } /* DB FD */
-OP(fd,dc) { illegal_1(); op_dc(); } /* DB FD */
-OP(fd,dd) { illegal_1(); op_dd(); } /* DB FD */
-OP(fd,de) { illegal_1(); op_de(); } /* DB FD */
-OP(fd,df) { illegal_1(); op_df(); } /* DB FD */
+OP(fd,d8) { z180_device_illegal_1(); z180_device_op_d8(); } /* DB FD */
+OP(fd,d9) { z180_device_illegal_1(); z180_device_op_d9(); } /* DB FD */
+OP(fd,da) { z180_device_illegal_1(); z180_device_op_da(); } /* DB FD */
+OP(fd,db) { z180_device_illegal_1(); z180_device_op_db(); } /* DB FD */
+OP(fd,dc) { z180_device_illegal_1(); z180_device_op_dc(); } /* DB FD */
+OP(fd,dd) { z180_device_illegal_1(); z180_device_op_dd(); } /* DB FD */
+OP(fd,de) { z180_device_illegal_1(); z180_device_op_de(); } /* DB FD */
+OP(fd,df) { z180_device_illegal_1(); z180_device_op_df(); } /* DB FD */
-OP(fd,e0) { illegal_1(); op_e0(); } /* DB FD */
+OP(fd,e0) { z180_device_illegal_1(); z180_device_op_e0(); } /* DB FD */
OP(fd,e1) { m_R++; POP(IY); } /* POP IY */
-OP(fd,e2) { illegal_1(); op_e2(); } /* DB FD */
+OP(fd,e2) { z180_device_illegal_1(); z180_device_op_e2(); } /* DB FD */
OP(fd,e3) { m_R++; EXSP(IY); } /* EX (SP),IY */
-OP(fd,e4) { illegal_1(); op_e4(); } /* DB FD */
+OP(fd,e4) { z180_device_illegal_1(); z180_device_op_e4(); } /* DB FD */
OP(fd,e5) { m_R++; PUSH( IY ); } /* PUSH IY */
-OP(fd,e6) { illegal_1(); op_e6(); } /* DB FD */
-OP(fd,e7) { illegal_1(); op_e7(); } /* DB FD */
+OP(fd,e6) { z180_device_illegal_1(); z180_device_op_e6(); } /* DB FD */
+OP(fd,e7) { z180_device_illegal_1(); z180_device_op_e7(); } /* DB FD */
-OP(fd,e8) { illegal_1(); op_e8(); } /* DB FD */
+OP(fd,e8) { z180_device_illegal_1(); z180_device_op_e8(); } /* DB FD */
OP(fd,e9) { m_R++; _PC = _IY; } /* JP (IY) */
-OP(fd,ea) { illegal_1(); op_ea(); } /* DB FD */
-OP(fd,eb) { illegal_1(); op_eb(); } /* DB FD */
-OP(fd,ec) { illegal_1(); op_ec(); } /* DB FD */
-OP(fd,ed) { illegal_1(); op_ed(); } /* DB FD */
-OP(fd,ee) { illegal_1(); op_ee(); } /* DB FD */
-OP(fd,ef) { illegal_1(); op_ef(); } /* DB FD */
+OP(fd,ea) { z180_device_illegal_1(); z180_device_op_ea(); } /* DB FD */
+OP(fd,eb) { z180_device_illegal_1(); z180_device_op_eb(); } /* DB FD */
+OP(fd,ec) { z180_device_illegal_1(); z180_device_op_ec(); } /* DB FD */
+OP(fd,ed) { z180_device_illegal_1(); z180_device_op_ed(); } /* DB FD */
+OP(fd,ee) { z180_device_illegal_1(); z180_device_op_ee(); } /* DB FD */
+OP(fd,ef) { z180_device_illegal_1(); z180_device_op_ef(); } /* DB FD */
-OP(fd,f0) { illegal_1(); op_f0(); } /* DB FD */
-OP(fd,f1) { illegal_1(); op_f1(); } /* DB FD */
-OP(fd,f2) { illegal_1(); op_f2(); } /* DB FD */
-OP(fd,f3) { illegal_1(); op_f3(); } /* DB FD */
-OP(fd,f4) { illegal_1(); op_f4(); } /* DB FD */
-OP(fd,f5) { illegal_1(); op_f5(); } /* DB FD */
-OP(fd,f6) { illegal_1(); op_f6(); } /* DB FD */
-OP(fd,f7) { illegal_1(); op_f7(); } /* DB FD */
+OP(fd,f0) { z180_device_illegal_1(); z180_device_op_f0(); } /* DB FD */
+OP(fd,f1) { z180_device_illegal_1(); z180_device_op_f1(); } /* DB FD */
+OP(fd,f2) { z180_device_illegal_1(); z180_device_op_f2(); } /* DB FD */
+OP(fd,f3) { z180_device_illegal_1(); z180_device_op_f3(); } /* DB FD */
+OP(fd,f4) { z180_device_illegal_1(); z180_device_op_f4(); } /* DB FD */
+OP(fd,f5) { z180_device_illegal_1(); z180_device_op_f5(); } /* DB FD */
+OP(fd,f6) { z180_device_illegal_1(); z180_device_op_f6(); } /* DB FD */
+OP(fd,f7) { z180_device_illegal_1(); z180_device_op_f7(); } /* DB FD */
-OP(fd,f8) { illegal_1(); op_f8(); } /* DB FD */
+OP(fd,f8) { z180_device_illegal_1(); z180_device_op_f8(); } /* DB FD */
OP(fd,f9) { m_R++; _SP = _IY; } /* LD SP,IY */
-OP(fd,fa) { illegal_1(); op_fa(); } /* DB FD */
-OP(fd,fb) { illegal_1(); op_fb(); } /* DB FD */
-OP(fd,fc) { illegal_1(); op_fc(); } /* DB FD */
-OP(fd,fd) { illegal_1(); op_fd(); } /* DB FD */
-OP(fd,fe) { illegal_1(); op_fe(); } /* DB FD */
-OP(fd,ff) { illegal_1(); op_ff(); } /* DB FD */
+OP(fd,fa) { z180_device_illegal_1(); z180_device_op_fa(); } /* DB FD */
+OP(fd,fb) { z180_device_illegal_1(); z180_device_op_fb(); } /* DB FD */
+OP(fd,fc) { z180_device_illegal_1(); z180_device_op_fc(); } /* DB FD */
+OP(fd,fd) { z180_device_illegal_1(); z180_device_op_fd(); } /* DB FD */
+OP(fd,fe) { z180_device_illegal_1(); z180_device_op_fe(); } /* DB FD */
+OP(fd,ff) { z180_device_illegal_1(); z180_device_op_ff(); } /* DB FD */
* main opcodes
**********************************************************/
OP(op,00) { } /* NOP */
-OP(op,01) { _BC = ARG16(); } /* LD BC,w */
+OP(op,01) { _BC = z180_device_ARG16(); } /* LD BC,w */
OP(op,02) { WM( _BC, _A ); } /* LD (BC),A */
OP(op,03) { _BC++; } /* INC BC */
-OP(op,04) { _B = INC(_B); } /* INC B */
-OP(op,05) { _B = DEC(_B); } /* DEC B */
-OP(op,06) { _B = ARG(); } /* LD B,n */
+OP(op,04) { _B = z180_device_INC(_B); } /* INC B */
+OP(op,05) { _B = z180_device_DEC(_B); } /* DEC B */
+OP(op,06) { _B = z180_device_ARG(); } /* LD B,n */
OP(op,07) { RLCA; } /* RLCA */
OP(op,08) { EX_AF; } /* EX AF,AF' */
OP(op,09) { ADD16(HL,BC); } /* ADD HL,BC */
-OP(op,0a) { _A = RM(_BC); } /* LD A,(BC) */
+OP(op,0a) { _A = z180_device_RM(_BC); } /* LD A,(BC) */
OP(op,0b) { _BC--; } /* DEC BC */
-OP(op,0c) { _C = INC(_C); } /* INC C */
-OP(op,0d) { _C = DEC(_C); } /* DEC C */
-OP(op,0e) { _C = ARG(); } /* LD C,n */
+OP(op,0c) { _C = z180_device_INC(_C); } /* INC C */
+OP(op,0d) { _C = z180_device_DEC(_C); } /* DEC C */
+OP(op,0e) { _C = z180_device_ARG(); } /* LD C,n */
OP(op,0f) { RRCA; } /* RRCA */
OP(op,10) { _B--; JR_COND( _B, 0x10 ); } /* DJNZ o */
-OP(op,11) { _DE = ARG16(); } /* LD DE,w */
+OP(op,11) { _DE = z180_device_ARG16(); } /* LD DE,w */
OP(op,12) { WM( _DE, _A ); } /* LD (DE),A */
OP(op,13) { _DE++; } /* INC DE */
-OP(op,14) { _D = INC(_D); } /* INC D */
-OP(op,15) { _D = DEC(_D); } /* DEC D */
-OP(op,16) { _D = ARG(); } /* LD D,n */
+OP(op,14) { _D = z180_device_INC(_D); } /* INC D */
+OP(op,15) { _D = z180_device_DEC(_D); } /* DEC D */
+OP(op,16) { _D = z180_device_ARG(); } /* LD D,n */
OP(op,17) { RLA; } /* RLA */
OP(op,18) { JR(); } /* JR o */
OP(op,19) { ADD16(HL,DE); } /* ADD HL,DE */
-OP(op,1a) { _A = RM(_DE); } /* LD A,(DE) */
+OP(op,1a) { _A = z180_device_RM(_DE); } /* LD A,(DE) */
OP(op,1b) { _DE--; ; } /* DEC DE */
-OP(op,1c) { _E = INC(_E); } /* INC E */
-OP(op,1d) { _E = DEC(_E); } /* DEC E */
-OP(op,1e) { _E = ARG(); } /* LD E,n */
+OP(op,1c) { _E = z180_device_INC(_E); } /* INC E */
+OP(op,1d) { _E = z180_device_DEC(_E); } /* DEC E */
+OP(op,1e) { _E = z180_device_ARG(); } /* LD E,n */
OP(op,1f) { RRA; } /* RRA */
OP(op,20) { JR_COND( !(_F & ZF), 0x20 ); } /* JR NZ,o */
-OP(op,21) { _HL = ARG16(); } /* LD HL,w */
-OP(op,22) { m_ea = ARG16(); WM16(m_ea, &m_HL ); } /* LD (w),HL */
+OP(op,21) { _HL = z180_device_ARG16(); } /* LD HL,w */
+OP(op,22) { m_ea = z180_device_ARG16(); z180_device_WM16(m_ea, &m_HL ); } /* LD (w),HL */
OP(op,23) { _HL++; } /* INC HL */
-OP(op,24) { _H = INC(_H); } /* INC H */
-OP(op,25) { _H = DEC(_H); } /* DEC H */
-OP(op,26) { _H = ARG(); } /* LD H,n */
+OP(op,24) { _H = z180_device_INC(_H); } /* INC H */
+OP(op,25) { _H = z180_device_DEC(_H); } /* DEC H */
+OP(op,26) { _H = z180_device_ARG(); } /* LD H,n */
OP(op,27) { DAA; } /* DAA */
OP(op,28) { JR_COND( _F & ZF, 0x28 ); } /* JR Z,o */
OP(op,29) { ADD16(HL,HL); } /* ADD HL,HL */
-OP(op,2a) { m_ea = ARG16(); RM16(m_ea, &m_HL ); } /* LD HL,(w) */
+OP(op,2a) { m_ea = z180_device_ARG16(); z180_device_RM16(m_ea, &m_HL ); } /* LD HL,(w) */
OP(op,2b) { _HL--; } /* DEC HL */
-OP(op,2c) { _L = INC(_L); } /* INC L */
-OP(op,2d) { _L = DEC(_L); } /* DEC L */
-OP(op,2e) { _L = ARG(); } /* LD L,n */
+OP(op,2c) { _L = z180_device_INC(_L); } /* INC L */
+OP(op,2d) { _L = z180_device_DEC(_L); } /* DEC L */
+OP(op,2e) { _L = z180_device_ARG(); } /* LD L,n */
OP(op,2f) { _A ^= 0xff; _F = (_F&(SF|ZF|PF|CF))|HF|NF|(_A&(YF|XF)); } /* CPL */
OP(op,30) { JR_COND( !(_F & CF), 0x30 ); } /* JR NC,o */
-OP(op,31) { _SP = ARG16(); } /* LD SP,w */
-OP(op,32) { m_ea = ARG16(); WM( m_ea, _A ); } /* LD (w),A */
+OP(op,31) { _SP = z180_device_ARG16(); } /* LD SP,w */
+OP(op,32) { m_ea = z180_device_ARG16(); WM( m_ea, _A ); } /* LD (w),A */
OP(op,33) { _SP++; } /* INC SP */
-OP(op,34) { WM( _HL, INC(RM(_HL)) ); } /* INC (HL) */
-OP(op,35) { WM( _HL, DEC(RM(_HL)) ); } /* DEC (HL) */
-OP(op,36) { WM( _HL, ARG() ); } /* LD (HL),n */
+OP(op,34) { WM( _HL, z180_device_INC(z180_device_RM(_HL)) ); } /* INC (HL) */
+OP(op,35) { WM( _HL, z180_device_DEC(z180_device_RM(_HL)) ); } /* DEC (HL) */
+OP(op,36) { WM( _HL, z180_device_ARG() ); } /* LD (HL),n */
OP(op,37) { _F = (_F & (SF|ZF|PF)) | CF | (_A & (YF|XF)); } /* SCF */
OP(op,38) { JR_COND( _F & CF, 0x38 ); } /* JR C,o */
OP(op,39) { ADD16(HL,SP); } /* ADD HL,SP */
-OP(op,3a) { m_ea = ARG16(); _A = RM( m_ea ); } /* LD A,(w) */
+OP(op,3a) { m_ea = z180_device_ARG16(); _A = z180_device_RM( m_ea ); } /* LD A,(w) */
OP(op,3b) { _SP--; } /* DEC SP */
-OP(op,3c) { _A = INC(_A); } /* INC A */
-OP(op,3d) { _A = DEC(_A); } /* DEC A */
-OP(op,3e) { _A = ARG(); } /* LD A,n */
+OP(op,3c) { _A = z180_device_INC(_A); } /* INC A */
+OP(op,3d) { _A = z180_device_DEC(_A); } /* DEC A */
+OP(op,3e) { _A = z180_device_ARG(); } /* LD A,n */
OP(op,3f) { _F = ((_F&(SF|ZF|PF|CF))|((_F&CF)<<4)|(_A&(YF|XF)))^CF; } /* CCF */
//OP(op,3f) { _F = ((_F & ~(HF|NF)) | ((_F & CF)<<4)) ^ CF; } /* CCF */
OP(op,43) { _B = _E; } /* LD B,E */
OP(op,44) { _B = _H; } /* LD B,H */
OP(op,45) { _B = _L; } /* LD B,L */
-OP(op,46) { _B = RM(_HL); } /* LD B,(HL) */
+OP(op,46) { _B = z180_device_RM(_HL); } /* LD B,(HL) */
OP(op,47) { _B = _A; } /* LD B,A */
OP(op,48) { _C = _B; } /* LD C,B */
OP(op,4b) { _C = _E; } /* LD C,E */
OP(op,4c) { _C = _H; } /* LD C,H */
OP(op,4d) { _C = _L; } /* LD C,L */
-OP(op,4e) { _C = RM(_HL); } /* LD C,(HL) */
+OP(op,4e) { _C = z180_device_RM(_HL); } /* LD C,(HL) */
OP(op,4f) { _C = _A; } /* LD C,A */
OP(op,50) { _D = _B; } /* LD D,B */
OP(op,53) { _D = _E; } /* LD D,E */
OP(op,54) { _D = _H; } /* LD D,H */
OP(op,55) { _D = _L; } /* LD D,L */
-OP(op,56) { _D = RM(_HL); } /* LD D,(HL) */
+OP(op,56) { _D = z180_device_RM(_HL); } /* LD D,(HL) */
OP(op,57) { _D = _A; } /* LD D,A */
OP(op,58) { _E = _B; } /* LD E,B */
OP(op,5b) { } /* LD E,E */
OP(op,5c) { _E = _H; } /* LD E,H */
OP(op,5d) { _E = _L; } /* LD E,L */
-OP(op,5e) { _E = RM(_HL); } /* LD E,(HL) */
+OP(op,5e) { _E = z180_device_RM(_HL); } /* LD E,(HL) */
OP(op,5f) { _E = _A; } /* LD E,A */
OP(op,60) { _H = _B; } /* LD H,B */
OP(op,63) { _H = _E; } /* LD H,E */
OP(op,64) { } /* LD H,H */
OP(op,65) { _H = _L; } /* LD H,L */
-OP(op,66) { _H = RM(_HL); } /* LD H,(HL) */
+OP(op,66) { _H = z180_device_RM(_HL); } /* LD H,(HL) */
OP(op,67) { _H = _A; } /* LD H,A */
OP(op,68) { _L = _B; } /* LD L,B */
OP(op,6b) { _L = _E; } /* LD L,E */
OP(op,6c) { _L = _H; } /* LD L,H */
OP(op,6d) { } /* LD L,L */
-OP(op,6e) { _L = RM(_HL); } /* LD L,(HL) */
+OP(op,6e) { _L = z180_device_RM(_HL); } /* LD L,(HL) */
OP(op,6f) { _L = _A; } /* LD L,A */
OP(op,70) { WM( _HL, _B ); } /* LD (HL),B */
OP(op,7b) { _A = _E; } /* LD A,E */
OP(op,7c) { _A = _H; } /* LD A,H */
OP(op,7d) { _A = _L; } /* LD A,L */
-OP(op,7e) { _A = RM(_HL); } /* LD A,(HL) */
+OP(op,7e) { _A = z180_device_RM(_HL); } /* LD A,(HL) */
OP(op,7f) { } /* LD A,A */
OP(op,80) { ADD(_B); } /* ADD A,B */
OP(op,83) { ADD(_E); } /* ADD A,E */
OP(op,84) { ADD(_H); } /* ADD A,H */
OP(op,85) { ADD(_L); } /* ADD A,L */
-OP(op,86) { ADD(RM(_HL)); } /* ADD A,(HL) */
+OP(op,86) { ADD(z180_device_RM(_HL)); } /* ADD A,(HL) */
OP(op,87) { ADD(_A); } /* ADD A,A */
OP(op,88) { ADC(_B); } /* ADC A,B */
OP(op,8b) { ADC(_E); } /* ADC A,E */
OP(op,8c) { ADC(_H); } /* ADC A,H */
OP(op,8d) { ADC(_L); } /* ADC A,L */
-OP(op,8e) { ADC(RM(_HL)); } /* ADC A,(HL) */
+OP(op,8e) { ADC(z180_device_RM(_HL)); } /* ADC A,(HL) */
OP(op,8f) { ADC(_A); } /* ADC A,A */
OP(op,90) { SUB(_B); } /* SUB B */
OP(op,93) { SUB(_E); } /* SUB E */
OP(op,94) { SUB(_H); } /* SUB H */
OP(op,95) { SUB(_L); } /* SUB L */
-OP(op,96) { SUB(RM(_HL)); } /* SUB (HL) */
+OP(op,96) { SUB(z180_device_RM(_HL)); } /* SUB (HL) */
OP(op,97) { SUB(_A); } /* SUB A */
OP(op,98) { SBC(_B); } /* SBC A,B */
OP(op,9b) { SBC(_E); } /* SBC A,E */
OP(op,9c) { SBC(_H); } /* SBC A,H */
OP(op,9d) { SBC(_L); } /* SBC A,L */
-OP(op,9e) { SBC(RM(_HL)); } /* SBC A,(HL) */
+OP(op,9e) { SBC(z180_device_RM(_HL)); } /* SBC A,(HL) */
OP(op,9f) { SBC(_A); } /* SBC A,A */
OP(op,a0) { AND(_B); } /* AND B */
OP(op,a3) { AND(_E); } /* AND E */
OP(op,a4) { AND(_H); } /* AND H */
OP(op,a5) { AND(_L); } /* AND L */
-OP(op,a6) { AND(RM(_HL)); } /* AND (HL) */
+OP(op,a6) { AND(z180_device_RM(_HL)); } /* AND (HL) */
OP(op,a7) { AND(_A); } /* AND A */
OP(op,a8) { XOR(_B); } /* XOR B */
OP(op,ab) { XOR(_E); } /* XOR E */
OP(op,ac) { XOR(_H); } /* XOR H */
OP(op,ad) { XOR(_L); } /* XOR L */
-OP(op,ae) { XOR(RM(_HL)); } /* XOR (HL) */
+OP(op,ae) { XOR(z180_device_RM(_HL)); } /* XOR (HL) */
OP(op,af) { XOR(_A); } /* XOR A */
OP(op,b0) { OR(_B); } /* OR B */
OP(op,b3) { OR(_E); } /* OR E */
OP(op,b4) { OR(_H); } /* OR H */
OP(op,b5) { OR(_L); } /* OR L */
-OP(op,b6) { OR(RM(_HL)); } /* OR (HL) */
+OP(op,b6) { OR(z180_device_RM(_HL)); } /* OR (HL) */
OP(op,b7) { OR(_A); } /* OR A */
OP(op,b8) { CP(_B); } /* CP B */
OP(op,bb) { CP(_E); } /* CP E */
OP(op,bc) { CP(_H); } /* CP H */
OP(op,bd) { CP(_L); } /* CP L */
-OP(op,be) { CP(RM(_HL)); } /* CP (HL) */
+OP(op,be) { CP(z180_device_RM(_HL)); } /* CP (HL) */
OP(op,bf) { CP(_A); } /* CP A */
OP(op,c0) { RET_COND( !(_F & ZF), 0xc0 ); } /* RET NZ */
OP(op,c3) { JP; } /* JP a */
OP(op,c4) { CALL_COND( !(_F & ZF), 0xc4 ); } /* CALL NZ,a */
OP(op,c5) { PUSH( BC ); } /* PUSH BC */
-OP(op,c6) { ADD(ARG()); } /* ADD A,n */
+OP(op,c6) { ADD(z180_device_ARG()); } /* ADD A,n */
OP(op,c7) { RST(0x00); } /* RST 0 */
OP(op,c8) { RET_COND( _F & ZF, 0xc8 ); } /* RET Z */
OP(op,c9) { POP(PC); } /* RET */
OP(op,ca) { JP_COND( _F & ZF ); } /* JP Z,a */
-OP(op,cb) { m_R++; m_extra_cycles += exec_cb(ROP()); } /* **** CB xx */
+OP(op,cb) { m_R++; m_extra_cycles += z180_device_exec_cb(z180_device_ROP()); } /* **** CB xx */
OP(op,cc) { CALL_COND( _F & ZF, 0xcc ); } /* CALL Z,a */
OP(op,cd) { CALL(); } /* CALL a */
-OP(op,ce) { ADC(ARG()); } /* ADC A,n */
+OP(op,ce) { ADC(z180_device_ARG()); } /* ADC A,n */
OP(op,cf) { RST(0x08); } /* RST 1 */
OP(op,d0) { RET_COND( !(_F & CF), 0xd0 ); } /* RET NC */
OP(op,d1) { POP(DE); } /* POP DE */
OP(op,d2) { JP_COND( !(_F & CF) ); } /* JP NC,a */
-OP(op,d3) { unsigned n = ARG() | (_A << 8); OUT(n, _A ); } /* OUT (n),A */
+OP(op,d3) { unsigned n = z180_device_ARG() | (_A << 8); z180_device_OUT(n, _A ); } /* OUT (n),A */
OP(op,d4) { CALL_COND( !(_F & CF), 0xd4 ); } /* CALL NC,a */
OP(op,d5) { PUSH( DE ); } /* PUSH DE */
-OP(op,d6) { SUB(ARG()); } /* SUB n */
+OP(op,d6) { SUB(z180_device_ARG()); } /* SUB n */
OP(op,d7) { RST(0x10); } /* RST 2 */
OP(op,d8) { RET_COND( _F & CF, 0xd8 ); } /* RET C */
OP(op,d9) { EXX; } /* EXX */
OP(op,da) { JP_COND( _F & CF ); } /* JP C,a */
-OP(op,db) { unsigned n = ARG() | (_A << 8); _A = IN(n ); } /* IN A,(n) */
+OP(op,db) { unsigned n = z180_device_ARG() | (_A << 8); _A = z180_device_IN(n ); } /* IN A,(n) */
OP(op,dc) { CALL_COND( _F & CF, 0xdc ); } /* CALL C,a */
-OP(op,dd) { m_R++; m_extra_cycles += exec_dd(ROP()); } /* **** DD xx */
-OP(op,de) { SBC(ARG()); } /* SBC A,n */
+OP(op,dd) { m_R++; m_extra_cycles += z180_device_exec_dd(z180_device_ROP()); } /* **** DD xx */
+OP(op,de) { SBC(z180_device_ARG()); } /* SBC A,n */
OP(op,df) { RST(0x18); } /* RST 3 */
OP(op,e0) { RET_COND( !(_F & PF), 0xe0 ); } /* RET PO */
OP(op,e3) { EXSP(HL); } /* EX HL,(SP) */
OP(op,e4) { CALL_COND( !(_F & PF), 0xe4 ); } /* CALL PO,a */
OP(op,e5) { PUSH( HL ); } /* PUSH HL */
-OP(op,e6) { AND(ARG()); } /* AND n */
+OP(op,e6) { AND(z180_device_ARG()); } /* AND n */
OP(op,e7) { RST(0x20); } /* RST 4 */
OP(op,e8) { RET_COND( _F & PF, 0xe8 ); } /* RET PE */
OP(op,ea) { JP_COND( _F & PF ); } /* JP PE,a */
OP(op,eb) { EX_DE_HL; } /* EX DE,HL */
OP(op,ec) { CALL_COND( _F & PF, 0xec ); } /* CALL PE,a */
-OP(op,ed) { m_R++; m_extra_cycles += exec_ed(ROP()); } /* **** ED xx */
-OP(op,ee) { XOR(ARG()); } /* XOR n */
+OP(op,ed) { m_R++; m_extra_cycles += z180_device_exec_ed(z180_device_ROP()); } /* **** ED xx */
+OP(op,ee) { XOR(z180_device_ARG()); } /* XOR n */
OP(op,ef) { RST(0x28); } /* RST 5 */
OP(op,f0) { RET_COND( !(_F & SF), 0xf0 ); } /* RET P */
OP(op,f3) { m_IFF1 = m_IFF2 = 0; } /* DI */
OP(op,f4) { CALL_COND( !(_F & SF), 0xf4 ); } /* CALL P,a */
OP(op,f5) { PUSH( AF ); } /* PUSH AF */
-OP(op,f6) { OR(ARG()); } /* OR n */
+OP(op,f6) { OR(z180_device_ARG()); } /* OR n */
OP(op,f7) { RST(0x30); } /* RST 6 */
OP(op,f8) { RET_COND( _F & SF, 0xf8 ); } /* RET M */
OP(op,fa) { JP_COND(_F & SF); } /* JP M,a */
OP(op,fb) { EI; } /* EI */
OP(op,fc) { CALL_COND( _F & SF, 0xfc ); } /* CALL M,a */
-OP(op,fd) { m_R++; m_extra_cycles += exec_fd(ROP()); } /* **** FD xx */
-OP(op,fe) { CP(ARG()); } /* CP n */
+OP(op,fd) { m_R++; m_extra_cycles += z180_device_exec_fd(z180_device_ROP()); } /* **** FD xx */
+OP(op,fe) { CP(z180_device_ARG()); } /* CP n */
OP(op,ff) { RST(0x38); } /* RST 7 */
-int /*z180_device::*/take_interrupt(int irq)
+int z180_device_take_interrupt(int irq)
{
int irq_vector;
int cycles = 0;
{
irq_vector = (irq_vector & 0xff) + (m_I << 8);
PUSH( PC );
- RM16(irq_vector, &m_PC );
+ z180_device_RM16(irq_vector, &m_PC );
LOG("Z180 IM2 [$%04x] = $%04x\n", irq_vector, _PCD);
/* CALL opcode timing */
cycles += m_cc[Z180_TABLE_op][0xcd];
irq_vector = (IO(Z180_IL) & Z180_IL_IL) + (irq - Z180_INT_IRQ1) * 2;
irq_vector = (m_I << 8) + (irq_vector & 0xff);
PUSH( PC );
- RM16(irq_vector, &m_PC );
+ z180_device_RM16(irq_vector, &m_PC );
LOG("Z180 INT%d [$%04x] = $%04x\n", irq, irq_vector, _PCD);
/* CALL opcode timing */
cycles += m_cc[Z180_TABLE_op][0xcd];
/***************************************************************
* Input a byte from given I/O port
***************************************************************/
-/*inline*/ u8 /*z180_device::*/IN(u16 port)
+/*inline*/ u8 z180_device_IN(u16 port)
{
if(((port ^ IO_IOCR) & 0xffc0) == 0)
- return z180_readcontrol(port);
+ return z180_device_z180_readcontrol(port);
m_extra_cycles += ((IO_DCNTL & (Z180_DCNTL_IWI1 | Z180_DCNTL_IWI0)) >> 4) + 1; // external I/O wait states
return m_iospace_read_byte(port);
}
/***************************************************************
* Output a byte to given I/O port
***************************************************************/
-/*inline*/ void /*z180_device::*/OUT(u16 port, u8 value)
+/*inline*/ void z180_device_OUT(u16 port, u8 value)
{
if (((port ^ IO_IOCR) & 0xffc0) == 0) {
- z180_writecontrol(port,value);
+ z180_device_z180_writecontrol(port,value);
} else
{
m_extra_cycles += ((IO_DCNTL & (Z180_DCNTL_IWI1 | Z180_DCNTL_IWI0)) >> 4) + 1; // external I/O wait states
* If the 4 bits are also greater or equal to the common base,
* the common base register is used to specify the offset.
***************************************************************/
-void /*z180_device::*/z180_mmu()
+void z180_device_z180_mmu()
{
offs_t addr, page, bb, cb;
bb = IO_CBAR & 15;
/***************************************************************
* Read a byte from given memory location
***************************************************************/
-/*inline*/ u8 /*z180_device::*/RM(offs_t addr)
+/*inline*/ u8 z180_device_RM(offs_t addr)
{
m_extra_cycles += IO_DCNTL >> 6; // memory wait states
return m_program_read_byte(MMU_REMAP_ADDR(addr));
/***************************************************************
* Read a word from given memory location
***************************************************************/
-void /*z180_device::*/RM16( offs_t addr, PAIR *r )
+void z180_device_RM16( offs_t addr, PAIR *r )
{
- r->b.l = RM(addr);
- r->b.h = RM(addr+1);
+ r->b.l = z180_device_RM(addr);
+ r->b.h = z180_device_RM(addr+1);
}
/***************************************************************
* Write a word to given memory location
***************************************************************/
-void /*z180_device::*/WM16( offs_t addr, PAIR *r )
+void z180_device_WM16( offs_t addr, PAIR *r )
{
WM(addr, r->b.l);
WM(addr+1, r->b.h);
}
/***************************************************************
- * ROP() is identical to RM() except it is used for
+ * z180_device_ROP() is identical to z180_device_RM() except it is used for
* reading opcodes_ In case of system with memory mapped I/O,
* this function can be used to greatly speed up emulation
***************************************************************/
-uint8_t /*z180_device::*/ROP()
+uint8_t z180_device_ROP()
{
offs_t addr = _PCD;
_PC++;
}
/****************************************************************
- * ARG() is identical to ROP() except it is used
+ * z180_device_ARG() is identical to z180_device_ROP() except it is used
* for reading opcode arguments. This difference can be used to
* support systems that use different encoding mechanisms for
* opcodes and opcode arguments
***************************************************************/
-uint8_t /*z180_device::*/ARG()
+uint8_t z180_device_ARG()
{
offs_t addr = _PCD;
_PC++;
return m_cache_read_byte(MMU_REMAP_ADDR(addr));
}
-uint32_t /*z180_device::*/ARG16()
+uint32_t z180_device_ARG16()
{
offs_t addr = _PCD;
_PC += 2;
* Calculate the effective address m_ea of an opcode using
* IX+offset resp. IY+offset addressing.
***************************************************************/
-#define EAX() m_ea = (uint32_t)(uint16_t)(_IX + (int8_t)ARG())
-#define EAY() m_ea = (uint32_t)(uint16_t)(_IY + (int8_t)ARG())
+#define EAX() m_ea = (uint32_t)(uint16_t)(_IX + (int8_t)z180_device_ARG())
+#define EAY() m_ea = (uint32_t)(uint16_t)(_IY + (int8_t)z180_device_ARG())
/***************************************************************
* POP
***************************************************************/
-#define POP(DR) { RM16(_SPD, &m_##DR ); _SP += 2; }
+#define POP(DR) { z180_device_RM16(_SPD, &m_##DR ); _SP += 2; }
/***************************************************************
* PUSH
***************************************************************/
-#define PUSH(SR) { _SP -= 2; WM16(_SPD, &m_##SR); }
+#define PUSH(SR) { _SP -= 2; z180_device_WM16(_SPD, &m_##SR); }
/***************************************************************
* JP
***************************************************************/
#define JP { \
- _PCD = ARG16(); \
+ _PCD = z180_device_ARG16(); \
}
/***************************************************************
#define JP_COND(cond) \
if( cond ) \
{ \
- _PCD = ARG16(); \
+ _PCD = z180_device_ARG16(); \
} \
else \
{ \
***************************************************************/
#define JR() \
{ \
- int8_t arg = (int8_t)ARG(); /* ARG() also increments _PC */ \
- _PC += arg; /* so don't do _PC += ARG() */ \
+ int8_t arg = (int8_t)z180_device_ARG(); /* z180_device_ARG() also increments _PC */ \
+ _PC += arg; /* so don't do _PC += z180_device_ARG() */ \
}
/***************************************************************
#define JR_COND(cond,opcode) \
if( cond ) \
{ \
- int8_t arg = (int8_t)ARG(); /* ARG() also increments _PC */ \
- _PC += arg; /* so don't do _PC += ARG() */ \
+ int8_t arg = (int8_t)z180_device_ARG(); /* z180_device_ARG() also increments _PC */ \
+ _PC += arg; /* so don't do _PC += z180_device_ARG() */ \
CC(ex,opcode); \
} \
else _PC++;
* CALL
***************************************************************/
#define CALL() \
- m_ea = ARG16(); \
+ m_ea = z180_device_ARG16(); \
PUSH( PC ); \
_PCD = m_ea;
#define CALL_COND(cond,opcode) \
if( cond ) \
{ \
- m_ea = ARG16(); \
+ m_ea = z180_device_ARG16(); \
PUSH( PC ); \
_PCD = m_ea; \
CC(ex,opcode); \
/***************************************************************
* INC r8
***************************************************************/
-uint8_t /*z180_device::*/INC(uint8_t value)
+uint8_t z180_device_INC(uint8_t value)
{
uint8_t res = value + 1;
_F = (_F & CF) | SZHV_inc[res];
/***************************************************************
* DEC r8
***************************************************************/
-uint8_t /*z180_device::*/DEC(uint8_t value)
+uint8_t z180_device_DEC(uint8_t value)
{
uint8_t res = value - 1;
_F = (_F & CF) | SZHV_dec[res];
* RRD
***************************************************************/
#define RRD { \
- uint8_t n = RM(_HL); \
+ uint8_t n = z180_device_RM(_HL); \
WM( _HL, (n >> 4) | (_A << 4) ); \
_A = (_A & 0xf0) | (n & 0x0f); \
_F = (_F & CF) | SZP[_A]; \
* RLD
***************************************************************/
#define RLD { \
- uint8_t n = RM(_HL); \
+ uint8_t n = z180_device_RM(_HL); \
WM( _HL, (n << 4) | (_A & 0x0f) ); \
_A = (_A & 0xf0) | (n >> 4); \
_F = (_F & CF) | SZP[_A]; \
#define EXSP(DR) \
{ \
PAIR tmp = { { 0, 0, 0, 0 } }; \
- RM16( _SPD, &tmp ); \
- WM16( _SPD, &m_##DR ); \
+ z180_device_RM16( _SPD, &tmp ); \
+ z180_device_WM16( _SPD, &m_##DR ); \
m_##DR = tmp; \
}
/***************************************************************
* RLC r8
***************************************************************/
-uint8_t /*z180_device::*/RLC(uint8_t value)
+uint8_t z180_device_RLC(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x80) ? CF : 0;
/***************************************************************
* RRC r8
***************************************************************/
-uint8_t /*z180_device::*/RRC(uint8_t value)
+uint8_t z180_device_RRC(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x01) ? CF : 0;
/***************************************************************
* RL r8
***************************************************************/
-uint8_t /*z180_device::*/RL(uint8_t value)
+uint8_t z180_device_RL(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x80) ? CF : 0;
/***************************************************************
* RR r8
***************************************************************/
-uint8_t /*z180_device::*/RR(uint8_t value)
+uint8_t z180_device_RR(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x01) ? CF : 0;
/***************************************************************
* SLA r8
***************************************************************/
-uint8_t /*z180_device::*/SLA(uint8_t value)
+uint8_t z180_device_SLA(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x80) ? CF : 0;
/***************************************************************
* SRA r8
***************************************************************/
-uint8_t /*z180_device::*/SRA(uint8_t value)
+uint8_t z180_device_SRA(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x01) ? CF : 0;
/***************************************************************
* SLL r8
***************************************************************/
-uint8_t /*z180_device::*/SLL(uint8_t value)
+uint8_t z180_device_SLL(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x80) ? CF : 0;
/***************************************************************
* SRL r8
***************************************************************/
-uint8_t /*z180_device::*/SRL(uint8_t value)
+uint8_t z180_device_SRL(uint8_t value)
{
unsigned res = value;
unsigned c = (res & 0x01) ? CF : 0;
/***************************************************************
* RES bit,r8
***************************************************************/
-uint8_t /*z180_device::*/RES(uint8_t bit, uint8_t value)
+uint8_t z180_device_RES(uint8_t bit, uint8_t value)
{
return value & ~(1<<bit);
}
/***************************************************************
* SET bit,r8
***************************************************************/
-uint8_t /*z180_device::*/SET(uint8_t bit, uint8_t value)
+uint8_t z180_device_SET(uint8_t bit, uint8_t value)
{
return value | (1<<bit);
}
* LDI
***************************************************************/
#define LDI { \
- uint8_t io = RM(_HL); \
+ uint8_t io = z180_device_RM(_HL); \
WM( _DE, io ); \
_F &= SF | ZF | CF; \
if( (_A + io) & 0x02 ) _F |= YF; /* bit 1 -> flag 5 */ \
* CPI
***************************************************************/
#define CPI { \
- uint8_t val = RM(_HL); \
+ uint8_t val = z180_device_RM(_HL); \
uint8_t res = _A - val; \
_HL++; _BC--; \
_F = (_F & CF) | (SZ[res] & ~(YF|XF)) | ((_A ^ val ^ res) & HF) | NF; \
* INI
***************************************************************/
#define INI { \
- uint8_t io = IN(_BC); \
+ uint8_t io = z180_device_IN(_BC); \
_B--; \
WM( _HL, io ); \
_HL++; \
* OUTI
***************************************************************/
#define OUTI { \
- uint8_t io = RM(_HL); \
+ uint8_t io = z180_device_RM(_HL); \
_B--; \
- OUT( _BC, io ); \
+ z180_device_OUT( _BC, io ); \
_HL++; \
_F = SZ[_B]; \
if( io & SF ) _F |= NF; \
* LDD
***************************************************************/
#define LDD { \
- uint8_t io = RM(_HL); \
+ uint8_t io = z180_device_RM(_HL); \
WM( _DE, io ); \
_F &= SF | ZF | CF; \
if( (_A + io) & 0x02 ) _F |= YF; /* bit 1 -> flag 5 */ \
* CPD
***************************************************************/
#define CPD { \
- uint8_t val = RM(_HL); \
+ uint8_t val = z180_device_RM(_HL); \
uint8_t res = _A - val; \
_HL--; _BC--; \
_F = (_F & CF) | (SZ[res] & ~(YF|XF)) | ((_A ^ val ^ res) & HF) | NF; \
* IND
***************************************************************/
#define IND { \
- uint8_t io = IN(_BC); \
+ uint8_t io = z180_device_IN(_BC); \
_B--; \
WM( _HL, io ); \
_HL--; \
* OUTD
***************************************************************/
#define OUTD { \
- uint8_t io = RM(_HL); \
+ uint8_t io = z180_device_RM(_HL); \
_B--; \
- OUT( _BC, io ); \
+ z180_device_OUT( _BC, io ); \
_HL--; \
_F = SZ[_B]; \
if( io & SF ) _F |= NF; \
***************************************************************/
#define OTIM { \
_B--; \
- OUT( _C, RM(_HL) ); \
+ z180_device_OUT( _C, z180_device_RM(_HL) ); \
_HL++; \
_C++; \
_F = (_B) ? NF : NF | ZF; \
***************************************************************/
#define OTDM { \
_B--; \
- OUT( _C, RM(_HL) ); \
+ z180_device_OUT( _C, z180_device_RM(_HL) ); \
_HL--; \
_C--; \
_F = (_B) ? NF : NF | ZF; \
#define TABLE(prefix) {\
- &/*z180_device::*/prefix##_00,&/*z180_device::*/prefix##_01,&/*z180_device::*/prefix##_02,&/*z180_device::*/prefix##_03,&/*z180_device::*/prefix##_04,&/*z180_device::*/prefix##_05,&/*z180_device::*/prefix##_06,&/*z180_device::*/prefix##_07, \
- &/*z180_device::*/prefix##_08,&/*z180_device::*/prefix##_09,&/*z180_device::*/prefix##_0a,&/*z180_device::*/prefix##_0b,&/*z180_device::*/prefix##_0c,&/*z180_device::*/prefix##_0d,&/*z180_device::*/prefix##_0e,&/*z180_device::*/prefix##_0f, \
- &/*z180_device::*/prefix##_10,&/*z180_device::*/prefix##_11,&/*z180_device::*/prefix##_12,&/*z180_device::*/prefix##_13,&/*z180_device::*/prefix##_14,&/*z180_device::*/prefix##_15,&/*z180_device::*/prefix##_16,&/*z180_device::*/prefix##_17, \
- &/*z180_device::*/prefix##_18,&/*z180_device::*/prefix##_19,&/*z180_device::*/prefix##_1a,&/*z180_device::*/prefix##_1b,&/*z180_device::*/prefix##_1c,&/*z180_device::*/prefix##_1d,&/*z180_device::*/prefix##_1e,&/*z180_device::*/prefix##_1f, \
- &/*z180_device::*/prefix##_20,&/*z180_device::*/prefix##_21,&/*z180_device::*/prefix##_22,&/*z180_device::*/prefix##_23,&/*z180_device::*/prefix##_24,&/*z180_device::*/prefix##_25,&/*z180_device::*/prefix##_26,&/*z180_device::*/prefix##_27, \
- &/*z180_device::*/prefix##_28,&/*z180_device::*/prefix##_29,&/*z180_device::*/prefix##_2a,&/*z180_device::*/prefix##_2b,&/*z180_device::*/prefix##_2c,&/*z180_device::*/prefix##_2d,&/*z180_device::*/prefix##_2e,&/*z180_device::*/prefix##_2f, \
- &/*z180_device::*/prefix##_30,&/*z180_device::*/prefix##_31,&/*z180_device::*/prefix##_32,&/*z180_device::*/prefix##_33,&/*z180_device::*/prefix##_34,&/*z180_device::*/prefix##_35,&/*z180_device::*/prefix##_36,&/*z180_device::*/prefix##_37, \
- &/*z180_device::*/prefix##_38,&/*z180_device::*/prefix##_39,&/*z180_device::*/prefix##_3a,&/*z180_device::*/prefix##_3b,&/*z180_device::*/prefix##_3c,&/*z180_device::*/prefix##_3d,&/*z180_device::*/prefix##_3e,&/*z180_device::*/prefix##_3f, \
- &/*z180_device::*/prefix##_40,&/*z180_device::*/prefix##_41,&/*z180_device::*/prefix##_42,&/*z180_device::*/prefix##_43,&/*z180_device::*/prefix##_44,&/*z180_device::*/prefix##_45,&/*z180_device::*/prefix##_46,&/*z180_device::*/prefix##_47, \
- &/*z180_device::*/prefix##_48,&/*z180_device::*/prefix##_49,&/*z180_device::*/prefix##_4a,&/*z180_device::*/prefix##_4b,&/*z180_device::*/prefix##_4c,&/*z180_device::*/prefix##_4d,&/*z180_device::*/prefix##_4e,&/*z180_device::*/prefix##_4f, \
- &/*z180_device::*/prefix##_50,&/*z180_device::*/prefix##_51,&/*z180_device::*/prefix##_52,&/*z180_device::*/prefix##_53,&/*z180_device::*/prefix##_54,&/*z180_device::*/prefix##_55,&/*z180_device::*/prefix##_56,&/*z180_device::*/prefix##_57, \
- &/*z180_device::*/prefix##_58,&/*z180_device::*/prefix##_59,&/*z180_device::*/prefix##_5a,&/*z180_device::*/prefix##_5b,&/*z180_device::*/prefix##_5c,&/*z180_device::*/prefix##_5d,&/*z180_device::*/prefix##_5e,&/*z180_device::*/prefix##_5f, \
- &/*z180_device::*/prefix##_60,&/*z180_device::*/prefix##_61,&/*z180_device::*/prefix##_62,&/*z180_device::*/prefix##_63,&/*z180_device::*/prefix##_64,&/*z180_device::*/prefix##_65,&/*z180_device::*/prefix##_66,&/*z180_device::*/prefix##_67, \
- &/*z180_device::*/prefix##_68,&/*z180_device::*/prefix##_69,&/*z180_device::*/prefix##_6a,&/*z180_device::*/prefix##_6b,&/*z180_device::*/prefix##_6c,&/*z180_device::*/prefix##_6d,&/*z180_device::*/prefix##_6e,&/*z180_device::*/prefix##_6f, \
- &/*z180_device::*/prefix##_70,&/*z180_device::*/prefix##_71,&/*z180_device::*/prefix##_72,&/*z180_device::*/prefix##_73,&/*z180_device::*/prefix##_74,&/*z180_device::*/prefix##_75,&/*z180_device::*/prefix##_76,&/*z180_device::*/prefix##_77, \
- &/*z180_device::*/prefix##_78,&/*z180_device::*/prefix##_79,&/*z180_device::*/prefix##_7a,&/*z180_device::*/prefix##_7b,&/*z180_device::*/prefix##_7c,&/*z180_device::*/prefix##_7d,&/*z180_device::*/prefix##_7e,&/*z180_device::*/prefix##_7f, \
- &/*z180_device::*/prefix##_80,&/*z180_device::*/prefix##_81,&/*z180_device::*/prefix##_82,&/*z180_device::*/prefix##_83,&/*z180_device::*/prefix##_84,&/*z180_device::*/prefix##_85,&/*z180_device::*/prefix##_86,&/*z180_device::*/prefix##_87, \
- &/*z180_device::*/prefix##_88,&/*z180_device::*/prefix##_89,&/*z180_device::*/prefix##_8a,&/*z180_device::*/prefix##_8b,&/*z180_device::*/prefix##_8c,&/*z180_device::*/prefix##_8d,&/*z180_device::*/prefix##_8e,&/*z180_device::*/prefix##_8f, \
- &/*z180_device::*/prefix##_90,&/*z180_device::*/prefix##_91,&/*z180_device::*/prefix##_92,&/*z180_device::*/prefix##_93,&/*z180_device::*/prefix##_94,&/*z180_device::*/prefix##_95,&/*z180_device::*/prefix##_96,&/*z180_device::*/prefix##_97, \
- &/*z180_device::*/prefix##_98,&/*z180_device::*/prefix##_99,&/*z180_device::*/prefix##_9a,&/*z180_device::*/prefix##_9b,&/*z180_device::*/prefix##_9c,&/*z180_device::*/prefix##_9d,&/*z180_device::*/prefix##_9e,&/*z180_device::*/prefix##_9f, \
- &/*z180_device::*/prefix##_a0,&/*z180_device::*/prefix##_a1,&/*z180_device::*/prefix##_a2,&/*z180_device::*/prefix##_a3,&/*z180_device::*/prefix##_a4,&/*z180_device::*/prefix##_a5,&/*z180_device::*/prefix##_a6,&/*z180_device::*/prefix##_a7, \
- &/*z180_device::*/prefix##_a8,&/*z180_device::*/prefix##_a9,&/*z180_device::*/prefix##_aa,&/*z180_device::*/prefix##_ab,&/*z180_device::*/prefix##_ac,&/*z180_device::*/prefix##_ad,&/*z180_device::*/prefix##_ae,&/*z180_device::*/prefix##_af, \
- &/*z180_device::*/prefix##_b0,&/*z180_device::*/prefix##_b1,&/*z180_device::*/prefix##_b2,&/*z180_device::*/prefix##_b3,&/*z180_device::*/prefix##_b4,&/*z180_device::*/prefix##_b5,&/*z180_device::*/prefix##_b6,&/*z180_device::*/prefix##_b7, \
- &/*z180_device::*/prefix##_b8,&/*z180_device::*/prefix##_b9,&/*z180_device::*/prefix##_ba,&/*z180_device::*/prefix##_bb,&/*z180_device::*/prefix##_bc,&/*z180_device::*/prefix##_bd,&/*z180_device::*/prefix##_be,&/*z180_device::*/prefix##_bf, \
- &/*z180_device::*/prefix##_c0,&/*z180_device::*/prefix##_c1,&/*z180_device::*/prefix##_c2,&/*z180_device::*/prefix##_c3,&/*z180_device::*/prefix##_c4,&/*z180_device::*/prefix##_c5,&/*z180_device::*/prefix##_c6,&/*z180_device::*/prefix##_c7, \
- &/*z180_device::*/prefix##_c8,&/*z180_device::*/prefix##_c9,&/*z180_device::*/prefix##_ca,&/*z180_device::*/prefix##_cb,&/*z180_device::*/prefix##_cc,&/*z180_device::*/prefix##_cd,&/*z180_device::*/prefix##_ce,&/*z180_device::*/prefix##_cf, \
- &/*z180_device::*/prefix##_d0,&/*z180_device::*/prefix##_d1,&/*z180_device::*/prefix##_d2,&/*z180_device::*/prefix##_d3,&/*z180_device::*/prefix##_d4,&/*z180_device::*/prefix##_d5,&/*z180_device::*/prefix##_d6,&/*z180_device::*/prefix##_d7, \
- &/*z180_device::*/prefix##_d8,&/*z180_device::*/prefix##_d9,&/*z180_device::*/prefix##_da,&/*z180_device::*/prefix##_db,&/*z180_device::*/prefix##_dc,&/*z180_device::*/prefix##_dd,&/*z180_device::*/prefix##_de,&/*z180_device::*/prefix##_df, \
- &/*z180_device::*/prefix##_e0,&/*z180_device::*/prefix##_e1,&/*z180_device::*/prefix##_e2,&/*z180_device::*/prefix##_e3,&/*z180_device::*/prefix##_e4,&/*z180_device::*/prefix##_e5,&/*z180_device::*/prefix##_e6,&/*z180_device::*/prefix##_e7, \
- &/*z180_device::*/prefix##_e8,&/*z180_device::*/prefix##_e9,&/*z180_device::*/prefix##_ea,&/*z180_device::*/prefix##_eb,&/*z180_device::*/prefix##_ec,&/*z180_device::*/prefix##_ed,&/*z180_device::*/prefix##_ee,&/*z180_device::*/prefix##_ef, \
- &/*z180_device::*/prefix##_f0,&/*z180_device::*/prefix##_f1,&/*z180_device::*/prefix##_f2,&/*z180_device::*/prefix##_f3,&/*z180_device::*/prefix##_f4,&/*z180_device::*/prefix##_f5,&/*z180_device::*/prefix##_f6,&/*z180_device::*/prefix##_f7, \
- &/*z180_device::*/prefix##_f8,&/*z180_device::*/prefix##_f9,&/*z180_device::*/prefix##_fa,&/*z180_device::*/prefix##_fb,&/*z180_device::*/prefix##_fc,&/*z180_device::*/prefix##_fd,&/*z180_device::*/prefix##_fe,&/*z180_device::*/prefix##_ff \
+ &z180_device_##prefix##_00,&z180_device_##prefix##_01,&z180_device_##prefix##_02,&z180_device_##prefix##_03,&z180_device_##prefix##_04,&z180_device_##prefix##_05,&z180_device_##prefix##_06,&z180_device_##prefix##_07, \
+ &z180_device_##prefix##_08,&z180_device_##prefix##_09,&z180_device_##prefix##_0a,&z180_device_##prefix##_0b,&z180_device_##prefix##_0c,&z180_device_##prefix##_0d,&z180_device_##prefix##_0e,&z180_device_##prefix##_0f, \
+ &z180_device_##prefix##_10,&z180_device_##prefix##_11,&z180_device_##prefix##_12,&z180_device_##prefix##_13,&z180_device_##prefix##_14,&z180_device_##prefix##_15,&z180_device_##prefix##_16,&z180_device_##prefix##_17, \
+ &z180_device_##prefix##_18,&z180_device_##prefix##_19,&z180_device_##prefix##_1a,&z180_device_##prefix##_1b,&z180_device_##prefix##_1c,&z180_device_##prefix##_1d,&z180_device_##prefix##_1e,&z180_device_##prefix##_1f, \
+ &z180_device_##prefix##_20,&z180_device_##prefix##_21,&z180_device_##prefix##_22,&z180_device_##prefix##_23,&z180_device_##prefix##_24,&z180_device_##prefix##_25,&z180_device_##prefix##_26,&z180_device_##prefix##_27, \
+ &z180_device_##prefix##_28,&z180_device_##prefix##_29,&z180_device_##prefix##_2a,&z180_device_##prefix##_2b,&z180_device_##prefix##_2c,&z180_device_##prefix##_2d,&z180_device_##prefix##_2e,&z180_device_##prefix##_2f, \
+ &z180_device_##prefix##_30,&z180_device_##prefix##_31,&z180_device_##prefix##_32,&z180_device_##prefix##_33,&z180_device_##prefix##_34,&z180_device_##prefix##_35,&z180_device_##prefix##_36,&z180_device_##prefix##_37, \
+ &z180_device_##prefix##_38,&z180_device_##prefix##_39,&z180_device_##prefix##_3a,&z180_device_##prefix##_3b,&z180_device_##prefix##_3c,&z180_device_##prefix##_3d,&z180_device_##prefix##_3e,&z180_device_##prefix##_3f, \
+ &z180_device_##prefix##_40,&z180_device_##prefix##_41,&z180_device_##prefix##_42,&z180_device_##prefix##_43,&z180_device_##prefix##_44,&z180_device_##prefix##_45,&z180_device_##prefix##_46,&z180_device_##prefix##_47, \
+ &z180_device_##prefix##_48,&z180_device_##prefix##_49,&z180_device_##prefix##_4a,&z180_device_##prefix##_4b,&z180_device_##prefix##_4c,&z180_device_##prefix##_4d,&z180_device_##prefix##_4e,&z180_device_##prefix##_4f, \
+ &z180_device_##prefix##_50,&z180_device_##prefix##_51,&z180_device_##prefix##_52,&z180_device_##prefix##_53,&z180_device_##prefix##_54,&z180_device_##prefix##_55,&z180_device_##prefix##_56,&z180_device_##prefix##_57, \
+ &z180_device_##prefix##_58,&z180_device_##prefix##_59,&z180_device_##prefix##_5a,&z180_device_##prefix##_5b,&z180_device_##prefix##_5c,&z180_device_##prefix##_5d,&z180_device_##prefix##_5e,&z180_device_##prefix##_5f, \
+ &z180_device_##prefix##_60,&z180_device_##prefix##_61,&z180_device_##prefix##_62,&z180_device_##prefix##_63,&z180_device_##prefix##_64,&z180_device_##prefix##_65,&z180_device_##prefix##_66,&z180_device_##prefix##_67, \
+ &z180_device_##prefix##_68,&z180_device_##prefix##_69,&z180_device_##prefix##_6a,&z180_device_##prefix##_6b,&z180_device_##prefix##_6c,&z180_device_##prefix##_6d,&z180_device_##prefix##_6e,&z180_device_##prefix##_6f, \
+ &z180_device_##prefix##_70,&z180_device_##prefix##_71,&z180_device_##prefix##_72,&z180_device_##prefix##_73,&z180_device_##prefix##_74,&z180_device_##prefix##_75,&z180_device_##prefix##_76,&z180_device_##prefix##_77, \
+ &z180_device_##prefix##_78,&z180_device_##prefix##_79,&z180_device_##prefix##_7a,&z180_device_##prefix##_7b,&z180_device_##prefix##_7c,&z180_device_##prefix##_7d,&z180_device_##prefix##_7e,&z180_device_##prefix##_7f, \
+ &z180_device_##prefix##_80,&z180_device_##prefix##_81,&z180_device_##prefix##_82,&z180_device_##prefix##_83,&z180_device_##prefix##_84,&z180_device_##prefix##_85,&z180_device_##prefix##_86,&z180_device_##prefix##_87, \
+ &z180_device_##prefix##_88,&z180_device_##prefix##_89,&z180_device_##prefix##_8a,&z180_device_##prefix##_8b,&z180_device_##prefix##_8c,&z180_device_##prefix##_8d,&z180_device_##prefix##_8e,&z180_device_##prefix##_8f, \
+ &z180_device_##prefix##_90,&z180_device_##prefix##_91,&z180_device_##prefix##_92,&z180_device_##prefix##_93,&z180_device_##prefix##_94,&z180_device_##prefix##_95,&z180_device_##prefix##_96,&z180_device_##prefix##_97, \
+ &z180_device_##prefix##_98,&z180_device_##prefix##_99,&z180_device_##prefix##_9a,&z180_device_##prefix##_9b,&z180_device_##prefix##_9c,&z180_device_##prefix##_9d,&z180_device_##prefix##_9e,&z180_device_##prefix##_9f, \
+ &z180_device_##prefix##_a0,&z180_device_##prefix##_a1,&z180_device_##prefix##_a2,&z180_device_##prefix##_a3,&z180_device_##prefix##_a4,&z180_device_##prefix##_a5,&z180_device_##prefix##_a6,&z180_device_##prefix##_a7, \
+ &z180_device_##prefix##_a8,&z180_device_##prefix##_a9,&z180_device_##prefix##_aa,&z180_device_##prefix##_ab,&z180_device_##prefix##_ac,&z180_device_##prefix##_ad,&z180_device_##prefix##_ae,&z180_device_##prefix##_af, \
+ &z180_device_##prefix##_b0,&z180_device_##prefix##_b1,&z180_device_##prefix##_b2,&z180_device_##prefix##_b3,&z180_device_##prefix##_b4,&z180_device_##prefix##_b5,&z180_device_##prefix##_b6,&z180_device_##prefix##_b7, \
+ &z180_device_##prefix##_b8,&z180_device_##prefix##_b9,&z180_device_##prefix##_ba,&z180_device_##prefix##_bb,&z180_device_##prefix##_bc,&z180_device_##prefix##_bd,&z180_device_##prefix##_be,&z180_device_##prefix##_bf, \
+ &z180_device_##prefix##_c0,&z180_device_##prefix##_c1,&z180_device_##prefix##_c2,&z180_device_##prefix##_c3,&z180_device_##prefix##_c4,&z180_device_##prefix##_c5,&z180_device_##prefix##_c6,&z180_device_##prefix##_c7, \
+ &z180_device_##prefix##_c8,&z180_device_##prefix##_c9,&z180_device_##prefix##_ca,&z180_device_##prefix##_cb,&z180_device_##prefix##_cc,&z180_device_##prefix##_cd,&z180_device_##prefix##_ce,&z180_device_##prefix##_cf, \
+ &z180_device_##prefix##_d0,&z180_device_##prefix##_d1,&z180_device_##prefix##_d2,&z180_device_##prefix##_d3,&z180_device_##prefix##_d4,&z180_device_##prefix##_d5,&z180_device_##prefix##_d6,&z180_device_##prefix##_d7, \
+ &z180_device_##prefix##_d8,&z180_device_##prefix##_d9,&z180_device_##prefix##_da,&z180_device_##prefix##_db,&z180_device_##prefix##_dc,&z180_device_##prefix##_dd,&z180_device_##prefix##_de,&z180_device_##prefix##_df, \
+ &z180_device_##prefix##_e0,&z180_device_##prefix##_e1,&z180_device_##prefix##_e2,&z180_device_##prefix##_e3,&z180_device_##prefix##_e4,&z180_device_##prefix##_e5,&z180_device_##prefix##_e6,&z180_device_##prefix##_e7, \
+ &z180_device_##prefix##_e8,&z180_device_##prefix##_e9,&z180_device_##prefix##_ea,&z180_device_##prefix##_eb,&z180_device_##prefix##_ec,&z180_device_##prefix##_ed,&z180_device_##prefix##_ee,&z180_device_##prefix##_ef, \
+ &z180_device_##prefix##_f0,&z180_device_##prefix##_f1,&z180_device_##prefix##_f2,&z180_device_##prefix##_f3,&z180_device_##prefix##_f4,&z180_device_##prefix##_f5,&z180_device_##prefix##_f6,&z180_device_##prefix##_f7, \
+ &z180_device_##prefix##_f8,&z180_device_##prefix##_f9,&z180_device_##prefix##_fa,&z180_device_##prefix##_fb,&z180_device_##prefix##_fc,&z180_device_##prefix##_fd,&z180_device_##prefix##_fe,&z180_device_##prefix##_ff \
}
-const /*z180_device::*/opcode_func /*z180_device::*/s_z180ops[Z180_PREFIX_COUNT][0x100] =
+const z180_device_opcode_func z180_device_s_z180ops[Z180_PREFIX_COUNT][0x100] =
{
TABLE(op),
TABLE(cb),
/***************************************************************
* define an opcode function
***************************************************************/
-#define OP(prefix,opcode) void /*z180_device::*/prefix##_##opcode()
+#define OP(prefix,opcode) void z180_device_##prefix##_##opcode()
/***************************************************************
* adjust cycle count by n T-states
***************************************************************/
#define EXEC_PROTOTYPE(prefix) \
-int /*z180_device::*/exec##_##prefix(const uint8_t opcode) \
+int z180_device_exec##_##prefix(const uint8_t opcode) \
{ \
- (/*this->*/*s_z180ops[Z180_PREFIX_##prefix][opcode])(); \
+ (/*this->*/*z180_device_s_z180ops[Z180_PREFIX_##prefix][opcode])(); \
return m_cc[Z180_TABLE_##prefix][opcode]; \
}
* opcodes with DD/FD CB prefix
* rotate, shift and bit operations with (IX+o)
**********************************************************/
-OP(xycb,00) { _B = RLC(RM(m_ea) ); WM( m_ea,_B ); } /* RLC B=(XY+o) */
-OP(xycb,01) { _C = RLC(RM(m_ea) ); WM( m_ea,_C ); } /* RLC C=(XY+o) */
-OP(xycb,02) { _D = RLC(RM(m_ea) ); WM( m_ea,_D ); } /* RLC D=(XY+o) */
-OP(xycb,03) { _E = RLC(RM(m_ea) ); WM( m_ea,_E ); } /* RLC E=(XY+o) */
-OP(xycb,04) { _H = RLC(RM(m_ea) ); WM( m_ea,_H ); } /* RLC H=(XY+o) */
-OP(xycb,05) { _L = RLC(RM(m_ea) ); WM( m_ea,_L ); } /* RLC L=(XY+o) */
-OP(xycb,06) { WM( m_ea, RLC(RM(m_ea) ) ); } /* RLC (XY+o) */
-OP(xycb,07) { _A = RLC(RM(m_ea) ); WM( m_ea,_A ); } /* RLC A=(XY+o) */
+OP(xycb,00) { _B = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RLC B=(XY+o) */
+OP(xycb,01) { _C = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RLC C=(XY+o) */
+OP(xycb,02) { _D = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RLC D=(XY+o) */
+OP(xycb,03) { _E = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RLC E=(XY+o) */
+OP(xycb,04) { _H = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RLC H=(XY+o) */
+OP(xycb,05) { _L = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RLC L=(XY+o) */
+OP(xycb,06) { WM( m_ea, z180_device_RLC(z180_device_RM(m_ea) ) ); } /* RLC (XY+o) */
+OP(xycb,07) { _A = z180_device_RLC(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RLC A=(XY+o) */
-OP(xycb,08) { _B = RRC(RM(m_ea) ); WM( m_ea,_B ); } /* RRC B=(XY+o) */
-OP(xycb,09) { _C = RRC(RM(m_ea) ); WM( m_ea,_C ); } /* RRC C=(XY+o) */
-OP(xycb,0a) { _D = RRC(RM(m_ea) ); WM( m_ea,_D ); } /* RRC D=(XY+o) */
-OP(xycb,0b) { _E = RRC(RM(m_ea) ); WM( m_ea,_E ); } /* RRC E=(XY+o) */
-OP(xycb,0c) { _H = RRC(RM(m_ea) ); WM( m_ea,_H ); } /* RRC H=(XY+o) */
-OP(xycb,0d) { _L = RRC(RM(m_ea) ); WM( m_ea,_L ); } /* RRC L=(XY+o) */
-OP(xycb,0e) { WM( m_ea,RRC(RM(m_ea) ) ); } /* RRC (XY+o) */
-OP(xycb,0f) { _A = RRC(RM(m_ea) ); WM( m_ea,_A ); } /* RRC A=(XY+o) */
+OP(xycb,08) { _B = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RRC B=(XY+o) */
+OP(xycb,09) { _C = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RRC C=(XY+o) */
+OP(xycb,0a) { _D = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RRC D=(XY+o) */
+OP(xycb,0b) { _E = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RRC E=(XY+o) */
+OP(xycb,0c) { _H = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RRC H=(XY+o) */
+OP(xycb,0d) { _L = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RRC L=(XY+o) */
+OP(xycb,0e) { WM( m_ea,z180_device_RRC(z180_device_RM(m_ea) ) ); } /* RRC (XY+o) */
+OP(xycb,0f) { _A = z180_device_RRC(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RRC A=(XY+o) */
-OP(xycb,10) { _B = RL(RM(m_ea) ); WM( m_ea,_B ); } /* RL B=(XY+o) */
-OP(xycb,11) { _C = RL(RM(m_ea) ); WM( m_ea,_C ); } /* RL C=(XY+o) */
-OP(xycb,12) { _D = RL(RM(m_ea) ); WM( m_ea,_D ); } /* RL D=(XY+o) */
-OP(xycb,13) { _E = RL(RM(m_ea) ); WM( m_ea,_E ); } /* RL E=(XY+o) */
-OP(xycb,14) { _H = RL(RM(m_ea) ); WM( m_ea,_H ); } /* RL H=(XY+o) */
-OP(xycb,15) { _L = RL(RM(m_ea) ); WM( m_ea,_L ); } /* RL L=(XY+o) */
-OP(xycb,16) { WM( m_ea,RL(RM(m_ea) ) ); } /* RL (XY+o) */
-OP(xycb,17) { _A = RL(RM(m_ea) ); WM( m_ea,_A ); } /* RL A=(XY+o) */
+OP(xycb,10) { _B = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RL B=(XY+o) */
+OP(xycb,11) { _C = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RL C=(XY+o) */
+OP(xycb,12) { _D = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RL D=(XY+o) */
+OP(xycb,13) { _E = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RL E=(XY+o) */
+OP(xycb,14) { _H = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RL H=(XY+o) */
+OP(xycb,15) { _L = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RL L=(XY+o) */
+OP(xycb,16) { WM( m_ea,z180_device_RL(z180_device_RM(m_ea) ) ); } /* RL (XY+o) */
+OP(xycb,17) { _A = z180_device_RL(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RL A=(XY+o) */
-OP(xycb,18) { _B = RR(RM(m_ea) ); WM( m_ea,_B ); } /* RR B=(XY+o) */
-OP(xycb,19) { _C = RR(RM(m_ea) ); WM( m_ea,_C ); } /* RR C=(XY+o) */
-OP(xycb,1a) { _D = RR(RM(m_ea) ); WM( m_ea,_D ); } /* RR D=(XY+o) */
-OP(xycb,1b) { _E = RR(RM(m_ea) ); WM( m_ea,_E ); } /* RR E=(XY+o) */
-OP(xycb,1c) { _H = RR(RM(m_ea) ); WM( m_ea,_H ); } /* RR H=(XY+o) */
-OP(xycb,1d) { _L = RR(RM(m_ea) ); WM( m_ea,_L ); } /* RR L=(XY+o) */
-OP(xycb,1e) { WM( m_ea,RR(RM(m_ea) ) ); } /* RR (XY+o) */
-OP(xycb,1f) { _A = RR(RM(m_ea) ); WM( m_ea,_A ); } /* RR A=(XY+o) */
+OP(xycb,18) { _B = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RR B=(XY+o) */
+OP(xycb,19) { _C = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RR C=(XY+o) */
+OP(xycb,1a) { _D = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RR D=(XY+o) */
+OP(xycb,1b) { _E = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RR E=(XY+o) */
+OP(xycb,1c) { _H = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RR H=(XY+o) */
+OP(xycb,1d) { _L = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RR L=(XY+o) */
+OP(xycb,1e) { WM( m_ea,z180_device_RR(z180_device_RM(m_ea) ) ); } /* RR (XY+o) */
+OP(xycb,1f) { _A = z180_device_RR(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RR A=(XY+o) */
-OP(xycb,20) { _B = SLA(RM(m_ea) ); WM( m_ea,_B ); } /* SLA B=(XY+o) */
-OP(xycb,21) { _C = SLA(RM(m_ea) ); WM( m_ea,_C ); } /* SLA C=(XY+o) */
-OP(xycb,22) { _D = SLA(RM(m_ea) ); WM( m_ea,_D ); } /* SLA D=(XY+o) */
-OP(xycb,23) { _E = SLA(RM(m_ea) ); WM( m_ea,_E ); } /* SLA E=(XY+o) */
-OP(xycb,24) { _H = SLA(RM(m_ea) ); WM( m_ea,_H ); } /* SLA H=(XY+o) */
-OP(xycb,25) { _L = SLA(RM(m_ea) ); WM( m_ea,_L ); } /* SLA L=(XY+o) */
-OP(xycb,26) { WM( m_ea,SLA(RM(m_ea) ) ); } /* SLA (XY+o) */
-OP(xycb,27) { _A = SLA(RM(m_ea) ); WM( m_ea,_A ); } /* SLA A=(XY+o) */
+OP(xycb,20) { _B = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SLA B=(XY+o) */
+OP(xycb,21) { _C = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SLA C=(XY+o) */
+OP(xycb,22) { _D = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SLA D=(XY+o) */
+OP(xycb,23) { _E = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SLA E=(XY+o) */
+OP(xycb,24) { _H = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SLA H=(XY+o) */
+OP(xycb,25) { _L = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SLA L=(XY+o) */
+OP(xycb,26) { WM( m_ea,z180_device_SLA(z180_device_RM(m_ea) ) ); } /* SLA (XY+o) */
+OP(xycb,27) { _A = z180_device_SLA(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SLA A=(XY+o) */
-OP(xycb,28) { _B = SRA(RM(m_ea) ); WM( m_ea,_B ); } /* SRA B=(XY+o) */
-OP(xycb,29) { _C = SRA(RM(m_ea) ); WM( m_ea,_C ); } /* SRA C=(XY+o) */
-OP(xycb,2a) { _D = SRA(RM(m_ea) ); WM( m_ea,_D ); } /* SRA D=(XY+o) */
-OP(xycb,2b) { _E = SRA(RM(m_ea) ); WM( m_ea,_E ); } /* SRA E=(XY+o) */
-OP(xycb,2c) { _H = SRA(RM(m_ea) ); WM( m_ea,_H ); } /* SRA H=(XY+o) */
-OP(xycb,2d) { _L = SRA(RM(m_ea) ); WM( m_ea,_L ); } /* SRA L=(XY+o) */
-OP(xycb,2e) { WM( m_ea,SRA(RM(m_ea) ) ); } /* SRA (XY+o) */
-OP(xycb,2f) { _A = SRA(RM(m_ea) ); WM( m_ea,_A ); } /* SRA A=(XY+o) */
+OP(xycb,28) { _B = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SRA B=(XY+o) */
+OP(xycb,29) { _C = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SRA C=(XY+o) */
+OP(xycb,2a) { _D = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SRA D=(XY+o) */
+OP(xycb,2b) { _E = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SRA E=(XY+o) */
+OP(xycb,2c) { _H = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SRA H=(XY+o) */
+OP(xycb,2d) { _L = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SRA L=(XY+o) */
+OP(xycb,2e) { WM( m_ea,z180_device_SRA(z180_device_RM(m_ea) ) ); } /* SRA (XY+o) */
+OP(xycb,2f) { _A = z180_device_SRA(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SRA A=(XY+o) */
-OP(xycb,30) { _B = SLL(RM(m_ea) ); WM( m_ea,_B ); } /* SLL B=(XY+o) */
-OP(xycb,31) { _C = SLL(RM(m_ea) ); WM( m_ea,_C ); } /* SLL C=(XY+o) */
-OP(xycb,32) { _D = SLL(RM(m_ea) ); WM( m_ea,_D ); } /* SLL D=(XY+o) */
-OP(xycb,33) { _E = SLL(RM(m_ea) ); WM( m_ea,_E ); } /* SLL E=(XY+o) */
-OP(xycb,34) { _H = SLL(RM(m_ea) ); WM( m_ea,_H ); } /* SLL H=(XY+o) */
-OP(xycb,35) { _L = SLL(RM(m_ea) ); WM( m_ea,_L ); } /* SLL L=(XY+o) */
-OP(xycb,36) { WM( m_ea,SLL(RM(m_ea) ) ); } /* SLL (XY+o) */
-OP(xycb,37) { _A = SLL(RM(m_ea) ); WM( m_ea,_A ); } /* SLL A=(XY+o) */
+OP(xycb,30) { _B = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SLL B=(XY+o) */
+OP(xycb,31) { _C = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SLL C=(XY+o) */
+OP(xycb,32) { _D = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SLL D=(XY+o) */
+OP(xycb,33) { _E = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SLL E=(XY+o) */
+OP(xycb,34) { _H = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SLL H=(XY+o) */
+OP(xycb,35) { _L = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SLL L=(XY+o) */
+OP(xycb,36) { WM( m_ea,z180_device_SLL(z180_device_RM(m_ea) ) ); } /* SLL (XY+o) */
+OP(xycb,37) { _A = z180_device_SLL(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SLL A=(XY+o) */
-OP(xycb,38) { _B = SRL(RM(m_ea) ); WM( m_ea,_B ); } /* SRL B=(XY+o) */
-OP(xycb,39) { _C = SRL(RM(m_ea) ); WM( m_ea,_C ); } /* SRL C=(XY+o) */
-OP(xycb,3a) { _D = SRL(RM(m_ea) ); WM( m_ea,_D ); } /* SRL D=(XY+o) */
-OP(xycb,3b) { _E = SRL(RM(m_ea) ); WM( m_ea,_E ); } /* SRL E=(XY+o) */
-OP(xycb,3c) { _H = SRL(RM(m_ea) ); WM( m_ea,_H ); } /* SRL H=(XY+o) */
-OP(xycb,3d) { _L = SRL(RM(m_ea) ); WM( m_ea,_L ); } /* SRL L=(XY+o) */
-OP(xycb,3e) { WM( m_ea,SRL(RM(m_ea) ) ); } /* SRL (XY+o) */
-OP(xycb,3f) { _A = SRL(RM(m_ea) ); WM( m_ea,_A ); } /* SRL A=(XY+o) */
+OP(xycb,38) { _B = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SRL B=(XY+o) */
+OP(xycb,39) { _C = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SRL C=(XY+o) */
+OP(xycb,3a) { _D = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SRL D=(XY+o) */
+OP(xycb,3b) { _E = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SRL E=(XY+o) */
+OP(xycb,3c) { _H = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SRL H=(XY+o) */
+OP(xycb,3d) { _L = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SRL L=(XY+o) */
+OP(xycb,3e) { WM( m_ea,z180_device_SRL(z180_device_RM(m_ea) ) ); } /* SRL (XY+o) */
+OP(xycb,3f) { _A = z180_device_SRL(z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SRL A=(XY+o) */
-OP(xycb,40) { xycb_46(); } /* BIT 0,B=(XY+o) */
-OP(xycb,41) { xycb_46(); } /* BIT 0,C=(XY+o) */
-OP(xycb,42) { xycb_46(); } /* BIT 0,D=(XY+o) */
-OP(xycb,43) { xycb_46(); } /* BIT 0,E=(XY+o) */
-OP(xycb,44) { xycb_46(); } /* BIT 0,H=(XY+o) */
-OP(xycb,45) { xycb_46(); } /* BIT 0,L=(XY+o) */
-OP(xycb,46) { BIT_XY(0,RM(m_ea)); } /* BIT 0,(XY+o) */
-OP(xycb,47) { xycb_46(); } /* BIT 0,A=(XY+o) */
+OP(xycb,40) { z180_device_xycb_46(); } /* BIT 0,B=(XY+o) */
+OP(xycb,41) { z180_device_xycb_46(); } /* BIT 0,C=(XY+o) */
+OP(xycb,42) { z180_device_xycb_46(); } /* BIT 0,D=(XY+o) */
+OP(xycb,43) { z180_device_xycb_46(); } /* BIT 0,E=(XY+o) */
+OP(xycb,44) { z180_device_xycb_46(); } /* BIT 0,H=(XY+o) */
+OP(xycb,45) { z180_device_xycb_46(); } /* BIT 0,L=(XY+o) */
+OP(xycb,46) { BIT_XY(0,z180_device_RM(m_ea)); } /* BIT 0,(XY+o) */
+OP(xycb,47) { z180_device_xycb_46(); } /* BIT 0,A=(XY+o) */
-OP(xycb,48) { xycb_4e(); } /* BIT 1,B=(XY+o) */
-OP(xycb,49) { xycb_4e(); } /* BIT 1,C=(XY+o) */
-OP(xycb,4a) { xycb_4e(); } /* BIT 1,D=(XY+o) */
-OP(xycb,4b) { xycb_4e(); } /* BIT 1,E=(XY+o) */
-OP(xycb,4c) { xycb_4e(); } /* BIT 1,H=(XY+o) */
-OP(xycb,4d) { xycb_4e(); } /* BIT 1,L=(XY+o) */
-OP(xycb,4e) { BIT_XY(1,RM(m_ea)); } /* BIT 1,(XY+o) */
-OP(xycb,4f) { xycb_4e(); } /* BIT 1,A=(XY+o) */
+OP(xycb,48) { z180_device_xycb_4e(); } /* BIT 1,B=(XY+o) */
+OP(xycb,49) { z180_device_xycb_4e(); } /* BIT 1,C=(XY+o) */
+OP(xycb,4a) { z180_device_xycb_4e(); } /* BIT 1,D=(XY+o) */
+OP(xycb,4b) { z180_device_xycb_4e(); } /* BIT 1,E=(XY+o) */
+OP(xycb,4c) { z180_device_xycb_4e(); } /* BIT 1,H=(XY+o) */
+OP(xycb,4d) { z180_device_xycb_4e(); } /* BIT 1,L=(XY+o) */
+OP(xycb,4e) { BIT_XY(1,z180_device_RM(m_ea)); } /* BIT 1,(XY+o) */
+OP(xycb,4f) { z180_device_xycb_4e(); } /* BIT 1,A=(XY+o) */
-OP(xycb,50) { xycb_56(); } /* BIT 2,B=(XY+o) */
-OP(xycb,51) { xycb_56(); } /* BIT 2,C=(XY+o) */
-OP(xycb,52) { xycb_56(); } /* BIT 2,D=(XY+o) */
-OP(xycb,53) { xycb_56(); } /* BIT 2,E=(XY+o) */
-OP(xycb,54) { xycb_56(); } /* BIT 2,H=(XY+o) */
-OP(xycb,55) { xycb_56(); } /* BIT 2,L=(XY+o) */
-OP(xycb,56) { BIT_XY(2,RM(m_ea)); } /* BIT 2,(XY+o) */
-OP(xycb,57) { xycb_56(); } /* BIT 2,A=(XY+o) */
+OP(xycb,50) { z180_device_xycb_56(); } /* BIT 2,B=(XY+o) */
+OP(xycb,51) { z180_device_xycb_56(); } /* BIT 2,C=(XY+o) */
+OP(xycb,52) { z180_device_xycb_56(); } /* BIT 2,D=(XY+o) */
+OP(xycb,53) { z180_device_xycb_56(); } /* BIT 2,E=(XY+o) */
+OP(xycb,54) { z180_device_xycb_56(); } /* BIT 2,H=(XY+o) */
+OP(xycb,55) { z180_device_xycb_56(); } /* BIT 2,L=(XY+o) */
+OP(xycb,56) { BIT_XY(2,z180_device_RM(m_ea)); } /* BIT 2,(XY+o) */
+OP(xycb,57) { z180_device_xycb_56(); } /* BIT 2,A=(XY+o) */
-OP(xycb,58) { xycb_5e(); } /* BIT 3,B=(XY+o) */
-OP(xycb,59) { xycb_5e(); } /* BIT 3,C=(XY+o) */
-OP(xycb,5a) { xycb_5e(); } /* BIT 3,D=(XY+o) */
-OP(xycb,5b) { xycb_5e(); } /* BIT 3,E=(XY+o) */
-OP(xycb,5c) { xycb_5e(); } /* BIT 3,H=(XY+o) */
-OP(xycb,5d) { xycb_5e(); } /* BIT 3,L=(XY+o) */
-OP(xycb,5e) { BIT_XY(3,RM(m_ea)); } /* BIT 3,(XY+o) */
-OP(xycb,5f) { xycb_5e(); } /* BIT 3,A=(XY+o) */
+OP(xycb,58) { z180_device_xycb_5e(); } /* BIT 3,B=(XY+o) */
+OP(xycb,59) { z180_device_xycb_5e(); } /* BIT 3,C=(XY+o) */
+OP(xycb,5a) { z180_device_xycb_5e(); } /* BIT 3,D=(XY+o) */
+OP(xycb,5b) { z180_device_xycb_5e(); } /* BIT 3,E=(XY+o) */
+OP(xycb,5c) { z180_device_xycb_5e(); } /* BIT 3,H=(XY+o) */
+OP(xycb,5d) { z180_device_xycb_5e(); } /* BIT 3,L=(XY+o) */
+OP(xycb,5e) { BIT_XY(3,z180_device_RM(m_ea)); } /* BIT 3,(XY+o) */
+OP(xycb,5f) { z180_device_xycb_5e(); } /* BIT 3,A=(XY+o) */
-OP(xycb,60) { xycb_66(); } /* BIT 4,B=(XY+o) */
-OP(xycb,61) { xycb_66(); } /* BIT 4,C=(XY+o) */
-OP(xycb,62) { xycb_66(); } /* BIT 4,D=(XY+o) */
-OP(xycb,63) { xycb_66(); } /* BIT 4,E=(XY+o) */
-OP(xycb,64) { xycb_66(); } /* BIT 4,H=(XY+o) */
-OP(xycb,65) { xycb_66(); } /* BIT 4,L=(XY+o) */
-OP(xycb,66) { BIT_XY(4,RM(m_ea)); } /* BIT 4,(XY+o) */
-OP(xycb,67) { xycb_66(); } /* BIT 4,A=(XY+o) */
+OP(xycb,60) { z180_device_xycb_66(); } /* BIT 4,B=(XY+o) */
+OP(xycb,61) { z180_device_xycb_66(); } /* BIT 4,C=(XY+o) */
+OP(xycb,62) { z180_device_xycb_66(); } /* BIT 4,D=(XY+o) */
+OP(xycb,63) { z180_device_xycb_66(); } /* BIT 4,E=(XY+o) */
+OP(xycb,64) { z180_device_xycb_66(); } /* BIT 4,H=(XY+o) */
+OP(xycb,65) { z180_device_xycb_66(); } /* BIT 4,L=(XY+o) */
+OP(xycb,66) { BIT_XY(4,z180_device_RM(m_ea)); } /* BIT 4,(XY+o) */
+OP(xycb,67) { z180_device_xycb_66(); } /* BIT 4,A=(XY+o) */
-OP(xycb,68) { xycb_6e(); } /* BIT 5,B=(XY+o) */
-OP(xycb,69) { xycb_6e(); } /* BIT 5,C=(XY+o) */
-OP(xycb,6a) { xycb_6e(); } /* BIT 5,D=(XY+o) */
-OP(xycb,6b) { xycb_6e(); } /* BIT 5,E=(XY+o) */
-OP(xycb,6c) { xycb_6e(); } /* BIT 5,H=(XY+o) */
-OP(xycb,6d) { xycb_6e(); } /* BIT 5,L=(XY+o) */
-OP(xycb,6e) { BIT_XY(5,RM(m_ea)); } /* BIT 5,(XY+o) */
-OP(xycb,6f) { xycb_6e(); } /* BIT 5,A=(XY+o) */
+OP(xycb,68) { z180_device_xycb_6e(); } /* BIT 5,B=(XY+o) */
+OP(xycb,69) { z180_device_xycb_6e(); } /* BIT 5,C=(XY+o) */
+OP(xycb,6a) { z180_device_xycb_6e(); } /* BIT 5,D=(XY+o) */
+OP(xycb,6b) { z180_device_xycb_6e(); } /* BIT 5,E=(XY+o) */
+OP(xycb,6c) { z180_device_xycb_6e(); } /* BIT 5,H=(XY+o) */
+OP(xycb,6d) { z180_device_xycb_6e(); } /* BIT 5,L=(XY+o) */
+OP(xycb,6e) { BIT_XY(5,z180_device_RM(m_ea)); } /* BIT 5,(XY+o) */
+OP(xycb,6f) { z180_device_xycb_6e(); } /* BIT 5,A=(XY+o) */
-OP(xycb,70) { xycb_76(); } /* BIT 6,B=(XY+o) */
-OP(xycb,71) { xycb_76(); } /* BIT 6,C=(XY+o) */
-OP(xycb,72) { xycb_76(); } /* BIT 6,D=(XY+o) */
-OP(xycb,73) { xycb_76(); } /* BIT 6,E=(XY+o) */
-OP(xycb,74) { xycb_76(); } /* BIT 6,H=(XY+o) */
-OP(xycb,75) { xycb_76(); } /* BIT 6,L=(XY+o) */
-OP(xycb,76) { BIT_XY(6,RM(m_ea)); } /* BIT 6,(XY+o) */
-OP(xycb,77) { xycb_76(); } /* BIT 6,A=(XY+o) */
+OP(xycb,70) { z180_device_xycb_76(); } /* BIT 6,B=(XY+o) */
+OP(xycb,71) { z180_device_xycb_76(); } /* BIT 6,C=(XY+o) */
+OP(xycb,72) { z180_device_xycb_76(); } /* BIT 6,D=(XY+o) */
+OP(xycb,73) { z180_device_xycb_76(); } /* BIT 6,E=(XY+o) */
+OP(xycb,74) { z180_device_xycb_76(); } /* BIT 6,H=(XY+o) */
+OP(xycb,75) { z180_device_xycb_76(); } /* BIT 6,L=(XY+o) */
+OP(xycb,76) { BIT_XY(6,z180_device_RM(m_ea)); } /* BIT 6,(XY+o) */
+OP(xycb,77) { z180_device_xycb_76(); } /* BIT 6,A=(XY+o) */
-OP(xycb,78) { xycb_7e(); } /* BIT 7,B=(XY+o) */
-OP(xycb,79) { xycb_7e(); } /* BIT 7,C=(XY+o) */
-OP(xycb,7a) { xycb_7e(); } /* BIT 7,D=(XY+o) */
-OP(xycb,7b) { xycb_7e(); } /* BIT 7,E=(XY+o) */
-OP(xycb,7c) { xycb_7e(); } /* BIT 7,H=(XY+o) */
-OP(xycb,7d) { xycb_7e(); } /* BIT 7,L=(XY+o) */
-OP(xycb,7e) { BIT_XY(7,RM(m_ea)); } /* BIT 7,(XY+o) */
-OP(xycb,7f) { xycb_7e(); } /* BIT 7,A=(XY+o) */
+OP(xycb,78) { z180_device_xycb_7e(); } /* BIT 7,B=(XY+o) */
+OP(xycb,79) { z180_device_xycb_7e(); } /* BIT 7,C=(XY+o) */
+OP(xycb,7a) { z180_device_xycb_7e(); } /* BIT 7,D=(XY+o) */
+OP(xycb,7b) { z180_device_xycb_7e(); } /* BIT 7,E=(XY+o) */
+OP(xycb,7c) { z180_device_xycb_7e(); } /* BIT 7,H=(XY+o) */
+OP(xycb,7d) { z180_device_xycb_7e(); } /* BIT 7,L=(XY+o) */
+OP(xycb,7e) { BIT_XY(7,z180_device_RM(m_ea)); } /* BIT 7,(XY+o) */
+OP(xycb,7f) { z180_device_xycb_7e(); } /* BIT 7,A=(XY+o) */
-OP(xycb,80) { _B = RES(0, RM(m_ea) ); WM( m_ea,_B ); } /* RES 0,B=(XY+o) */
-OP(xycb,81) { _C = RES(0, RM(m_ea) ); WM( m_ea,_C ); } /* RES 0,C=(XY+o) */
-OP(xycb,82) { _D = RES(0, RM(m_ea) ); WM( m_ea,_D ); } /* RES 0,D=(XY+o) */
-OP(xycb,83) { _E = RES(0, RM(m_ea) ); WM( m_ea,_E ); } /* RES 0,E=(XY+o) */
-OP(xycb,84) { _H = RES(0, RM(m_ea) ); WM( m_ea,_H ); } /* RES 0,H=(XY+o) */
-OP(xycb,85) { _L = RES(0, RM(m_ea) ); WM( m_ea,_L ); } /* RES 0,L=(XY+o) */
-OP(xycb,86) { WM( m_ea, RES(0,RM(m_ea)) ); } /* RES 0,(XY+o) */
-OP(xycb,87) { _A = RES(0, RM(m_ea) ); WM( m_ea,_A ); } /* RES 0,A=(XY+o) */
+OP(xycb,80) { _B = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 0,B=(XY+o) */
+OP(xycb,81) { _C = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 0,C=(XY+o) */
+OP(xycb,82) { _D = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 0,D=(XY+o) */
+OP(xycb,83) { _E = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 0,E=(XY+o) */
+OP(xycb,84) { _H = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 0,H=(XY+o) */
+OP(xycb,85) { _L = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 0,L=(XY+o) */
+OP(xycb,86) { WM( m_ea, z180_device_RES(0,z180_device_RM(m_ea)) ); } /* RES 0,(XY+o) */
+OP(xycb,87) { _A = z180_device_RES(0, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 0,A=(XY+o) */
-OP(xycb,88) { _B = RES(1, RM(m_ea) ); WM( m_ea,_B ); } /* RES 1,B=(XY+o) */
-OP(xycb,89) { _C = RES(1, RM(m_ea) ); WM( m_ea,_C ); } /* RES 1,C=(XY+o) */
-OP(xycb,8a) { _D = RES(1, RM(m_ea) ); WM( m_ea,_D ); } /* RES 1,D=(XY+o) */
-OP(xycb,8b) { _E = RES(1, RM(m_ea) ); WM( m_ea,_E ); } /* RES 1,E=(XY+o) */
-OP(xycb,8c) { _H = RES(1, RM(m_ea) ); WM( m_ea,_H ); } /* RES 1,H=(XY+o) */
-OP(xycb,8d) { _L = RES(1, RM(m_ea) ); WM( m_ea,_L ); } /* RES 1,L=(XY+o) */
-OP(xycb,8e) { WM( m_ea, RES(1,RM(m_ea)) ); } /* RES 1,(XY+o) */
-OP(xycb,8f) { _A = RES(1, RM(m_ea) ); WM( m_ea,_A ); } /* RES 1,A=(XY+o) */
+OP(xycb,88) { _B = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 1,B=(XY+o) */
+OP(xycb,89) { _C = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 1,C=(XY+o) */
+OP(xycb,8a) { _D = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 1,D=(XY+o) */
+OP(xycb,8b) { _E = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 1,E=(XY+o) */
+OP(xycb,8c) { _H = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 1,H=(XY+o) */
+OP(xycb,8d) { _L = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 1,L=(XY+o) */
+OP(xycb,8e) { WM( m_ea, z180_device_RES(1,z180_device_RM(m_ea)) ); } /* RES 1,(XY+o) */
+OP(xycb,8f) { _A = z180_device_RES(1, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 1,A=(XY+o) */
-OP(xycb,90) { _B = RES(2, RM(m_ea) ); WM( m_ea,_B ); } /* RES 2,B=(XY+o) */
-OP(xycb,91) { _C = RES(2, RM(m_ea) ); WM( m_ea,_C ); } /* RES 2,C=(XY+o) */
-OP(xycb,92) { _D = RES(2, RM(m_ea) ); WM( m_ea,_D ); } /* RES 2,D=(XY+o) */
-OP(xycb,93) { _E = RES(2, RM(m_ea) ); WM( m_ea,_E ); } /* RES 2,E=(XY+o) */
-OP(xycb,94) { _H = RES(2, RM(m_ea) ); WM( m_ea,_H ); } /* RES 2,H=(XY+o) */
-OP(xycb,95) { _L = RES(2, RM(m_ea) ); WM( m_ea,_L ); } /* RES 2,L=(XY+o) */
-OP(xycb,96) { WM( m_ea, RES(2,RM(m_ea)) ); } /* RES 2,(XY+o) */
-OP(xycb,97) { _A = RES(2, RM(m_ea) ); WM( m_ea,_A ); } /* RES 2,A=(XY+o) */
+OP(xycb,90) { _B = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 2,B=(XY+o) */
+OP(xycb,91) { _C = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 2,C=(XY+o) */
+OP(xycb,92) { _D = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 2,D=(XY+o) */
+OP(xycb,93) { _E = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 2,E=(XY+o) */
+OP(xycb,94) { _H = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 2,H=(XY+o) */
+OP(xycb,95) { _L = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 2,L=(XY+o) */
+OP(xycb,96) { WM( m_ea, z180_device_RES(2,z180_device_RM(m_ea)) ); } /* RES 2,(XY+o) */
+OP(xycb,97) { _A = z180_device_RES(2, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 2,A=(XY+o) */
-OP(xycb,98) { _B = RES(3, RM(m_ea) ); WM( m_ea,_B ); } /* RES 3,B=(XY+o) */
-OP(xycb,99) { _C = RES(3, RM(m_ea) ); WM( m_ea,_C ); } /* RES 3,C=(XY+o) */
-OP(xycb,9a) { _D = RES(3, RM(m_ea) ); WM( m_ea,_D ); } /* RES 3,D=(XY+o) */
-OP(xycb,9b) { _E = RES(3, RM(m_ea) ); WM( m_ea,_E ); } /* RES 3,E=(XY+o) */
-OP(xycb,9c) { _H = RES(3, RM(m_ea) ); WM( m_ea,_H ); } /* RES 3,H=(XY+o) */
-OP(xycb,9d) { _L = RES(3, RM(m_ea) ); WM( m_ea,_L ); } /* RES 3,L=(XY+o) */
-OP(xycb,9e) { WM( m_ea, RES(3,RM(m_ea)) ); } /* RES 3,(XY+o) */
-OP(xycb,9f) { _A = RES(3, RM(m_ea) ); WM( m_ea,_A ); } /* RES 3,A=(XY+o) */
+OP(xycb,98) { _B = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 3,B=(XY+o) */
+OP(xycb,99) { _C = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 3,C=(XY+o) */
+OP(xycb,9a) { _D = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 3,D=(XY+o) */
+OP(xycb,9b) { _E = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 3,E=(XY+o) */
+OP(xycb,9c) { _H = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 3,H=(XY+o) */
+OP(xycb,9d) { _L = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 3,L=(XY+o) */
+OP(xycb,9e) { WM( m_ea, z180_device_RES(3,z180_device_RM(m_ea)) ); } /* RES 3,(XY+o) */
+OP(xycb,9f) { _A = z180_device_RES(3, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 3,A=(XY+o) */
-OP(xycb,a0) { _B = RES(4, RM(m_ea) ); WM( m_ea,_B ); } /* RES 4,B=(XY+o) */
-OP(xycb,a1) { _C = RES(4, RM(m_ea) ); WM( m_ea,_C ); } /* RES 4,C=(XY+o) */
-OP(xycb,a2) { _D = RES(4, RM(m_ea) ); WM( m_ea,_D ); } /* RES 4,D=(XY+o) */
-OP(xycb,a3) { _E = RES(4, RM(m_ea) ); WM( m_ea,_E ); } /* RES 4,E=(XY+o) */
-OP(xycb,a4) { _H = RES(4, RM(m_ea) ); WM( m_ea,_H ); } /* RES 4,H=(XY+o) */
-OP(xycb,a5) { _L = RES(4, RM(m_ea) ); WM( m_ea,_L ); } /* RES 4,L=(XY+o) */
-OP(xycb,a6) { WM( m_ea, RES(4,RM(m_ea)) ); } /* RES 4,(XY+o) */
-OP(xycb,a7) { _A = RES(4, RM(m_ea) ); WM( m_ea,_A ); } /* RES 4,A=(XY+o) */
+OP(xycb,a0) { _B = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 4,B=(XY+o) */
+OP(xycb,a1) { _C = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 4,C=(XY+o) */
+OP(xycb,a2) { _D = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 4,D=(XY+o) */
+OP(xycb,a3) { _E = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 4,E=(XY+o) */
+OP(xycb,a4) { _H = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 4,H=(XY+o) */
+OP(xycb,a5) { _L = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 4,L=(XY+o) */
+OP(xycb,a6) { WM( m_ea, z180_device_RES(4,z180_device_RM(m_ea)) ); } /* RES 4,(XY+o) */
+OP(xycb,a7) { _A = z180_device_RES(4, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 4,A=(XY+o) */
-OP(xycb,a8) { _B = RES(5, RM(m_ea) ); WM( m_ea,_B ); } /* RES 5,B=(XY+o) */
-OP(xycb,a9) { _C = RES(5, RM(m_ea) ); WM( m_ea,_C ); } /* RES 5,C=(XY+o) */
-OP(xycb,aa) { _D = RES(5, RM(m_ea) ); WM( m_ea,_D ); } /* RES 5,D=(XY+o) */
-OP(xycb,ab) { _E = RES(5, RM(m_ea) ); WM( m_ea,_E ); } /* RES 5,E=(XY+o) */
-OP(xycb,ac) { _H = RES(5, RM(m_ea) ); WM( m_ea,_H ); } /* RES 5,H=(XY+o) */
-OP(xycb,ad) { _L = RES(5, RM(m_ea) ); WM( m_ea,_L ); } /* RES 5,L=(XY+o) */
-OP(xycb,ae) { WM( m_ea, RES(5,RM(m_ea)) ); } /* RES 5,(XY+o) */
-OP(xycb,af) { _A = RES(5, RM(m_ea) ); WM( m_ea,_A ); } /* RES 5,A=(XY+o) */
+OP(xycb,a8) { _B = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 5,B=(XY+o) */
+OP(xycb,a9) { _C = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 5,C=(XY+o) */
+OP(xycb,aa) { _D = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 5,D=(XY+o) */
+OP(xycb,ab) { _E = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 5,E=(XY+o) */
+OP(xycb,ac) { _H = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 5,H=(XY+o) */
+OP(xycb,ad) { _L = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 5,L=(XY+o) */
+OP(xycb,ae) { WM( m_ea, z180_device_RES(5,z180_device_RM(m_ea)) ); } /* RES 5,(XY+o) */
+OP(xycb,af) { _A = z180_device_RES(5, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 5,A=(XY+o) */
-OP(xycb,b0) { _B = RES(6, RM(m_ea) ); WM( m_ea,_B ); } /* RES 6,B=(XY+o) */
-OP(xycb,b1) { _C = RES(6, RM(m_ea) ); WM( m_ea,_C ); } /* RES 6,C=(XY+o) */
-OP(xycb,b2) { _D = RES(6, RM(m_ea) ); WM( m_ea,_D ); } /* RES 6,D=(XY+o) */
-OP(xycb,b3) { _E = RES(6, RM(m_ea) ); WM( m_ea,_E ); } /* RES 6,E=(XY+o) */
-OP(xycb,b4) { _H = RES(6, RM(m_ea) ); WM( m_ea,_H ); } /* RES 6,H=(XY+o) */
-OP(xycb,b5) { _L = RES(6, RM(m_ea) ); WM( m_ea,_L ); } /* RES 6,L=(XY+o) */
-OP(xycb,b6) { WM( m_ea, RES(6,RM(m_ea)) ); } /* RES 6,(XY+o) */
-OP(xycb,b7) { _A = RES(6, RM(m_ea) ); WM( m_ea,_A ); } /* RES 6,A=(XY+o) */
+OP(xycb,b0) { _B = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 6,B=(XY+o) */
+OP(xycb,b1) { _C = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 6,C=(XY+o) */
+OP(xycb,b2) { _D = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 6,D=(XY+o) */
+OP(xycb,b3) { _E = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 6,E=(XY+o) */
+OP(xycb,b4) { _H = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 6,H=(XY+o) */
+OP(xycb,b5) { _L = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 6,L=(XY+o) */
+OP(xycb,b6) { WM( m_ea, z180_device_RES(6,z180_device_RM(m_ea)) ); } /* RES 6,(XY+o) */
+OP(xycb,b7) { _A = z180_device_RES(6, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 6,A=(XY+o) */
-OP(xycb,b8) { _B = RES(7, RM(m_ea) ); WM( m_ea,_B ); } /* RES 7,B=(XY+o) */
-OP(xycb,b9) { _C = RES(7, RM(m_ea) ); WM( m_ea,_C ); } /* RES 7,C=(XY+o) */
-OP(xycb,ba) { _D = RES(7, RM(m_ea) ); WM( m_ea,_D ); } /* RES 7,D=(XY+o) */
-OP(xycb,bb) { _E = RES(7, RM(m_ea) ); WM( m_ea,_E ); } /* RES 7,E=(XY+o) */
-OP(xycb,bc) { _H = RES(7, RM(m_ea) ); WM( m_ea,_H ); } /* RES 7,H=(XY+o) */
-OP(xycb,bd) { _L = RES(7, RM(m_ea) ); WM( m_ea,_L ); } /* RES 7,L=(XY+o) */
-OP(xycb,be) { WM( m_ea, RES(7,RM(m_ea)) ); } /* RES 7,(XY+o) */
-OP(xycb,bf) { _A = RES(7, RM(m_ea) ); WM( m_ea,_A ); } /* RES 7,A=(XY+o) */
+OP(xycb,b8) { _B = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* RES 7,B=(XY+o) */
+OP(xycb,b9) { _C = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* RES 7,C=(XY+o) */
+OP(xycb,ba) { _D = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* RES 7,D=(XY+o) */
+OP(xycb,bb) { _E = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* RES 7,E=(XY+o) */
+OP(xycb,bc) { _H = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* RES 7,H=(XY+o) */
+OP(xycb,bd) { _L = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* RES 7,L=(XY+o) */
+OP(xycb,be) { WM( m_ea, z180_device_RES(7,z180_device_RM(m_ea)) ); } /* RES 7,(XY+o) */
+OP(xycb,bf) { _A = z180_device_RES(7, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* RES 7,A=(XY+o) */
-OP(xycb,c0) { _B = SET(0, RM(m_ea) ); WM( m_ea,_B ); } /* SET 0,B=(XY+o) */
-OP(xycb,c1) { _C = SET(0, RM(m_ea) ); WM( m_ea,_C ); } /* SET 0,C=(XY+o) */
-OP(xycb,c2) { _D = SET(0, RM(m_ea) ); WM( m_ea,_D ); } /* SET 0,D=(XY+o) */
-OP(xycb,c3) { _E = SET(0, RM(m_ea) ); WM( m_ea,_E ); } /* SET 0,E=(XY+o) */
-OP(xycb,c4) { _H = SET(0, RM(m_ea) ); WM( m_ea,_H ); } /* SET 0,H=(XY+o) */
-OP(xycb,c5) { _L = SET(0, RM(m_ea) ); WM( m_ea,_L ); } /* SET 0,L=(XY+o) */
-OP(xycb,c6) { WM( m_ea, SET(0,RM(m_ea)) ); } /* SET 0,(XY+o) */
-OP(xycb,c7) { _A = SET(0, RM(m_ea) ); WM( m_ea,_A ); } /* SET 0,A=(XY+o) */
+OP(xycb,c0) { _B = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 0,B=(XY+o) */
+OP(xycb,c1) { _C = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 0,C=(XY+o) */
+OP(xycb,c2) { _D = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 0,D=(XY+o) */
+OP(xycb,c3) { _E = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 0,E=(XY+o) */
+OP(xycb,c4) { _H = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 0,H=(XY+o) */
+OP(xycb,c5) { _L = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 0,L=(XY+o) */
+OP(xycb,c6) { WM( m_ea, z180_device_SET(0,z180_device_RM(m_ea)) ); } /* SET 0,(XY+o) */
+OP(xycb,c7) { _A = z180_device_SET(0, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 0,A=(XY+o) */
-OP(xycb,c8) { _B = SET(1, RM(m_ea) ); WM( m_ea,_B ); } /* SET 1,B=(XY+o) */
-OP(xycb,c9) { _C = SET(1, RM(m_ea) ); WM( m_ea,_C ); } /* SET 1,C=(XY+o) */
-OP(xycb,ca) { _D = SET(1, RM(m_ea) ); WM( m_ea,_D ); } /* SET 1,D=(XY+o) */
-OP(xycb,cb) { _E = SET(1, RM(m_ea) ); WM( m_ea,_E ); } /* SET 1,E=(XY+o) */
-OP(xycb,cc) { _H = SET(1, RM(m_ea) ); WM( m_ea,_H ); } /* SET 1,H=(XY+o) */
-OP(xycb,cd) { _L = SET(1, RM(m_ea) ); WM( m_ea,_L ); } /* SET 1,L=(XY+o) */
-OP(xycb,ce) { WM( m_ea, SET(1,RM(m_ea)) ); } /* SET 1,(XY+o) */
-OP(xycb,cf) { _A = SET(1, RM(m_ea) ); WM( m_ea,_A ); } /* SET 1,A=(XY+o) */
+OP(xycb,c8) { _B = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 1,B=(XY+o) */
+OP(xycb,c9) { _C = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 1,C=(XY+o) */
+OP(xycb,ca) { _D = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 1,D=(XY+o) */
+OP(xycb,cb) { _E = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 1,E=(XY+o) */
+OP(xycb,cc) { _H = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 1,H=(XY+o) */
+OP(xycb,cd) { _L = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 1,L=(XY+o) */
+OP(xycb,ce) { WM( m_ea, z180_device_SET(1,z180_device_RM(m_ea)) ); } /* SET 1,(XY+o) */
+OP(xycb,cf) { _A = z180_device_SET(1, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 1,A=(XY+o) */
-OP(xycb,d0) { _B = SET(2, RM(m_ea) ); WM( m_ea,_B ); } /* SET 2,B=(XY+o) */
-OP(xycb,d1) { _C = SET(2, RM(m_ea) ); WM( m_ea,_C ); } /* SET 2,C=(XY+o) */
-OP(xycb,d2) { _D = SET(2, RM(m_ea) ); WM( m_ea,_D ); } /* SET 2,D=(XY+o) */
-OP(xycb,d3) { _E = SET(2, RM(m_ea) ); WM( m_ea,_E ); } /* SET 2,E=(XY+o) */
-OP(xycb,d4) { _H = SET(2, RM(m_ea) ); WM( m_ea,_H ); } /* SET 2,H=(XY+o) */
-OP(xycb,d5) { _L = SET(2, RM(m_ea) ); WM( m_ea,_L ); } /* SET 2,L=(XY+o) */
-OP(xycb,d6) { WM( m_ea, SET(2,RM(m_ea)) ); } /* SET 2,(XY+o) */
-OP(xycb,d7) { _A = SET(2, RM(m_ea) ); WM( m_ea,_A ); } /* SET 2,A=(XY+o) */
+OP(xycb,d0) { _B = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 2,B=(XY+o) */
+OP(xycb,d1) { _C = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 2,C=(XY+o) */
+OP(xycb,d2) { _D = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 2,D=(XY+o) */
+OP(xycb,d3) { _E = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 2,E=(XY+o) */
+OP(xycb,d4) { _H = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 2,H=(XY+o) */
+OP(xycb,d5) { _L = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 2,L=(XY+o) */
+OP(xycb,d6) { WM( m_ea, z180_device_SET(2,z180_device_RM(m_ea)) ); } /* SET 2,(XY+o) */
+OP(xycb,d7) { _A = z180_device_SET(2, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 2,A=(XY+o) */
-OP(xycb,d8) { _B = SET(3, RM(m_ea) ); WM( m_ea,_B ); } /* SET 3,B=(XY+o) */
-OP(xycb,d9) { _C = SET(3, RM(m_ea) ); WM( m_ea,_C ); } /* SET 3,C=(XY+o) */
-OP(xycb,da) { _D = SET(3, RM(m_ea) ); WM( m_ea,_D ); } /* SET 3,D=(XY+o) */
-OP(xycb,db) { _E = SET(3, RM(m_ea) ); WM( m_ea,_E ); } /* SET 3,E=(XY+o) */
-OP(xycb,dc) { _H = SET(3, RM(m_ea) ); WM( m_ea,_H ); } /* SET 3,H=(XY+o) */
-OP(xycb,dd) { _L = SET(3, RM(m_ea) ); WM( m_ea,_L ); } /* SET 3,L=(XY+o) */
-OP(xycb,de) { WM( m_ea, SET(3,RM(m_ea)) ); } /* SET 3,(XY+o) */
-OP(xycb,df) { _A = SET(3, RM(m_ea) ); WM( m_ea,_A ); } /* SET 3,A=(XY+o) */
+OP(xycb,d8) { _B = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 3,B=(XY+o) */
+OP(xycb,d9) { _C = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 3,C=(XY+o) */
+OP(xycb,da) { _D = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 3,D=(XY+o) */
+OP(xycb,db) { _E = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 3,E=(XY+o) */
+OP(xycb,dc) { _H = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 3,H=(XY+o) */
+OP(xycb,dd) { _L = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 3,L=(XY+o) */
+OP(xycb,de) { WM( m_ea, z180_device_SET(3,z180_device_RM(m_ea)) ); } /* SET 3,(XY+o) */
+OP(xycb,df) { _A = z180_device_SET(3, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 3,A=(XY+o) */
-OP(xycb,e0) { _B = SET(4, RM(m_ea) ); WM( m_ea,_B ); } /* SET 4,B=(XY+o) */
-OP(xycb,e1) { _C = SET(4, RM(m_ea) ); WM( m_ea,_C ); } /* SET 4,C=(XY+o) */
-OP(xycb,e2) { _D = SET(4, RM(m_ea) ); WM( m_ea,_D ); } /* SET 4,D=(XY+o) */
-OP(xycb,e3) { _E = SET(4, RM(m_ea) ); WM( m_ea,_E ); } /* SET 4,E=(XY+o) */
-OP(xycb,e4) { _H = SET(4, RM(m_ea) ); WM( m_ea,_H ); } /* SET 4,H=(XY+o) */
-OP(xycb,e5) { _L = SET(4, RM(m_ea) ); WM( m_ea,_L ); } /* SET 4,L=(XY+o) */
-OP(xycb,e6) { WM( m_ea, SET(4,RM(m_ea)) ); } /* SET 4,(XY+o) */
-OP(xycb,e7) { _A = SET(4, RM(m_ea) ); WM( m_ea,_A ); } /* SET 4,A=(XY+o) */
+OP(xycb,e0) { _B = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 4,B=(XY+o) */
+OP(xycb,e1) { _C = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 4,C=(XY+o) */
+OP(xycb,e2) { _D = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 4,D=(XY+o) */
+OP(xycb,e3) { _E = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 4,E=(XY+o) */
+OP(xycb,e4) { _H = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 4,H=(XY+o) */
+OP(xycb,e5) { _L = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 4,L=(XY+o) */
+OP(xycb,e6) { WM( m_ea, z180_device_SET(4,z180_device_RM(m_ea)) ); } /* SET 4,(XY+o) */
+OP(xycb,e7) { _A = z180_device_SET(4, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 4,A=(XY+o) */
-OP(xycb,e8) { _B = SET(5, RM(m_ea) ); WM( m_ea,_B ); } /* SET 5,B=(XY+o) */
-OP(xycb,e9) { _C = SET(5, RM(m_ea) ); WM( m_ea,_C ); } /* SET 5,C=(XY+o) */
-OP(xycb,ea) { _D = SET(5, RM(m_ea) ); WM( m_ea,_D ); } /* SET 5,D=(XY+o) */
-OP(xycb,eb) { _E = SET(5, RM(m_ea) ); WM( m_ea,_E ); } /* SET 5,E=(XY+o) */
-OP(xycb,ec) { _H = SET(5, RM(m_ea) ); WM( m_ea,_H ); } /* SET 5,H=(XY+o) */
-OP(xycb,ed) { _L = SET(5, RM(m_ea) ); WM( m_ea,_L ); } /* SET 5,L=(XY+o) */
-OP(xycb,ee) { WM( m_ea, SET(5,RM(m_ea)) ); } /* SET 5,(XY+o) */
-OP(xycb,ef) { _A = SET(5, RM(m_ea) ); WM( m_ea,_A ); } /* SET 5,A=(XY+o) */
+OP(xycb,e8) { _B = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 5,B=(XY+o) */
+OP(xycb,e9) { _C = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 5,C=(XY+o) */
+OP(xycb,ea) { _D = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 5,D=(XY+o) */
+OP(xycb,eb) { _E = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 5,E=(XY+o) */
+OP(xycb,ec) { _H = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 5,H=(XY+o) */
+OP(xycb,ed) { _L = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 5,L=(XY+o) */
+OP(xycb,ee) { WM( m_ea, z180_device_SET(5,z180_device_RM(m_ea)) ); } /* SET 5,(XY+o) */
+OP(xycb,ef) { _A = z180_device_SET(5, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 5,A=(XY+o) */
-OP(xycb,f0) { _B = SET(6, RM(m_ea) ); WM( m_ea,_B ); } /* SET 6,B=(XY+o) */
-OP(xycb,f1) { _C = SET(6, RM(m_ea) ); WM( m_ea,_C ); } /* SET 6,C=(XY+o) */
-OP(xycb,f2) { _D = SET(6, RM(m_ea) ); WM( m_ea,_D ); } /* SET 6,D=(XY+o) */
-OP(xycb,f3) { _E = SET(6, RM(m_ea) ); WM( m_ea,_E ); } /* SET 6,E=(XY+o) */
-OP(xycb,f4) { _H = SET(6, RM(m_ea) ); WM( m_ea,_H ); } /* SET 6,H=(XY+o) */
-OP(xycb,f5) { _L = SET(6, RM(m_ea) ); WM( m_ea,_L ); } /* SET 6,L=(XY+o) */
-OP(xycb,f6) { WM( m_ea, SET(6,RM(m_ea)) ); } /* SET 6,(XY+o) */
-OP(xycb,f7) { _A = SET(6, RM(m_ea) ); WM( m_ea,_A ); } /* SET 6,A=(XY+o) */
+OP(xycb,f0) { _B = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 6,B=(XY+o) */
+OP(xycb,f1) { _C = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 6,C=(XY+o) */
+OP(xycb,f2) { _D = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 6,D=(XY+o) */
+OP(xycb,f3) { _E = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 6,E=(XY+o) */
+OP(xycb,f4) { _H = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 6,H=(XY+o) */
+OP(xycb,f5) { _L = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 6,L=(XY+o) */
+OP(xycb,f6) { WM( m_ea, z180_device_SET(6,z180_device_RM(m_ea)) ); } /* SET 6,(XY+o) */
+OP(xycb,f7) { _A = z180_device_SET(6, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 6,A=(XY+o) */
-OP(xycb,f8) { _B = SET(7, RM(m_ea) ); WM( m_ea,_B ); } /* SET 7,B=(XY+o) */
-OP(xycb,f9) { _C = SET(7, RM(m_ea) ); WM( m_ea,_C ); } /* SET 7,C=(XY+o) */
-OP(xycb,fa) { _D = SET(7, RM(m_ea) ); WM( m_ea,_D ); } /* SET 7,D=(XY+o) */
-OP(xycb,fb) { _E = SET(7, RM(m_ea) ); WM( m_ea,_E ); } /* SET 7,E=(XY+o) */
-OP(xycb,fc) { _H = SET(7, RM(m_ea) ); WM( m_ea,_H ); } /* SET 7,H=(XY+o) */
-OP(xycb,fd) { _L = SET(7, RM(m_ea) ); WM( m_ea,_L ); } /* SET 7,L=(XY+o) */
-OP(xycb,fe) { WM( m_ea, SET(7,RM(m_ea)) ); } /* SET 7,(XY+o) */
-OP(xycb,ff) { _A = SET(7, RM(m_ea) ); WM( m_ea,_A ); } /* SET 7,A=(XY+o) */
+OP(xycb,f8) { _B = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_B ); } /* SET 7,B=(XY+o) */
+OP(xycb,f9) { _C = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_C ); } /* SET 7,C=(XY+o) */
+OP(xycb,fa) { _D = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_D ); } /* SET 7,D=(XY+o) */
+OP(xycb,fb) { _E = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_E ); } /* SET 7,E=(XY+o) */
+OP(xycb,fc) { _H = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_H ); } /* SET 7,H=(XY+o) */
+OP(xycb,fd) { _L = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_L ); } /* SET 7,L=(XY+o) */
+OP(xycb,fe) { WM( m_ea, z180_device_SET(7,z180_device_RM(m_ea)) ); } /* SET 7,(XY+o) */
+OP(xycb,ff) { _A = z180_device_SET(7, z180_device_RM(m_ea) ); WM( m_ea,_A ); } /* SET 7,A=(XY+o) */