mirror of https://github.com/bsnes-emu/bsnes.git
108 lines
3.0 KiB
C++
Executable File
108 lines
3.0 KiB
C++
Executable File
#ifndef PROCESSOR_SPC700_HPP
|
|
#define PROCESSOR_SPC700_HPP
|
|
|
|
namespace Processor {
|
|
|
|
struct SPC700 {
|
|
virtual void op_io() = 0;
|
|
virtual uint8 op_read(uint16 addr) = 0;
|
|
virtual void op_write(uint16 addr, uint8 data) = 0;
|
|
void op_step();
|
|
|
|
virtual uint8 disassembler_read(uint16 addr) = 0;
|
|
|
|
#include "registers.hpp"
|
|
#include "memory.hpp"
|
|
|
|
regs_t regs;
|
|
word_t dp, sp, rd, wr, bit, ya;
|
|
uint8 opcode;
|
|
|
|
void serialize(serializer&);
|
|
string disassemble_opcode(uint16 addr);
|
|
|
|
protected:
|
|
uint8 op_adc(uint8, uint8);
|
|
uint8 op_and(uint8, uint8);
|
|
uint8 op_asl(uint8);
|
|
uint8 op_cmp(uint8, uint8);
|
|
uint8 op_dec(uint8);
|
|
uint8 op_eor(uint8, uint8);
|
|
uint8 op_inc(uint8);
|
|
uint8 op_ld (uint8, uint8);
|
|
uint8 op_lsr(uint8);
|
|
uint8 op_or (uint8, uint8);
|
|
uint8 op_rol(uint8);
|
|
uint8 op_ror(uint8);
|
|
uint8 op_sbc(uint8, uint8);
|
|
uint8 op_st (uint8, uint8);
|
|
uint16 op_adw(uint16, uint16);
|
|
uint16 op_cpw(uint16, uint16);
|
|
uint16 op_ldw(uint16, uint16);
|
|
uint16 op_sbw(uint16, uint16);
|
|
|
|
template<uint8 (SPC700::*op)(uint8)> void op_adjust(uint8&);
|
|
template<uint8 (SPC700::*op)(uint8)> void op_adjust_addr();
|
|
template<uint8 (SPC700::*op)(uint8)> void op_adjust_dp();
|
|
void op_adjust_dpw(signed);
|
|
template<uint8 (SPC700::*op)(uint8)> void op_adjust_dpx();
|
|
void op_branch(bool);
|
|
void op_branch_bit();
|
|
void op_pull(uint8&);
|
|
void op_push(uint8);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_addr(uint8&);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_addri(uint8&);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_const(uint8&);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_dp(uint8&);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_dpi(uint8&, uint8&);
|
|
template<uint16 (SPC700::*op)(uint16, uint16)> void op_read_dpw();
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_idpx();
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_idpy();
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_read_ix();
|
|
void op_set_addr_bit();
|
|
void op_set_bit();
|
|
void op_set_flag(bool&, bool);
|
|
void op_test_addr(bool);
|
|
void op_transfer(uint8&, uint8&);
|
|
void op_write_addr(uint8&);
|
|
void op_write_addri(uint8&);
|
|
void op_write_dp(uint8&);
|
|
void op_write_dpi(uint8&, uint8&);
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_write_dp_const();
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_write_dp_dp();
|
|
template<uint8 (SPC700::*op)(uint8, uint8)> void op_write_ix_iy();
|
|
|
|
void op_bne_dp();
|
|
void op_bne_dpdec();
|
|
void op_bne_dpx();
|
|
void op_bne_ydec();
|
|
void op_brk();
|
|
void op_clv();
|
|
void op_cmc();
|
|
void op_daa();
|
|
void op_das();
|
|
void op_div_ya_x();
|
|
void op_jmp_addr();
|
|
void op_jmp_iaddrx();
|
|
void op_jsp_dp();
|
|
void op_jsr_addr();
|
|
void op_jst();
|
|
void op_lda_ixinc();
|
|
void op_mul_ya();
|
|
void op_nop();
|
|
void op_plp();
|
|
void op_rti();
|
|
void op_rts();
|
|
void op_sta_idpx();
|
|
void op_sta_idpy();
|
|
void op_sta_ix();
|
|
void op_sta_ixinc();
|
|
void op_stw_dp();
|
|
void op_wait();
|
|
void op_xcn();
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|