mirror of
https://github.com/zoriya/ComSquare.git
synced 2026-05-28 08:33:34 +00:00
Solving timing issues
This commit is contained in:
@@ -7,7 +7,7 @@
|
||||
|
||||
namespace ComSquare::CPU
|
||||
{
|
||||
int CPU::AND(uint24_t valueAddr)
|
||||
int CPU::AND(uint24_t valueAddr, AddressingMode mode)
|
||||
{
|
||||
unsigned negativeMask = this->_isEmulationMode ? 0x80u : 0x8000u;
|
||||
unsigned value = this->_bus->read(valueAddr);
|
||||
@@ -17,6 +17,27 @@ namespace ComSquare::CPU
|
||||
this->_registers.a &= value;
|
||||
this->_registers.p.n = this->_registers.a & negativeMask;
|
||||
this->_registers.p.z = this->_registers.a == 0;
|
||||
return 0;
|
||||
|
||||
int cycles = !this->_registers.p.m;
|
||||
switch (mode) {
|
||||
case DirectPage:
|
||||
case DirectPageIndirect:
|
||||
case DirectPageIndirectLong:
|
||||
case DirectPageIndexedByX:
|
||||
case DirectPageIndirectIndexedByX:
|
||||
case DirectPageIndirectIndexedByYLong:
|
||||
cycles += this->_registers.dl != 0;
|
||||
break;
|
||||
case AbsoluteIndexedByX:
|
||||
case AbsoluteIndexedByY:
|
||||
cycles += this->_hasIndexCrossedPageBoundary;
|
||||
break;
|
||||
case DirectPageIndirectIndexedByY:
|
||||
cycles += this->_registers.dl != 0 + this->_hasIndexCrossedPageBoundary;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return cycles;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user