Update to v101r33 release.

byuu says:

Changelog:

  - PCE: HuC6280 core completed

There's bound to be a countless stream of bugs, and the cycle counts are
almost certainly not exact yet, but ... all instructions are implemented.

So at this point, I can start comparing trace logs against Mednafen's
debugger output.

Of course, we're very likely to immediately slam into a wall of needing
I/O registers implemented for the VDC in order to proceed further.
This commit is contained in:
Tim Allen 2017-01-15 11:58:47 +11:00
parent 26bd7590ad
commit 8499c64756
7 changed files with 730 additions and 321 deletions

View File

@ -12,7 +12,7 @@ using namespace nall;
namespace Emulator { namespace Emulator {
static const string Name = "higan"; static const string Name = "higan";
static const string Version = "101.32"; static const string Version = "101.33";
static const string Author = "byuu"; static const string Author = "byuu";
static const string License = "GPLv3"; static const string License = "GPLv3";
static const string Website = "http://byuu.org/"; static const string Website = "http://byuu.org/";

View File

@ -51,6 +51,9 @@ auto CPU::write(uint21 addr, uint8 data) -> void {
if(bank == 0xff) return; //hardware if(bank == 0xff) return; //hardware
} }
auto CPU::st(uint2 addr, uint8 data) -> void {
}
auto CPU::lastCycle() -> void { auto CPU::lastCycle() -> void {
} }

View File

@ -9,6 +9,7 @@ struct CPU : Processor::HuC6280, Thread {
auto read(uint21 addr) -> uint8 override; auto read(uint21 addr) -> uint8 override;
auto write(uint21 addr, uint8 data) -> void override; auto write(uint21 addr, uint8 data) -> void override;
auto st(uint2 addr, uint8 data) -> void override;
auto lastCycle() -> void override; auto lastCycle() -> void override;
vector<Thread*> peripherals; vector<Thread*> peripherals;

View File

@ -18,12 +18,46 @@ auto HuC6280::disassemble(uint16 pc_) -> string {
auto indirect = [&]() -> string { return {"($", hex(readByte(), 2L), ")"}; }; auto indirect = [&]() -> string { return {"($", hex(readByte(), 2L), ")"}; };
auto indirectX = [&]() -> string { return {"($", hex(readByte(), 2L), ",x)"}; }; auto indirectX = [&]() -> string { return {"($", hex(readByte(), 2L), ",x)"}; };
auto indirectY = [&]() -> string { return {"($", hex(readByte(), 2L), "),y"}; }; auto indirectY = [&]() -> string { return {"($", hex(readByte(), 2L), "),y"}; };
auto indirectLong = [&]() -> string { return {"($", hex(readWord(), 4L), ")"}; };
auto indirectLongX = [&]() -> string { return {"($", hex(readWord(), 4L), ",x)"}; };
auto memory = [&]() -> string { return {"(x),#$", hex(readByte(), 2L)}; }; auto memory = [&]() -> string { return {"(x),#$", hex(readByte(), 2L)}; };
auto relative = [&]() -> string { auto displacement = readByte(); return {"$", hex(pc + (int8)displacement, 4L)}; }; auto relative = [&]() -> string { auto displacement = readByte(); return {"$", hex(pc + (int8)displacement, 4L)}; };
auto zeropage = [&]() -> string { return {"$", hex(readByte(), 2L)}; }; auto zeropage = [&]() -> string { return {"$", hex(readByte(), 2L)}; };
auto zeropageX = [&]() -> string { return {"$", hex(readByte(), 2L), ",x"}; }; auto zeropageX = [&]() -> string { return {"$", hex(readByte(), 2L), ",x"}; };
auto zeropageY = [&]() -> string { return {"$", hex(readByte(), 2L), ",y"}; }; auto zeropageY = [&]() -> string { return {"$", hex(readByte(), 2L), ",y"}; };
auto immediateAbsolute = [&](string index = "") -> string {
auto immediate = readByte();
auto absolute = readWord();
if(index) index.prepend(",");
return {"#$", hex(immediate, 2L), ",$", hex(absolute, 4L), index};
};
auto immediateZeropage = [&](string index = "") -> string {
auto immediate = readByte();
auto zeropage = readByte();
if(index) index.prepend(",");
return {"#$", hex(immediate, 2L), ",$", hex(zeropage, 2L), index};
};
auto zeropageBit = [&](uint3 bit) -> string {
auto zeropage = readByte();
return {"$", hex(zeropage, 2L), ":", bit};
};
auto zeropageBitRelative = [&](uint3 bit) -> string {
auto zeropage = readByte();
auto displacement = readByte();
return {"$", hex(zeropage, 2L), ":", bit, ",$", hex(pc + (int8)displacement, 4L)};
};
auto blockMove = [&]() -> string {
auto source = readWord();
auto target = readWord();
auto length = readWord();
return {"$", hex(source, 4L), ",$", hex(target, 4L), ",$", hex(length, 4L)};
};
uint8 opcode = readByte(); uint8 opcode = readByte();
#define op(id, name, ...) case id: o = {name, " ", string_vector{__VA_ARGS__}.merge(",")}; break; #define op(id, name, ...) case id: o = {name, " ", string_vector{__VA_ARGS__}.merge(",")}; break;
@ -36,59 +70,87 @@ auto HuC6280::disassemble(uint16 pc_) -> string {
op(0x69, "adc", memory()) op(0x69, "adc", memory())
} }
#define U
if(T == 0) switch(opcode) { if(T == 0) switch(opcode) {
op(0x00, "brk")
op(0x01, "ora", indirectX()) op(0x01, "ora", indirectX())
op(0x02, "sxy") op(0x02, "sxy")
op(0x03, "st0")
op(0x04, "tsb", zeropage())
op(0x05, "ora", zeropage()) op(0x05, "ora", zeropage())
op(0x06, "asl", zeropage()) op(0x06, "asl", zeropage())
op(0x07, "rmb", zeropageBit(0))
op(0x08, "php") op(0x08, "php")
op(0x09, "ora", immediate()) op(0x09, "ora", immediate())
op(0x0a, "asl") op(0x0a, "asl")
U op(0x0b, "nop", "$0b")
op(0x0c, "tsb", absolute())
op(0x0d, "ora", absolute()) op(0x0d, "ora", absolute())
op(0x0e, "asl", absolute()) op(0x0e, "asl", absolute())
op(0x0f, "bbr", zeropageBitRelative(0))
op(0x10, "bpl", relative()) op(0x10, "bpl", relative())
op(0x11, "ora", indirectY()) op(0x11, "ora", indirectY())
op(0x12, "ora", indirect()) op(0x12, "ora", indirect())
op(0x13, "st1")
op(0x14, "trb", zeropage())
op(0x15, "ora", zeropageX()) op(0x15, "ora", zeropageX())
op(0x16, "asl", zeropageX()) op(0x16, "asl", zeropageX())
op(0x17, "rmb", zeropageBit(1))
op(0x18, "clc") op(0x18, "clc")
op(0x19, "ora", absoluteY()) op(0x19, "ora", absoluteY())
op(0x1a, "inc") op(0x1a, "inc")
U op(0x1b, "nop", "$1b")
op(0x1c, "trb", absolute())
op(0x1d, "ora", absoluteX()) op(0x1d, "ora", absoluteX())
op(0x1e, "asl", absoluteX()) op(0x1e, "asl", absoluteX())
op(0x1f, "bbr", zeropageBitRelative(1))
op(0x20, "jsr", absolute())
op(0x21, "and", indirectX()) op(0x21, "and", indirectX())
op(0x22, "sax") op(0x22, "sax")
op(0x23, "st2")
op(0x24, "bit", zeropage()) op(0x24, "bit", zeropage())
op(0x25, "and", zeropage()) op(0x25, "and", zeropage())
op(0x26, "rol", zeropage()) op(0x26, "rol", zeropage())
op(0x27, "rmb", zeropageBit(2))
op(0x28, "plp") op(0x28, "plp")
op(0x29, "and", immediate()) op(0x29, "and", immediate())
op(0x2a, "rol") op(0x2a, "rol")
U op(0x2b, "nop", "$2b")
op(0x2c, "bit", absolute()) op(0x2c, "bit", absolute())
op(0x2d, "and", absolute()) op(0x2d, "and", absolute())
op(0x2e, "rol", absolute()) op(0x2e, "rol", absolute())
op(0x2f, "bbr", zeropageBitRelative(2))
op(0x30, "bmi", relative()) op(0x30, "bmi", relative())
op(0x31, "and", indirectY()) op(0x31, "and", indirectY())
op(0x32, "and", indirect()) op(0x32, "and", indirect())
op(0x34, "bit", zeropageX()) op(0x34, "bit", zeropageX())
op(0x35, "and", zeropageX()) op(0x35, "and", zeropageX())
op(0x36, "rol", zeropageX()) op(0x36, "rol", zeropageX())
op(0x37, "rmb", zeropageBit(3))
op(0x38, "sec") op(0x38, "sec")
op(0x39, "and", absoluteY()) op(0x39, "and", absoluteY())
op(0x3a, "dec") op(0x3a, "dec")
U op(0x3b, "nop", "$3b")
op(0x3c, "bit", absoluteX()) op(0x3c, "bit", absoluteX())
op(0x3d, "and", absoluteX()) op(0x3d, "and", absoluteX())
op(0x3e, "rol", absoluteX()) op(0x3e, "rol", absoluteX())
op(0x3f, "bbr", zeropageBitRelative(3))
op(0x40, "rti")
op(0x41, "eor", indirectX()) op(0x41, "eor", indirectX())
op(0x42, "say") op(0x42, "say")
op(0x43, "tma", immediate()) op(0x43, "tma", immediate())
op(0x44, "bsr", relative())
op(0x45, "eor", zeropage()) op(0x45, "eor", zeropage())
op(0x46, "lsr", zeropage()) op(0x46, "lsr", zeropage())
op(0x47, "rmb", zeropageBit(4))
op(0x48, "pha") op(0x48, "pha")
op(0x49, "eor", immediate()) op(0x49, "eor", immediate())
op(0x4a, "lsr") op(0x4a, "lsr")
U op(0x4b, "nop", "$4b")
op(0x4c, "jmp", absolute())
op(0x4d, "eor", absolute()) op(0x4d, "eor", absolute())
op(0x4e, "lsr", absolute()) op(0x4e, "lsr", absolute())
op(0x4f, "bbr", zeropageBitRelative(4))
op(0x50, "bvc", relative()) op(0x50, "bvc", relative())
op(0x51, "eor", indirectY()) op(0x51, "eor", indirectY())
op(0x52, "eor", indirect()) op(0x52, "eor", indirect())
@ -96,125 +158,180 @@ auto HuC6280::disassemble(uint16 pc_) -> string {
op(0x54, "csl") op(0x54, "csl")
op(0x55, "eor", zeropageX()) op(0x55, "eor", zeropageX())
op(0x56, "lsr", zeropageX()) op(0x56, "lsr", zeropageX())
op(0x57, "rmb", zeropageBit(5))
op(0x58, "cli") op(0x58, "cli")
op(0x59, "eor", absoluteY()) op(0x59, "eor", absoluteY())
op(0x5a, "phy") op(0x5a, "phy")
U op(0x5b, "nop", "$5b")
U op(0x5c, "nop", "$5c")
op(0x5d, "eor", absoluteX()) op(0x5d, "eor", absoluteX())
op(0x5e, "lsr", absoluteX()) op(0x5e, "lsr", absoluteX())
op(0x5f, "bbr", zeropageBitRelative(5))
op(0x60, "rts")
op(0x61, "adc", indirectX()) op(0x61, "adc", indirectX())
op(0x62, "cla") op(0x62, "cla")
U op(0x63, "nop", "$63")
op(0x64, "stz", zeropage()) op(0x64, "stz", zeropage())
op(0x65, "adc", zeropage()) op(0x65, "adc", zeropage())
op(0x66, "ror", zeropage()) op(0x66, "ror", zeropage())
op(0x67, "rmb", zeropageBit(6))
op(0x68, "pla") op(0x68, "pla")
op(0x69, "adc", immediate()) op(0x69, "adc", immediate())
op(0x6a, "ror") op(0x6a, "ror")
U op(0x6b, "nop", "$6b")
op(0x6c, "jmp", indirectLong())
op(0x6d, "adc", absolute()) op(0x6d, "adc", absolute())
op(0x6e, "ror", absolute()) op(0x6e, "ror", absolute())
op(0x6f, "bbr", zeropageBitRelative(6))
op(0x70, "bvs", relative()) op(0x70, "bvs", relative())
op(0x71, "adc", indirectY()) op(0x71, "adc", indirectY())
op(0x72, "adc", indirect()) op(0x72, "adc", indirect())
op(0x73, "tii", blockMove())
op(0x74, "stz", zeropageX()) op(0x74, "stz", zeropageX())
op(0x75, "adc", zeropageX()) op(0x75, "adc", zeropageX())
op(0x76, "ror", zeropageX()) op(0x76, "ror", zeropageX())
op(0x77, "rmb", zeropageBit(7))
op(0x78, "sei") op(0x78, "sei")
op(0x79, "adc", absoluteY()) op(0x79, "adc", absoluteY())
op(0x7a, "ply") op(0x7a, "ply")
U op(0x7b, "nop", "$7b")
op(0x7c, "jmp", indirectLongX())
op(0x7d, "adc", absoluteX()) op(0x7d, "adc", absoluteX())
op(0x7e, "ror", absoluteX()) op(0x7e, "ror", absoluteX())
op(0x7f, "bbr", zeropageBitRelative(7))
op(0x80, "bra", relative()) op(0x80, "bra", relative())
op(0x81, "sta", indirectX()) op(0x81, "sta", indirectX())
op(0x82, "clx") op(0x82, "clx")
op(0x83, "tst", immediateZeropage())
op(0x84, "sty", zeropage()) op(0x84, "sty", zeropage())
op(0x85, "sta", zeropage()) op(0x85, "sta", zeropage())
op(0x86, "stx", zeropage()) op(0x86, "stx", zeropage())
op(0x87, "smb", zeropageBit(0))
op(0x88, "dey") op(0x88, "dey")
op(0x89, "bit", immediate()) op(0x89, "bit", immediate())
op(0x8a, "txa") op(0x8a, "txa")
U op(0x8b, "nop", "$8b")
op(0x8c, "sty", absolute()) op(0x8c, "sty", absolute())
op(0x8d, "sta", absolute()) op(0x8d, "sta", absolute())
op(0x8e, "stx", absolute()) op(0x8e, "stx", absolute())
op(0x8f, "bbs", zeropageBitRelative(0))
op(0x90, "bcc", relative()) op(0x90, "bcc", relative())
op(0x91, "sta", indirectY()) op(0x91, "sta", indirectY())
op(0x92, "sta", indirect()) op(0x92, "sta", indirect())
op(0x93, "tst", immediateAbsolute())
op(0x94, "sty", zeropageX()) op(0x94, "sty", zeropageX())
op(0x95, "sta", zeropageX()) op(0x95, "sta", zeropageX())
op(0x96, "stx", zeropageY()) op(0x96, "stx", zeropageY())
op(0x97, "smb", zeropageBit(1))
op(0x98, "tya") op(0x98, "tya")
op(0x99, "sta", absoluteY()) op(0x99, "sta", absoluteY())
op(0x9a, "txs") op(0x9a, "txs")
U op(0x9b, "nop", "$9b")
op(0x9c, "stz", absolute()) op(0x9c, "stz", absolute())
op(0x9d, "sta", absoluteX()) op(0x9d, "sta", absoluteX())
op(0x9e, "stz", absoluteX()) op(0x9e, "stz", absoluteX())
op(0x9f, "bbs", zeropageBitRelative(1))
op(0xa0, "ldy", immediate()) op(0xa0, "ldy", immediate())
op(0xa1, "lda", indirectX()) op(0xa1, "lda", indirectX())
op(0xa2, "ldx", immediate()) op(0xa2, "ldx", immediate())
op(0xa3, "tst", immediateZeropage("x"))
op(0xa4, "ldy", zeropage()) op(0xa4, "ldy", zeropage())
op(0xa5, "lda", zeropage()) op(0xa5, "lda", zeropage())
op(0xa6, "ldx", zeropage()) op(0xa6, "ldx", zeropage())
op(0xa7, "smb", zeropageBit(2))
op(0xa8, "tay") op(0xa8, "tay")
op(0xa9, "lda", immediate()) op(0xa9, "lda", immediate())
op(0xaa, "tax") op(0xaa, "tax")
U op(0xab, "nop", "$ab")
op(0xac, "ldy", absolute()) op(0xac, "ldy", absolute())
op(0xad, "lda", absolute()) op(0xad, "lda", absolute())
op(0xae, "ldx", absolute()) op(0xae, "ldx", absolute())
op(0xaf, "bbs", zeropageBitRelative(2))
op(0xb0, "bcs", relative()) op(0xb0, "bcs", relative())
op(0xb1, "lda", indirectY()) op(0xb1, "lda", indirectY())
op(0xb2, "lda", indirect()) op(0xb2, "lda", indirect())
op(0xb3, "tst", immediateAbsolute("x"))
op(0xb4, "ldy", zeropageX()) op(0xb4, "ldy", zeropageX())
op(0xb5, "lda", zeropageX()) op(0xb5, "lda", zeropageX())
op(0xb6, "ldx", zeropageY()) op(0xb6, "ldx", zeropageY())
op(0xb7, "smb", zeropageBit(3))
op(0xb8, "clv") op(0xb8, "clv")
op(0xb9, "lda", absoluteY()) op(0xb9, "lda", absoluteY())
op(0xba, "tsx") op(0xba, "tsx")
U op(0xbb, "nop", "$bb")
op(0xbc, "ldy", absoluteX()) op(0xbc, "ldy", absoluteX())
op(0xbd, "lda", absoluteX()) op(0xbd, "lda", absoluteX())
op(0xbe, "ldx", absoluteY()) op(0xbe, "ldx", absoluteY())
op(0xbf, "bbs", zeropageBitRelative(3))
op(0xc0, "cpy", immediate()) op(0xc0, "cpy", immediate())
op(0xc1, "cmp", indirectX()) op(0xc1, "cmp", indirectX())
op(0xc2, "cly") op(0xc2, "cly")
op(0xc3, "tdd", blockMove())
op(0xc4, "cpy", zeropage())
op(0xc5, "cmp", zeropage()) op(0xc5, "cmp", zeropage())
op(0xc6, "dec", zeropage()) op(0xc6, "dec", zeropage())
op(0xc7, "smb", zeropageBit(4))
op(0xc8, "iny") op(0xc8, "iny")
op(0xc9, "cmp", immediate()) op(0xc9, "cmp", immediate())
op(0xca, "dex") op(0xca, "dex")
U op(0xcb, "nop", "$cb")
op(0xcc, "cpy", absolute())
op(0xcd, "cmp", absolute()) op(0xcd, "cmp", absolute())
op(0xce, "dec", absolute()) op(0xce, "dec", absolute())
op(0xcf, "bbs", zeropageBitRelative(4))
op(0xd0, "bne", relative()) op(0xd0, "bne", relative())
op(0xd1, "cmp", indirectY()) op(0xd1, "cmp", indirectY())
op(0xd2, "cmp", indirect()) op(0xd2, "cmp", indirect())
op(0xd3, "tin", blockMove())
op(0xd4, "csh") op(0xd4, "csh")
op(0xd5, "cmp", zeropageX()) op(0xd5, "cmp", zeropageX())
op(0xd6, "dec", zeropageX()) op(0xd6, "dec", zeropageX())
op(0xd7, "smb", zeropageBit(5))
op(0xd8, "cld") op(0xd8, "cld")
op(0xd9, "cmp", absoluteY()) op(0xd9, "cmp", absoluteY())
op(0xda, "phx") op(0xda, "phx")
U op(0xdb, "nop", "$db")
U op(0xdc, "nop", "$dc")
op(0xdd, "cmp", absoluteX()) op(0xdd, "cmp", absoluteX())
op(0xde, "dec", absoluteX()) op(0xde, "dec", absoluteX())
op(0xdf, "bbs", zeropageBitRelative(5))
op(0xe0, "cpx", immediate()) op(0xe0, "cpx", immediate())
op(0xe1, "sbc", indirectX()) op(0xe1, "sbc", indirectX())
U op(0xe2, "nop", "$e2")
op(0xe3, "tia", blockMove())
op(0xe4, "cpx", zeropage())
op(0xe5, "sbc", zeropage()) op(0xe5, "sbc", zeropage())
op(0xe6, "inc", zeropage()) op(0xe6, "inc", zeropage())
op(0xe7, "smb", zeropageBit(6))
op(0xe8, "inx") op(0xe8, "inx")
op(0xe9, "sbc", immediate()) op(0xe9, "sbc", immediate())
op(0xea, "nop") op(0xea, "nop")
U op(0xeb, "nop", "$eb")
op(0xec, "cpx", absolute())
op(0xed, "sbc", absolute()) op(0xed, "sbc", absolute())
op(0xee, "inc", absolute()) op(0xee, "inc", absolute())
op(0xef, "bbs", zeropageBitRelative(6))
op(0xf0, "beq", relative()) op(0xf0, "beq", relative())
op(0xf1, "sbc", indirectY()) op(0xf1, "sbc", indirectY())
op(0xf2, "sbc", indirect()) op(0xf2, "sbc", indirect())
op(0xf3, "tai", blockMove())
op(0xf4, "set") op(0xf4, "set")
op(0xf5, "sbc", zeropageX()) op(0xf5, "sbc", zeropageX())
op(0xf6, "inc", zeropageX()) op(0xf6, "inc", zeropageX())
op(0xf7, "smb", zeropageBit(7))
op(0xf8, "sed") op(0xf8, "sed")
op(0xf9, "sbc", absoluteY()) op(0xf9, "sbc", absoluteY())
op(0xfa, "plx") op(0xfa, "plx")
U op(0xfb, "nop", "$fb")
U op(0xfc, "nop", "$fc")
op(0xfd, "sbc", absoluteX()) op(0xfd, "sbc", absoluteX())
op(0xfe, "inc", absoluteX()) op(0xfe, "inc", absoluteX())
op(0xff, "bbs", zeropageBitRelative(7))
} }
#undef U
if(!o) o = {"??? (", hex(opcode, 2L), ")"}; if(!o) o = {"??? (", hex(opcode, 2L), ")"};
s.append(pad(o, -16L, ' ')); s.append(pad(o, -22L, ' '));
#undef op #undef op
s.append(" A:", hex(r.a, 2L)); s.append(" A:", hex(r.a, 2L));

View File

@ -8,6 +8,7 @@ struct HuC6280 {
virtual auto step(uint clocks) -> void = 0; virtual auto step(uint clocks) -> void = 0;
virtual auto read(uint21 addr) -> uint8 = 0; virtual auto read(uint21 addr) -> uint8 = 0;
virtual auto write(uint21 addr, uint8 data) -> void = 0; virtual auto write(uint21 addr, uint8 data) -> void = 0;
virtual auto st(uint2, uint8) -> void = 0;
virtual auto lastCycle() -> void = 0; virtual auto lastCycle() -> void = 0;
auto power() -> void; auto power() -> void;
@ -28,6 +29,7 @@ struct HuC6280 {
auto instruction() -> void; auto instruction() -> void;
//instructions.cpp //instructions.cpp
using fp = auto (HuC6280::*)(uint8) -> uint8;
auto ADC(uint8) -> uint8; auto ADC(uint8) -> uint8;
auto AND(uint8) -> uint8; auto AND(uint8) -> uint8;
auto ASL(uint8) -> uint8; auto ASL(uint8) -> uint8;
@ -44,39 +46,60 @@ struct HuC6280 {
auto ROL(uint8) -> uint8; auto ROL(uint8) -> uint8;
auto ROR(uint8) -> uint8; auto ROR(uint8) -> uint8;
auto SBC(uint8) -> uint8; auto SBC(uint8) -> uint8;
auto TRB(uint8) -> uint8;
auto TSB(uint8) -> uint8;
using fp = auto (HuC6280::*)(uint8) -> uint8; using bp = auto (HuC6280::*)(uint16&, uint16&) -> void;
auto instruction_alu_absolute(fp, uint8 = 0) -> void; auto TAI(uint16&, uint16&) -> void;
auto instruction_alu_immediate(fp) -> void; auto TDD(uint16&, uint16&) -> void;
auto instruction_alu_implied(fp, uint8&) -> void; auto TIA(uint16&, uint16&) -> void;
auto instruction_alu_indirect(fp, uint8 = 0) -> void; auto TII(uint16&, uint16&) -> void;
auto instruction_alu_indirectY(fp) -> void; auto TIN(uint16&, uint16&) -> void;
auto instruction_alu_memory(fp) -> void;
auto instruction_alu_zeropage(fp, uint8 = 0) -> void; auto instruction_absoluteLoad(fp, uint8&, uint8 = 0) -> void;
auto instruction_bra(bool) -> void; auto instruction_absoluteModify(fp, uint8 = 0) -> void;
auto instruction_CLb(uint8&) -> void; auto instruction_absoluteStore(uint8, uint8 = 0) -> void;
auto instruction_CLf(bool&) -> void; auto instruction_blockmove(bp) -> void;
auto instruction_branch(bool) -> void;
auto instruction_clear(uint8&) -> void;
auto instruction_clear(bool&) -> void;
auto instruction_immediate(fp, uint8&) -> void;
auto instruction_implied(fp, uint8&) -> void;
auto instruction_indirectLoad(fp, uint8&, uint8 = 0) -> void;
auto instruction_indirectStore(uint8, uint8 = 0) -> void;
auto instruction_indirectYLoad(fp, uint8&) -> void;
auto instruction_indirectYStore(uint8) -> void;
auto instruction_memory(fp) -> void;
auto instruction_pull(uint8&) -> void;
auto instruction_pullP() -> void;
auto instruction_push(uint8) -> void;
auto instruction_set(bool&) -> void;
auto instruction_swap(uint8&, uint8&) -> void;
auto instruction_transfer(uint8&, uint8&) -> void;
auto instruction_zeropageLoad(fp, uint8&, uint8 = 0) -> void;
auto instruction_zeropageModify(fp, uint8 = 0) -> void;
auto instruction_zeropageStore(uint8, uint8 = 0) -> void;
auto instruction_BBR(uint3) -> void;
auto instruction_BBS(uint3) -> void;
auto instruction_BRK() -> void;
auto instruction_BSR() -> void;
auto instruction_CSL() -> void; auto instruction_CSL() -> void;
auto instruction_CSH() -> void; auto instruction_CSH() -> void;
auto instruction_LDA_indirect(uint8 index = 0) -> void; auto instruction_JMP_absolute() -> void;
auto instruction_LDA_indirectY() -> void; auto instruction_JMP_indirect(uint8 = 0) -> void;
auto instruction_LDb_absolute(uint8&, uint8 = 0) -> void; auto instruction_JSR() -> void;
auto instruction_LDb_immediate(uint8&) -> void;
auto instruction_LDb_zeropage(uint8&, uint8 = 0) -> void;
auto instruction_NOP() -> void; auto instruction_NOP() -> void;
auto instruction_PHb(uint8&) -> void;
auto instruction_PHP() -> void; auto instruction_PHP() -> void;
auto instruction_PLb(uint8&) -> void; auto instruction_RMB(uint3) -> void;
auto instruction_PLP() -> void; auto instruction_RTI() -> void;
auto instruction_SEf(bool&) -> void; auto instruction_RTS() -> void;
auto instruction_STA_indirect(uint8 index = 0) -> void; auto instruction_SMB(uint3) -> void;
auto instruction_STA_indirectY() -> void; auto instruction_ST(uint2) -> void;
auto instruction_STb_absolute(uint8, uint8 = 0) -> void;
auto instruction_STb_zeropage(uint8, uint8 = 0) -> void;
auto instruction_Sbb(uint8&, uint8&) -> void;
auto instruction_TAM() -> void; auto instruction_TAM() -> void;
auto instruction_Tbb(uint8&, uint8&) -> void;
auto instruction_TMA() -> void; auto instruction_TMA() -> void;
auto instruction_TST_absolute(uint8 = 0) -> void;
auto instruction_TST_zeropage(uint8 = 0) -> void;
auto instruction_TXS() -> void; auto instruction_TXS() -> void;
//disassembler.cpp //disassembler.cpp

View File

@ -7,189 +7,273 @@ auto HuC6280::instruction() -> void {
if(T) { if(T) {
T = 0; T = 0;
switch(code) { switch(code) {
op(0x09, alu_memory, fp(ORA)) op(0x09, memory, fp(ORA))
op(0x29, alu_memory, fp(AND)) op(0x29, memory, fp(AND))
op(0x49, alu_memory, fp(EOR)) op(0x49, memory, fp(EOR))
op(0x69, alu_memory, fp(ADC)) op(0x69, memory, fp(ADC))
} }
} }
#define U
switch(code) { switch(code) {
op(0x01, alu_indirect, fp(ORA), X) op(0x00, BRK)
op(0x02, Sbb, X, Y) op(0x01, indirectLoad, fp(ORA), A, X)
op(0x05, alu_zeropage, fp(ORA)) op(0x02, swap, X, Y)
op(0x06, alu_zeropage, fp(ASL)) op(0x03, ST, 0)
op(0x08, PHP) op(0x04, zeropageModify, fp(TSB))
op(0x09, alu_immediate, fp(ORA)) op(0x05, zeropageLoad, fp(ORA), A)
op(0x0a, alu_implied, fp(ASL), A) op(0x06, zeropageModify, fp(ASL))
op(0x0d, alu_absolute, fp(ORA)) op(0x07, RMB, 0)
op(0x0e, alu_absolute, fp(ASL)) op(0x08, push, P)
op(0x10, bra, N == 0) op(0x09, immediate, fp(ORA), A)
op(0x11, alu_indirectY, fp(ORA)) op(0x0a, implied, fp(ASL), A)
op(0x12, alu_indirect, fp(ORA)) U op(0x0b, NOP)
op(0x15, alu_zeropage, fp(ORA), X) op(0x0c, absoluteModify, fp(TSB))
op(0x16, alu_zeropage, fp(ASL), X) op(0x0d, absoluteLoad, fp(ORA), A)
op(0x18, CLf, C) op(0x0e, absoluteModify, fp(ASL))
op(0x19, alu_absolute, fp(ORA), Y) op(0x0f, BBR, 0)
op(0x1a, alu_implied, fp(INC), A) op(0x10, branch, N == 0)
op(0x1d, alu_absolute, fp(ORA), X) op(0x11, indirectYLoad, fp(ORA), A)
op(0x1e, alu_absolute, fp(ASL), X) op(0x12, indirectLoad, fp(ORA), A)
op(0x21, alu_indirect, fp(AND), X) op(0x13, ST, 1)
op(0x22, Sbb, A, X) op(0x14, zeropageModify, fp(TRB))
op(0x24, alu_zeropage, fp(BIT)) op(0x15, zeropageLoad, fp(ORA), A, X)
op(0x25, alu_zeropage, fp(AND)) op(0x16, zeropageModify, fp(ASL), X)
op(0x26, alu_zeropage, fp(ROL)) op(0x17, RMB, 1)
op(0x28, PLP) op(0x18, clear, C)
op(0x29, alu_immediate, fp(AND)) op(0x19, absoluteLoad, fp(ORA), A, Y)
op(0x2a, alu_implied, fp(ROL), A) op(0x1a, implied, fp(INC), A)
op(0x2c, alu_absolute, fp(BIT)) U op(0x1b, NOP)
op(0x2d, alu_absolute, fp(AND)) op(0x1c, absoluteModify, fp(TRB))
op(0x2e, alu_absolute, fp(ROL)) op(0x1d, absoluteLoad, fp(ORA), A, X)
op(0x30, bra, N == 1) op(0x1e, absoluteModify, fp(ASL), X)
op(0x31, alu_indirectY, fp(AND)) op(0x1f, BBR, 1)
op(0x32, alu_indirect, fp(AND)) op(0x20, JSR)
op(0x34, alu_zeropage, fp(BIT), X) op(0x21, indirectLoad, fp(AND), A, X)
op(0x35, alu_zeropage, fp(AND), X) op(0x22, swap, A, X)
op(0x36, alu_zeropage, fp(ROL), X) op(0x23, ST, 2)
op(0x38, SEf, C) op(0x24, zeropageLoad, fp(BIT), A)
op(0x39, alu_absolute, fp(AND), Y) op(0x25, zeropageLoad, fp(AND), A)
op(0x3a, alu_implied, fp(DEC), A) op(0x26, zeropageModify, fp(ROL))
op(0x3c, alu_absolute, fp(BIT), X) op(0x27, RMB, 2)
op(0x3d, alu_absolute, fp(AND), X) op(0x28, pullP)
op(0x3e, alu_absolute, fp(ROL), X) op(0x29, immediate, fp(AND), A)
op(0x41, alu_indirect, fp(EOR), X) op(0x2a, implied, fp(ROL), A)
op(0x42, Sbb, A, Y) U op(0x2b, NOP)
op(0x2c, absoluteLoad, fp(BIT), A)
op(0x2d, absoluteLoad, fp(AND), A)
op(0x2e, absoluteModify, fp(ROL))
op(0x2f, BBR, 2)
op(0x30, branch, N == 1)
op(0x31, indirectYLoad, fp(AND), A)
op(0x32, indirectLoad, fp(AND), A)
U op(0x33, NOP)
op(0x34, zeropageLoad, fp(BIT), A, X)
op(0x35, zeropageLoad, fp(AND), A, X)
op(0x36, zeropageModify, fp(ROL), X)
op(0x37, RMB, 3)
op(0x38, set, C)
op(0x39, absoluteLoad, fp(AND), A, Y)
op(0x3a, implied, fp(DEC), A)
U op(0x3b, NOP)
op(0x3c, absoluteLoad, fp(BIT), A, X)
op(0x3d, absoluteLoad, fp(AND), A, X)
op(0x3e, absoluteModify, fp(ROL), X)
op(0x3f, BBR, 3)
op(0x40, RTI)
op(0x41, indirectLoad, fp(EOR), A, X)
op(0x42, swap, A, Y)
op(0x43, TMA) op(0x43, TMA)
op(0x45, alu_zeropage, fp(EOR)) op(0x44, BSR)
op(0x46, alu_zeropage, fp(LSR)) op(0x45, zeropageLoad, fp(EOR), A)
op(0x48, PHb, A) op(0x46, zeropageModify, fp(LSR))
op(0x49, alu_immediate, fp(EOR)) op(0x47, RMB, 4)
op(0x4a, alu_implied, fp(LSR), A) op(0x48, push, A)
op(0x4d, alu_absolute, fp(EOR)) op(0x49, immediate, fp(EOR), A)
op(0x4e, alu_absolute, fp(LSR)) op(0x4a, implied, fp(LSR), A)
op(0x50, bra, V == 0) U op(0x4b, NOP)
op(0x51, alu_indirectY, fp(EOR)) op(0x4c, JMP_absolute)
op(0x52, alu_indirect, fp(EOR)) op(0x4d, absoluteLoad, fp(EOR), A)
op(0x4e, absoluteModify, fp(LSR))
op(0x4f, BBR, 4)
op(0x50, branch, V == 0)
op(0x51, indirectYLoad, fp(EOR), A)
op(0x52, indirectLoad, fp(EOR), A)
op(0x53, TAM) op(0x53, TAM)
op(0x54, CSL) op(0x54, CSL)
op(0x55, alu_zeropage, fp(EOR), X) op(0x55, zeropageLoad, fp(EOR), A, X)
op(0x56, alu_zeropage, fp(LSR), X) op(0x56, zeropageModify, fp(LSR), X)
op(0x58, CLf, I) op(0x57, RMB, 5)
op(0x59, alu_absolute, fp(EOR), Y) op(0x58, clear, I)
op(0x5a, PHb, Y) op(0x59, absoluteLoad, fp(EOR), A, Y)
op(0x5d, alu_absolute, fp(EOR), X) op(0x5a, push, Y)
op(0x5e, alu_absolute, fp(LSR), X) U op(0x5b, NOP)
op(0x61, alu_indirect, fp(ADC), X) U op(0x5c, NOP)
op(0x62, CLb, A) op(0x5d, absoluteLoad, fp(EOR), A, X)
op(0x64, STb_zeropage, 0) op(0x5e, absoluteModify, fp(LSR), X)
op(0x65, alu_zeropage, fp(ADC)) op(0x5f, BBR, 5)
op(0x66, alu_zeropage, fp(ROR)) op(0x60, RTS)
op(0x68, PLb, A) op(0x61, indirectLoad, fp(ADC), A, X)
op(0x69, alu_immediate, fp(ADC)) op(0x62, clear, A)
op(0x6a, alu_implied, fp(ROR), A) U op(0x63, NOP)
op(0x6d, alu_absolute, fp(ADC)) op(0x64, zeropageStore, 0)
op(0x6e, alu_absolute, fp(ROR)) op(0x65, zeropageLoad, fp(ADC), A)
op(0x70, bra, V == 1) op(0x66, zeropageModify, fp(ROR))
op(0x71, alu_indirectY, fp(ADC)) op(0x67, RMB, 6)
op(0x72, alu_indirect, fp(ADC)) op(0x68, pull, A)
op(0x74, STb_zeropage, 0, X) op(0x69, immediate, fp(ADC), A)
op(0x75, alu_zeropage, fp(ADC), X) op(0x6a, implied, fp(ROR), A)
op(0x76, alu_zeropage, fp(ROR), X) U op(0x6b, NOP)
op(0x78, SEf, I) op(0x6c, JMP_indirect)
op(0x79, alu_absolute, fp(ADC), Y) op(0x6d, absoluteLoad, fp(ADC), A)
op(0x7a, PLb, Y) op(0x6e, absoluteModify, fp(ROR))
op(0x7d, alu_absolute, fp(ADC), X) op(0x6f, BBR, 6)
op(0x7e, alu_absolute, fp(ROR), X) op(0x70, branch, V == 1)
op(0x80, bra, 1) op(0x71, indirectYLoad, fp(ADC), A)
op(0x81, STA_indirect, X) op(0x72, indirectLoad, fp(ADC), A)
op(0x82, CLb, X) op(0x73, blockmove, fp(TII))
op(0x84, STb_zeropage, Y) op(0x74, zeropageStore, 0, X)
op(0x85, STb_zeropage, A) op(0x75, zeropageLoad, fp(ADC), A, X)
op(0x86, STb_zeropage, X) op(0x76, zeropageModify, fp(ROR), X)
op(0x88, alu_implied, fp(DEC), Y) op(0x77, RMB, 7)
op(0x89, alu_immediate, fp(BIT)) op(0x78, set, I)
op(0x8a, Tbb, X, A) op(0x79, absoluteLoad, fp(ADC), A, Y)
op(0x8c, STb_absolute, Y) op(0x7a, pull, Y)
op(0x8d, STb_absolute, A) U op(0x7b, NOP)
op(0x8e, STb_absolute, X) op(0x7c, JMP_indirect, X)
op(0x90, bra, C == 0) op(0x7d, absoluteLoad, fp(ADC), A, X)
op(0x91, STA_indirectY) op(0x7e, absoluteModify, fp(ROR), X)
op(0x92, STA_indirect) op(0x7f, BBR, 7)
op(0x94, STb_zeropage, Y, X) op(0x80, branch, 1)
op(0x95, STb_zeropage, A, X) op(0x81, indirectStore, A, X)
op(0x96, STb_zeropage, X, Y) op(0x82, clear, X)
op(0x98, Tbb, Y, A) op(0x83, TST_zeropage)
op(0x99, STb_absolute, A, Y) op(0x84, zeropageStore, Y)
op(0x85, zeropageStore, A)
op(0x86, zeropageStore, X)
op(0x87, SMB, 0)
op(0x88, implied, fp(DEC), Y)
op(0x89, immediate, fp(BIT), A)
op(0x8a, transfer, X, A)
U op(0x8b, NOP)
op(0x8c, absoluteStore, Y)
op(0x8d, absoluteStore, A)
op(0x8e, absoluteStore, X)
op(0x8f, BBS, 0)
op(0x90, branch, C == 0)
op(0x91, indirectYStore, A)
op(0x92, indirectStore, A)
op(0x93, TST_absolute)
op(0x94, zeropageStore, Y, X)
op(0x95, zeropageStore, A, X)
op(0x96, zeropageStore, X, Y)
op(0x97, SMB, 1)
op(0x98, transfer, Y, A)
op(0x99, absoluteStore, A, Y)
op(0x9a, TXS) op(0x9a, TXS)
op(0x9c, STb_absolute, 0) U op(0x9b, NOP)
op(0x9d, STb_absolute, A, X) op(0x9c, absoluteStore, 0)
op(0x9e, STb_absolute, 0, X) op(0x9d, absoluteStore, A, X)
op(0xa0, LDb_immediate, Y) op(0x9e, absoluteStore, 0, X)
op(0xa1, LDA_indirect, X) op(0x9f, BBS, 1)
op(0xa2, LDb_immediate, X) op(0xa0, immediate, fp(LD), Y)
op(0xa4, LDb_zeropage, Y) op(0xa1, indirectLoad, fp(LD), A, X)
op(0xa5, LDb_zeropage, A) op(0xa2, immediate, fp(LD), X)
op(0xa6, LDb_zeropage, X) op(0xa3, TST_zeropage, X)
op(0xa8, Tbb, A, Y) op(0xa4, zeropageLoad, fp(LD), Y)
op(0xa9, LDb_immediate, A) op(0xa5, zeropageLoad, fp(LD), A)
op(0xaa, Tbb, A, X) op(0xa6, zeropageLoad, fp(LD), X)
op(0xac, LDb_absolute, Y) op(0xa7, SMB, 2)
op(0xad, LDb_absolute, A) op(0xa8, transfer, A, Y)
op(0xae, LDb_absolute, X) op(0xa9, immediate, fp(LD), A)
op(0xb0, bra, C == 1) op(0xaa, transfer, A, X)
op(0xb1, LDA_indirectY) U op(0xab, NOP)
op(0xb2, LDA_indirect) op(0xac, absoluteLoad, fp(LD), Y)
op(0xb4, LDb_zeropage, Y, X) op(0xad, absoluteLoad, fp(LD), A)
op(0xb5, LDb_zeropage, A, X) op(0xae, absoluteLoad, fp(LD), X)
op(0xb6, LDb_zeropage, X, Y) op(0xaf, BBS, 2)
op(0xb8, CLf, V) op(0xb0, branch, C == 1)
op(0xb9, LDb_absolute, A, Y) op(0xb1, indirectYLoad, fp(LD), A)
op(0xba, Tbb, S, X) op(0xb2, indirectLoad, fp(LD), A)
op(0xbc, LDb_absolute, Y, X) op(0xb3, TST_absolute, X)
op(0xbd, LDb_absolute, A, X) op(0xb4, zeropageLoad, fp(LD), Y, X)
op(0xbe, LDb_absolute, X, Y) op(0xb5, zeropageLoad, fp(LD), A, X)
op(0xc0, alu_immediate, fp(CPY)) op(0xb6, zeropageLoad, fp(LD), X, Y)
op(0xc1, alu_indirect, fp(CMP), X) op(0xb7, SMB, 3)
op(0xc2, CLb, Y) op(0xb8, clear, V)
op(0xc5, alu_zeropage, fp(CMP)) op(0xb9, absoluteLoad, fp(LD), A, Y)
op(0xc6, alu_zeropage, fp(DEC)) op(0xba, transfer, S, X)
op(0xc8, alu_implied, fp(INC), Y) U op(0xbb, NOP)
op(0xc9, alu_immediate, fp(CMP)) op(0xbc, absoluteLoad, fp(LD), Y, X)
op(0xca, alu_implied, fp(DEC), X) op(0xbd, absoluteLoad, fp(LD), A, X)
op(0xcd, alu_absolute, fp(CMP)) op(0xbe, absoluteLoad, fp(LD), X, Y)
op(0xce, alu_absolute, fp(DEC)) op(0xbf, BBS, 3)
op(0xd0, bra, Z == 0) op(0xc0, immediate, fp(CPY), Y)
op(0xd1, alu_indirectY, fp(CMP)) op(0xc1, indirectLoad, fp(CMP), A, X)
op(0xd2, alu_indirect, fp(CMP)) op(0xc2, clear, Y)
op(0xc3, blockmove, fp(TDD))
op(0xc4, zeropageLoad, fp(CPY), Y)
op(0xc5, zeropageLoad, fp(CMP), A)
op(0xc6, zeropageModify, fp(DEC))
op(0xc7, SMB, 4)
op(0xc8, implied, fp(INC), Y)
op(0xc9, immediate, fp(CMP), A)
op(0xca, implied, fp(DEC), X)
U op(0xcb, NOP)
op(0xcc, absoluteLoad, fp(CPY), Y)
op(0xcd, absoluteLoad, fp(CMP), A)
op(0xce, absoluteModify, fp(DEC))
op(0xcf, BBS, 4)
op(0xd0, branch, Z == 0)
op(0xd1, indirectYLoad, fp(CMP), A)
op(0xd2, indirectLoad, fp(CMP), A)
op(0xd3, blockmove, fp(TIN))
op(0xd4, CSH) op(0xd4, CSH)
op(0xd5, alu_zeropage, fp(CMP), X) op(0xd5, zeropageLoad, fp(CMP), A, X)
op(0xd6, alu_zeropage, fp(DEC), X) op(0xd6, zeropageModify, fp(DEC), X)
op(0xd8, CLf, D) op(0xd7, SMB, 5)
op(0xd9, alu_absolute, fp(CMP), Y) op(0xd8, clear, D)
op(0xda, PHb, X) op(0xd9, absoluteLoad, fp(CMP), A, Y)
op(0xdd, alu_absolute, fp(CMP), X) op(0xda, push, X)
op(0xde, alu_absolute, fp(DEC), X) U op(0xdb, NOP)
op(0xe0, alu_immediate, fp(CPX)) U op(0xdc, NOP)
op(0xe1, alu_indirect, fp(SBC), X) op(0xdd, absoluteLoad, fp(CMP), A, X)
op(0xe5, alu_zeropage, fp(SBC)) op(0xde, absoluteModify, fp(DEC), X)
op(0xe6, alu_zeropage, fp(INC)) op(0xdf, BBS, 5)
op(0xe8, alu_implied, fp(INC), X) op(0xe0, immediate, fp(CPX), X)
op(0xe9, alu_immediate, fp(SBC)) op(0xe1, indirectLoad, fp(SBC), A, X)
U op(0xe2, NOP)
op(0xe3, blockmove, fp(TIA))
op(0xe4, zeropageLoad, fp(CPX), X)
op(0xe5, zeropageLoad, fp(SBC), A)
op(0xe6, zeropageModify, fp(INC))
op(0xe7, SMB, 6)
op(0xe8, implied, fp(INC), X)
op(0xe9, immediate, fp(SBC), A)
op(0xea, NOP) op(0xea, NOP)
op(0xed, alu_absolute, fp(SBC)) U op(0xeb, NOP)
op(0xee, alu_absolute, fp(INC)) op(0xec, absoluteLoad, fp(CPX), X)
op(0xf0, bra, Z == 1) op(0xed, absoluteLoad, fp(SBC), A)
op(0xf1, alu_indirectY, fp(SBC)) op(0xee, absoluteModify, fp(INC))
op(0xf2, alu_indirect, fp(SBC)) op(0xef, BBS, 6)
op(0xf4, SEf, T) op(0xf0, branch, Z == 1)
op(0xf5, alu_zeropage, fp(SBC), X) op(0xf1, indirectYLoad, fp(SBC), A)
op(0xf6, alu_zeropage, fp(INC), X) op(0xf2, indirectLoad, fp(SBC), A)
op(0xf8, SEf, D) op(0xf3, blockmove, fp(TAI))
op(0xf9, alu_absolute, fp(SBC), Y) op(0xf4, set, T)
op(0xfa, PLb, X) op(0xf5, zeropageLoad, fp(SBC), A, X)
op(0xfd, alu_absolute, fp(SBC), X) op(0xf6, zeropageModify, fp(INC), X)
op(0xfe, alu_absolute, fp(INC), X) op(0xf7, SMB, 7)
op(0xf8, set, D)
op(0xf9, absoluteLoad, fp(SBC), A, Y)
op(0xfa, pull, X)
U op(0xfb, NOP)
U op(0xfc, NOP)
op(0xfd, absoluteLoad, fp(SBC), A, X)
op(0xfe, absoluteModify, fp(INC), X)
op(0xff, BBS, 7)
} }
#undef U
} }
#undef op #undef op

View File

@ -117,76 +117,263 @@ auto HuC6280::SBC(uint8 i) -> uint8 {
return ADC(~i); return ADC(~i);
} }
auto HuC6280::TRB(uint8 i) -> uint8 {
uint8 o = i & A;
Z = o == 0;
V = o.bit(6);
N = o.bit(7);
return i & ~A;
}
auto HuC6280::TSB(uint8 i) -> uint8 {
uint8 o = i & A;
Z = o == 0;
V = o.bit(6);
N = o.bit(7);
return i | A;
}
// //
auto HuC6280::instruction_alu_absolute(fp alu, uint8 index) -> void { auto HuC6280::TAI(uint16& source, uint16& target) -> void {
source ^= 1;
target++;
}
auto HuC6280::TDD(uint16& source, uint16& target) -> void {
source--;
target--;
}
auto HuC6280::TIA(uint16& source, uint16& target) -> void {
source++;
target ^= 1;
}
auto HuC6280::TII(uint16& source, uint16& target) -> void {
source++;
target++;
}
auto HuC6280::TIN(uint16& source, uint16& target) -> void {
source++;
}
//
auto HuC6280::instruction_absoluteLoad(fp alu, uint8& data, uint8 index) -> void {
uint16 absolute = operand(); uint16 absolute = operand();
absolute |= operand() << 8; absolute |= operand() << 8;
io(); io();
L A = ALU(load(absolute + index)); L data = ALU(load(absolute + index));
} }
auto HuC6280::instruction_alu_immediate(fp alu) -> void { auto HuC6280::instruction_absoluteModify(fp alu, uint8 index) -> void {
A = ALU(operand()); uint16 absolute = operand();
absolute |= operand() << 8;
io();
io();
auto data = ALU(load(absolute + index));
L store(absolute + index, data);
}
auto HuC6280::instruction_absoluteStore(uint8 data, uint8 index) -> void {
uint16 absolute = operand();
absolute |= operand() << 8;
io();
L store(absolute + index, data);
}
auto HuC6280::instruction_blockmove(bp alu) -> void {
uint16 source = operand();
source |= operand() << 8;
uint16 target = operand();
target |= operand() << 8;
uint16 length = operand();
length |= operand() << 8;
do {
auto data = load(source);
store(target, data);
ALU(source, target);
} while(--length);
L io(); L io();
} }
auto HuC6280::instruction_alu_implied(fp alu, uint8& b) -> void { auto HuC6280::instruction_branch(bool take) -> void {
b = ALU(b); if(!take) {
L io();
}
auto HuC6280::instruction_alu_indirect(fp alu, uint8 index) -> void {
auto zeropage = operand();
io();
auto absolute = load(0x2000 + zeropage + index);
absolute |= load(0x2001 + zeropage + index) << 8;
L A = ALU(load(absolute));
}
auto HuC6280::instruction_alu_indirectY(fp alu) -> void {
auto zeropage = operand();
io();
auto absolute = load(0x2000 + zeropage);
absolute |= load(0x2001 + zeropage) << 8;
L A = ALU(load(absolute + Y));
}
auto HuC6280::instruction_alu_memory(fp alu) -> void {
auto a = A;
A = load(0x2000 + X);
instruction_alu_immediate(alu);
store(0x2000 + X, A);
A = a;
}
auto HuC6280::instruction_alu_zeropage(fp alu, uint8 index) -> void {
auto zeropage = operand();
io();
L A = ALU(load(0x2000 + zeropage + index));
}
auto HuC6280::instruction_bra(bool c) -> void {
if(!c) {
L operand(); L operand();
} else { } else {
auto displacement = operand(); auto displacement = operand();
io(); io();
L io(); L io();
PC = PC + (int8)displacement; PC += (int8)displacement;
} }
} }
auto HuC6280::instruction_CLb(uint8& b) -> void { auto HuC6280::instruction_clear(uint8& data) -> void {
b = 0; data = 0;
L io(); L io();
} }
auto HuC6280::instruction_CLf(bool& f) -> void { auto HuC6280::instruction_clear(bool& flag) -> void {
f = 0; flag = 0;
L io(); L io();
} }
auto HuC6280::instruction_immediate(fp alu, uint8& data) -> void {
data = ALU(operand());
L io();
}
auto HuC6280::instruction_implied(fp alu, uint8& data) -> void {
data = ALU(data);
L io();
}
auto HuC6280::instruction_indirectLoad(fp alu, uint8& data, uint8 index) -> void {
auto zeropage = operand();
io();
uint16 absolute = load(0x2000 + zeropage + index);
absolute |= load(0x2001 + zeropage + index) << 8;
io();
L data = ALU(load(absolute));
}
auto HuC6280::instruction_indirectStore(uint8 data, uint8 index) -> void {
auto zeropage = operand();
io();
auto absolute = load(0x2000 + zeropage + index);
absolute |= load(0x2001 + zeropage + index) << 8;
L store(absolute, data);
}
auto HuC6280::instruction_indirectYLoad(fp alu, uint8& data) -> void {
auto zeropage = operand();
io();
uint16 absolute = load(0x2000 + zeropage);
absolute |= load(0x2001 + zeropage) << 8;
io();
L data = ALU(load(absolute + Y));
}
auto HuC6280::instruction_indirectYStore(uint8 data) -> void {
auto zeropage = operand();
io();
auto absolute = load(0x2000 + zeropage);
absolute |= load(0x2001 + zeropage) << 8;
L store(absolute + Y, data);
}
auto HuC6280::instruction_memory(fp alu) -> void {
auto a = A;
A = ALU(load(0x2000 + X));
L store(0x2000 + X, A);
A = a;
}
auto HuC6280::instruction_pull(uint8& data) -> void {
io();
io();
L data = pull();
}
auto HuC6280::instruction_pullP() -> void {
io();
io();
L P = pull();
}
auto HuC6280::instruction_push(uint8 data) -> void {
io();
L push(data);
}
auto HuC6280::instruction_set(bool& flag) -> void {
flag = 1;
L io();
}
auto HuC6280::instruction_swap(uint8& lhs, uint8& rhs) -> void {
swap(lhs, rhs);
io();
L io();
}
auto HuC6280::instruction_transfer(uint8& source, uint8& target) -> void {
target = source;
L io();
Z = target == 0;
N = target.bit(7);
}
auto HuC6280::instruction_zeropageLoad(fp alu, uint8& data, uint8 index) -> void {
auto zeropage = operand();
io();
L data = ALU(load(0x2000 + zeropage + index));
}
auto HuC6280::instruction_zeropageModify(fp alu, uint8 index) -> void {
auto zeropage = operand();
io();
io();
auto data = ALU(load(0x2000 + zeropage + index));
L store(0x2000 + zeropage + index, data);
}
auto HuC6280::instruction_zeropageStore(uint8 data, uint8 index) -> void {
auto zeropage = operand();
io();
L store(0x2000 + zeropage + index, data);
}
//
auto HuC6280::instruction_BBR(uint3 index) -> void {
auto zeropage = operand();
auto displacement = operand();
io();
io();
L io();
if(zeropage.bit(index) == 0) {
PC += (int8)displacement;
}
}
auto HuC6280::instruction_BBS(uint3 index) -> void {
auto zeropage = operand();
auto displacement = operand();
io();
io();
L io();
if(zeropage.bit(index) == 1) {
PC += (int8)displacement;
}
}
auto HuC6280::instruction_BRK() -> void {
operand();
io();
push(PC >> 8);
push(PC >> 0);
uint8 p = P;
push(p | 0x10); //B flag set on push
I = 1;
D = 0;
PC.byte(0) = load(0xfff6);
L PC.byte(1) = load(0xfff7);
}
auto HuC6280::instruction_BSR() -> void {
auto displacement = operand();
io();
io();
io();
io();
push((PC - 1) >> 8);
L push((PC - 1) >> 0);
PC += (int8)displacement;
}
auto HuC6280::instruction_CSL() -> void { auto HuC6280::instruction_CSL() -> void {
r.cs = 12; r.cs = 12;
L io(); L io();
@ -197,104 +384,80 @@ auto HuC6280::instruction_CSH() -> void {
L io(); L io();
} }
auto HuC6280::instruction_LDA_indirect(uint8 index) -> void { auto HuC6280::instruction_JMP_absolute() -> void {
auto zeropage = operand(); uint16 address = operand();
io(); address |= operand() << 8;
auto absolute = load(0x2000 + zeropage + index);
absolute |= load(0x2001 + zeropage + index) << 8;
L A = LD(load(absolute));
}
auto HuC6280::instruction_LDA_indirectY() -> void {
auto zeropage = operand();
io();
auto absolute = load(0x2000 + zeropage);
absolute |= load(0x2001 + zeropage) << 8;
L A = LD(load(absolute + Y));
}
auto HuC6280::instruction_LDb_absolute(uint8& b, uint8 index) -> void {
uint16 absolute = operand();
absolute |= operand() << 8;
io();
L b = LD(load(absolute + index));
}
auto HuC6280::instruction_LDb_immediate(uint8& b) -> void {
b = LD(operand());
L io(); L io();
PC = address;
} }
auto HuC6280::instruction_LDb_zeropage(uint8& b, uint8 index) -> void { auto HuC6280::instruction_JMP_indirect(uint8 index) -> void {
auto zeropage = operand(); uint16 address = operand();
address |= operand() << 8;
io(); io();
L b = LD(load(0x2000 + zeropage + index)); io();
PC.byte(0) = load(address + index + 0);
L PC.byte(1) = load(address + index + 1);
}
auto HuC6280::instruction_JSR() -> void {
uint16 address = operand();
address |= operand() << 8;
io();
io();
push((PC - 1) >> 8);
L push((PC - 1) >> 0);
PC = address;
} }
auto HuC6280::instruction_NOP() -> void { auto HuC6280::instruction_NOP() -> void {
L io(); L io();
} }
auto HuC6280::instruction_PHb(uint8& b) -> void { auto HuC6280::instruction_RMB(uint3 index) -> void {
auto zeropage = operand();
io(); io();
L push(b); io();
io();
auto data = load(0x2000 + zeropage);
data.bit(index) = 0;
L store(0x2000 + zeropage, data);
} }
auto HuC6280::instruction_PHP() -> void { auto HuC6280::instruction_RTI() -> void {
io(); io();
L push(P); io();
io();
P = pull();
PC.byte(0) = pull();
L PC.byte(1) = pull();
} }
auto HuC6280::instruction_PLb(uint8& b) -> void { auto HuC6280::instruction_RTS() -> void {
io(); io();
io(); io();
L b = pull();
}
auto HuC6280::instruction_PLP() -> void {
io(); io();
io(); PC.byte(0) = pull();
L P = pull(); PC.byte(1) = pull();
}
auto HuC6280::instruction_SEf(bool& f) -> void {
f = 1;
L io(); L io();
PC++;
} }
auto HuC6280::instruction_STA_indirect(uint8 index) -> void { auto HuC6280::instruction_SMB(uint3 index) -> void {
auto zeropage = operand(); auto zeropage = operand();
io(); io();
auto absolute = load(0x2000 + zeropage + index);
absolute |= load(0x2001 + zeropage + index) << 8;
L store(absolute, A);
}
auto HuC6280::instruction_STA_indirectY() -> void {
auto zeropage = operand();
io(); io();
auto absolute = load(0x2000 + zeropage);
absolute |= load(0x2001 + zeropage) << 8;
L store(absolute + Y, A);
}
auto HuC6280::instruction_STb_absolute(uint8 b, uint8 index) -> void {
uint16 absolute = operand();
absolute |= operand() << 8;
io(); io();
L store(absolute + index, b); auto data = load(0x2000 + zeropage);
data.bit(index) = 1;
L store(0x2000 + zeropage, data);
} }
auto HuC6280::instruction_STb_zeropage(uint8 b, uint8 index) -> void { auto HuC6280::instruction_ST(uint2 index) -> void {
auto zeropage = operand(); auto data = operand();
io();
L store(0x2000 + zeropage + index, b);
}
auto HuC6280::instruction_Sbb(uint8& lhs, uint8& rhs) -> void {
swap(lhs, rhs);
io(); io();
L io(); L io();
st(index, data);
} }
auto HuC6280::instruction_TAM() -> void { auto HuC6280::instruction_TAM() -> void {
@ -307,13 +470,6 @@ L io();
} }
} }
auto HuC6280::instruction_Tbb(uint8& source, uint8& target) -> void {
target = source;
L io();
Z = target == 0;
N = target.bit(7);
}
auto HuC6280::instruction_TMA() -> void { auto HuC6280::instruction_TMA() -> void {
auto mask = operand(); auto mask = operand();
io(); io();
@ -323,6 +479,31 @@ L io();
} }
} }
auto HuC6280::instruction_TST_absolute(uint8 index) -> void {
auto mask = operand();
uint16 absolute = operand();
absolute |= operand() << 8;
io();
io();
io();
L uint8 data = load(absolute + index) & mask;
Z = data == 0;
V = data.bit(6);
N = data.bit(7);
}
auto HuC6280::instruction_TST_zeropage(uint8 index) -> void {
auto mask = operand();
auto zeropage = operand();
io();
io();
io();
L uint8 data = load(0x2000 + zeropage + index) & mask;
Z = data == 0;
V = data.bit(6);
N = data.bit(7);
}
auto HuC6280::instruction_TXS() -> void { auto HuC6280::instruction_TXS() -> void {
S = X; S = X;
L io(); L io();