#ifndef PROCESSOR_R65816_HPP #define PROCESSOR_R65816_HPP namespace Processor { //WDC 65C816 CPU core //* Ricoh 5A22 //* Nintendo SA-1 struct R65816 { #include "registers.hpp" #include "memory.hpp" #include "disassembler.hpp" regs_t regs; reg24_t aa, rd; uint8_t sp, dp; virtual void op_io() = 0; virtual uint8_t op_read(uint32_t addr) = 0; virtual void op_write(uint32_t addr, uint8_t data) = 0; virtual void last_cycle() = 0; virtual bool interrupt_pending() = 0; virtual void op_irq(); virtual uint8 disassembler_read(uint32 addr) { return 0u; } void op_io_irq(); void op_io_cond2(); void op_io_cond4(uint16 x, uint16 y); void op_io_cond6(uint16 addr); void op_adc_b(); void op_adc_w(); void op_and_b(); void op_and_w(); void op_bit_b(); void op_bit_w(); void op_cmp_b(); void op_cmp_w(); void op_cpx_b(); void op_cpx_w(); void op_cpy_b(); void op_cpy_w(); void op_eor_b(); void op_eor_w(); void op_lda_b(); void op_lda_w(); void op_ldx_b(); void op_ldx_w(); void op_ldy_b(); void op_ldy_w(); void op_ora_b(); void op_ora_w(); void op_sbc_b(); void op_sbc_w(); void op_inc_b(); void op_inc_w(); void op_dec_b(); void op_dec_w(); void op_asl_b(); void op_asl_w(); void op_lsr_b(); void op_lsr_w(); void op_rol_b(); void op_rol_w(); void op_ror_b(); void op_ror_w(); void op_trb_b(); void op_trb_w(); void op_tsb_b(); void op_tsb_w(); template void op_read_const_b(); template void op_read_const_w(); void op_read_bit_const_b(); void op_read_bit_const_w(); template void op_read_addr_b(); template void op_read_addr_w(); template void op_read_addrx_b(); template void op_read_addrx_w(); template void op_read_addry_b(); template void op_read_addry_w(); template void op_read_long_b(); template void op_read_long_w(); template void op_read_longx_b(); template void op_read_longx_w(); template void op_read_dp_b(); template void op_read_dp_w(); template void op_read_dpr_b(); template void op_read_dpr_w(); template void op_read_idp_b(); template void op_read_idp_w(); template void op_read_idpx_b(); template void op_read_idpx_w(); template void op_read_idpy_b(); template void op_read_idpy_w(); template void op_read_ildp_b(); template void op_read_ildp_w(); template void op_read_ildpy_b(); template void op_read_ildpy_w(); template void op_read_sr_b(); template void op_read_sr_w(); template void op_read_isry_b(); template void op_read_isry_w(); template void op_write_addr_b(); template void op_write_addr_w(); template void op_write_addrr_b(); template void op_write_addrr_w(); template void op_write_longr_b(); template void op_write_longr_w(); template void op_write_dp_b(); template void op_write_dp_w(); template void op_write_dpr_b(); template void op_write_dpr_w(); void op_sta_idp_b(); void op_sta_idp_w(); void op_sta_ildp_b(); void op_sta_ildp_w(); void op_sta_idpx_b(); void op_sta_idpx_w(); void op_sta_idpy_b(); void op_sta_idpy_w(); void op_sta_ildpy_b(); void op_sta_ildpy_w(); void op_sta_sr_b(); void op_sta_sr_w(); void op_sta_isry_b(); void op_sta_isry_w(); template void op_adjust_imm_b(); template void op_adjust_imm_w(); void op_asl_imm_b(); void op_asl_imm_w(); void op_lsr_imm_b(); void op_lsr_imm_w(); void op_rol_imm_b(); void op_rol_imm_w(); void op_ror_imm_b(); void op_ror_imm_w(); template void op_adjust_addr_b(); template void op_adjust_addr_w(); template void op_adjust_addrx_b(); template void op_adjust_addrx_w(); template void op_adjust_dp_b(); template void op_adjust_dp_w(); template void op_adjust_dpx_b(); template void op_adjust_dpx_w(); template void op_branch(); void op_bra(); void op_brl(); void op_jmp_addr(); void op_jmp_long(); void op_jmp_iaddr(); void op_jmp_iaddrx(); void op_jmp_iladdr(); void op_jsr_addr(); void op_jsr_long_e(); void op_jsr_long_n(); void op_jsr_iaddrx_e(); void op_jsr_iaddrx_n(); void op_rti_e(); void op_rti_n(); void op_rts(); void op_rtl_e(); void op_rtl_n(); void op_nop(); void op_wdm(); void op_xba(); template void op_move_b(); template void op_move_w(); template void op_interrupt_e(); template void op_interrupt_n(); void op_stp(); void op_wai(); void op_xce(); template void op_flag(); template void op_pflag_e(); template void op_pflag_n(); template void op_transfer_b(); template void op_transfer_w(); void op_tcs_e(); void op_tcs_n(); void op_tsx_b(); void op_tsx_w(); void op_txs_e(); void op_txs_n(); template void op_push_b(); template void op_push_w(); void op_phd_e(); void op_phd_n(); void op_phb(); void op_phk(); void op_php(); template void op_pull_b(); template void op_pull_w(); void op_pld_e(); void op_pld_n(); void op_plb(); void op_plp_e(); void op_plp_n(); void op_pea_e(); void op_pea_n(); void op_pei_e(); void op_pei_n(); void op_per_e(); void op_per_n(); void (R65816::**opcode_table)(); void (R65816::*op_table[5 * 256])(); void initialize_opcode_table(); void update_table(); enum { table_EM = 0, // 8-bit accumulator, 8-bit index (emulation mode) table_MX = 256, // 8-bit accumulator, 8-bit index table_Mx = 512, // 8-bit accumulator, 16-bit index table_mX = 768, //16-bit accumulator, 8-bit index table_mx = 1024, //16-bit accumulator, 16-bit index }; void serialize(serializer&); R65816(); }; } #endif