[Save State] Recover Disk Seek Address for more stability

This commit is contained in:
LuigiBlood 2020-06-10 13:58:03 +02:00
parent e805c709b3
commit c5c6167f05
1 changed files with 7 additions and 0 deletions

View File

@ -17,6 +17,7 @@
#include <Project64-core/N64System/Mips/Transferpak.h> #include <Project64-core/N64System/Mips/Transferpak.h>
#include <Project64-core/N64System/Interpreter/InterpreterCPU.h> #include <Project64-core/N64System/Interpreter/InterpreterCPU.h>
#include <Project64-core/N64System/Mips/OpcodeName.h> #include <Project64-core/N64System/Mips/OpcodeName.h>
#include <Project64-core/N64System/Mips/Disk.h>
#include <Project64-core/N64System/N64DiskClass.h> #include <Project64-core/N64System/N64DiskClass.h>
#include <Project64-core/ExceptionHandler.h> #include <Project64-core/ExceptionHandler.h>
#include <Project64-core/Logging.h> #include <Project64-core/Logging.h>
@ -2132,8 +2133,14 @@ bool CN64System::LoadState(const char * FileName)
//Disk Interface Info //Disk Interface Info
if (Value == SaveID_2) if (Value == SaveID_2)
{
hExtraInfo.Read(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22); hExtraInfo.Read(m_Reg.m_DiskInterface, sizeof(uint32_t) * 22);
//Recover Disk Seek Address (if the save state is done while loading/saving data)
if (g_Disk)
DiskBMReadWrite(false);
}
//System Timers Info //System Timers Info
m_SystemTimer.LoadData(hExtraInfo); m_SystemTimer.LoadData(hExtraInfo);