mirror of https://github.com/bsnes-emu/bsnes.git
129 lines
2.6 KiB
C++
129 lines
2.6 KiB
C++
auto WDC65816::instructionBranch(bool take) -> void {
|
|
if(!take) {
|
|
L fetch();
|
|
} else {
|
|
uint8 displacement = fetch();
|
|
uint16 absolute = PC + (int8)displacement;
|
|
idle6(absolute);
|
|
L idle();
|
|
aa(PC) = absolute;
|
|
}
|
|
}
|
|
|
|
auto WDC65816::instructionBranchLong() -> void {
|
|
uint16 displacement = fetch();
|
|
hi(displacement) = fetch();
|
|
L idle();
|
|
aa(PC) = PC + (int16)displacement;
|
|
}
|
|
|
|
auto WDC65816::instructionJumpShort() -> void {
|
|
uint16 data = fetch();
|
|
L hi(data) = fetch();
|
|
aa(PC) = data;
|
|
}
|
|
|
|
auto WDC65816::instructionJumpLong() -> void {
|
|
uint24 data = fetch();
|
|
hi(data) = fetch();
|
|
L db(data) = fetch();
|
|
PC = data;
|
|
}
|
|
|
|
auto WDC65816::instructionJumpIndirect() -> void {
|
|
uint16 absolute = fetch();
|
|
hi(absolute) = fetch();
|
|
uint16 data = read(uint16(absolute + 0));
|
|
L hi(data) = read(uint16(absolute + 1));
|
|
aa(PC) = data;
|
|
}
|
|
|
|
auto WDC65816::instructionJumpIndexedIndirect() -> void {
|
|
uint16 absolute = fetch();
|
|
hi(absolute) = fetch();
|
|
idle();
|
|
uint16 data = read(db(PC) << 16 | uint16(absolute + X + 0));
|
|
L hi(data) = read(db(PC) << 16 | uint16(absolute + X + 1));
|
|
aa(PC) = data;
|
|
}
|
|
|
|
auto WDC65816::instructionJumpIndirectLong() -> void {
|
|
uint16 absolute = fetch();
|
|
hi(absolute) = fetch();
|
|
uint24 data = read(uint16(absolute + 0));
|
|
hi(data) = read(uint16(absolute + 1));
|
|
L db(data) = read(uint16(absolute + 2));
|
|
PC = data;
|
|
}
|
|
|
|
auto WDC65816::instructionCallShort() -> void {
|
|
uint16 data = fetch();
|
|
hi(data) = fetch();
|
|
idle();
|
|
aa(PC)--;
|
|
push(hi(PC));
|
|
L push(lo(PC));
|
|
aa(PC) = data;
|
|
}
|
|
|
|
auto WDC65816::instructionCallLong() -> void {
|
|
uint24 data = fetch();
|
|
hi(data) = fetch();
|
|
pushN(db(PC));
|
|
idle();
|
|
db(data) = fetch();
|
|
aa(PC)--;
|
|
pushN(hi(PC));
|
|
L pushN(lo(PC));
|
|
PC = data;
|
|
E hi(S) = 0x01;
|
|
}
|
|
|
|
auto WDC65816::instructionCallIndexedIndirect() -> void {
|
|
uint16 absolute = fetch();
|
|
pushN(hi(PC));
|
|
pushN(lo(PC));
|
|
hi(absolute) = fetch();
|
|
idle();
|
|
uint16 data = read(db(PC) << 16 | uint16(absolute + X + 0));
|
|
L hi(data) = read(db(PC) << 16 | uint16(absolute + X + 1));
|
|
aa(PC) = data;
|
|
E hi(S) = 0x01;
|
|
}
|
|
|
|
auto WDC65816::instructionReturnInterrupt() -> void {
|
|
idle();
|
|
idle();
|
|
P = pull();
|
|
E XF = 1, MF = 1;
|
|
if(XF) hi(X) = 0x00, hi(Y) = 0x00;
|
|
lo(PC) = pull();
|
|
if(EF) {
|
|
L hi(PC) = pull();
|
|
} else {
|
|
hi(PC) = pull();
|
|
L db(PC) = pull();
|
|
}
|
|
}
|
|
|
|
auto WDC65816::instructionReturnShort() -> void {
|
|
idle();
|
|
idle();
|
|
uint16 data = pull();
|
|
hi(data) = pull();
|
|
L idle();
|
|
aa(PC) = data;
|
|
aa(PC)++;
|
|
}
|
|
|
|
auto WDC65816::instructionReturnLong() -> void {
|
|
idle();
|
|
idle();
|
|
uint24 data = pullN();
|
|
hi(data) = pullN();
|
|
L db(data) = pullN();
|
|
PC = data;
|
|
aa(PC)++;
|
|
E hi(S) = 0x01;
|
|
}
|