mirror of https://github.com/bsnes-emu/bsnes.git
111 lines
2.5 KiB
C++
111 lines
2.5 KiB
C++
auto CPU::serialize(serializer& s) -> void {
|
|
WDC65816::serialize(s);
|
|
Thread::serialize(s);
|
|
PPUcounter::serialize(s);
|
|
|
|
s.array(wram);
|
|
|
|
s.integer(version);
|
|
s.integer(clockCounter);
|
|
|
|
s.integer(status.interruptPending);
|
|
|
|
s.integer(status.clockCount);
|
|
s.integer(status.lineClocks);
|
|
|
|
s.integer(status.irqLock);
|
|
|
|
s.integer(status.dramRefreshPosition);
|
|
s.integer(status.dramRefreshed);
|
|
|
|
s.integer(status.hdmaInitPosition);
|
|
s.integer(status.hdmaInitTriggered);
|
|
|
|
s.integer(status.hdmaPosition);
|
|
s.integer(status.hdmaTriggered);
|
|
|
|
s.integer(status.nmiValid);
|
|
s.integer(status.nmiLine);
|
|
s.integer(status.nmiTransition);
|
|
s.integer(status.nmiPending);
|
|
s.integer(status.nmiHold);
|
|
|
|
s.integer(status.irqValid);
|
|
s.integer(status.irqLine);
|
|
s.integer(status.irqTransition);
|
|
s.integer(status.irqPending);
|
|
s.integer(status.irqHold);
|
|
|
|
s.integer(status.powerPending);
|
|
s.integer(status.resetPending);
|
|
|
|
s.integer(status.dmaActive);
|
|
s.integer(status.dmaClocks);
|
|
s.integer(status.dmaPending);
|
|
s.integer(status.hdmaPending);
|
|
s.integer(status.hdmaMode);
|
|
|
|
s.integer(status.autoJoypadActive);
|
|
s.integer(status.autoJoypadLatch);
|
|
s.integer(status.autoJoypadCounter);
|
|
|
|
s.integer(io.wramAddress);
|
|
|
|
s.integer(io.joypadStrobeLatch);
|
|
|
|
s.integer(io.nmiEnabled);
|
|
s.integer(io.hirqEnabled);
|
|
s.integer(io.virqEnabled);
|
|
s.integer(io.autoJoypadPoll);
|
|
|
|
s.integer(io.pio);
|
|
|
|
s.integer(io.wrmpya);
|
|
s.integer(io.wrmpyb);
|
|
|
|
s.integer(io.wrdiva);
|
|
s.integer(io.wrdivb);
|
|
|
|
s.integer(io.hirqPos);
|
|
s.integer(io.virqPos);
|
|
|
|
s.integer(io.romSpeed);
|
|
|
|
s.integer(io.rddiv);
|
|
s.integer(io.rdmpy);
|
|
|
|
s.integer(io.joy1);
|
|
s.integer(io.joy2);
|
|
s.integer(io.joy3);
|
|
s.integer(io.joy4);
|
|
|
|
s.integer(alu.mpyctr);
|
|
s.integer(alu.divctr);
|
|
s.integer(alu.shift);
|
|
|
|
for(auto& channel : this->channel) {
|
|
s.integer(channel.dmaEnabled);
|
|
s.integer(channel.hdmaEnabled);
|
|
s.integer(channel.direction);
|
|
s.integer(channel.indirect);
|
|
s.integer(channel.unused);
|
|
s.integer(channel.reverseTransfer);
|
|
s.integer(channel.fixedTransfer);
|
|
s.integer(channel.transferMode);
|
|
s.integer(channel.targetAddress);
|
|
s.integer(channel.sourceAddress);
|
|
s.integer(channel.sourceBank);
|
|
s.integer(channel.transferSize);
|
|
s.integer(channel.indirectBank);
|
|
s.integer(channel.hdmaAddress);
|
|
s.integer(channel.lineCounter);
|
|
s.integer(channel.unknown);
|
|
s.integer(channel.hdmaCompleted);
|
|
s.integer(channel.hdmaDoTransfer);
|
|
}
|
|
|
|
s.integer(pipe.valid);
|
|
s.integer(pipe.addr);
|
|
s.integer(pipe.data);
|
|
}
|