IOS: Don't let Kernel initialize WiiRoot if already initialized

The SaveToSYSCONF call in BootManager.cpp was unintentionally
overriding the temporary NAND set by the preceding
InitializeWiiRoot call. Fixes
https://bugs.dolphin-emu.org/issues/12500.
This commit is contained in:
JosJuice 2021-05-02 10:07:54 +02:00
parent 219f66c6e9
commit 3397f49a0a
3 changed files with 18 additions and 2 deletions

View File

@ -256,8 +256,11 @@ Kernel::Kernel()
// Until the Wii root and NAND path stuff is entirely managed by IOS and made non-static, // Until the Wii root and NAND path stuff is entirely managed by IOS and made non-static,
// using more than one IOS instance at a time is not supported. // using more than one IOS instance at a time is not supported.
ASSERT(GetIOS() == nullptr); ASSERT(GetIOS() == nullptr);
m_is_responsible_for_nand_root = !Core::WiiRootIsInitialized();
if (m_is_responsible_for_nand_root)
Core::InitializeWiiRoot(false); Core::InitializeWiiRoot(false);
m_is_responsible_for_nand_root = true;
AddCoreDevices(); AddCoreDevices();
} }

View File

@ -33,6 +33,7 @@ namespace Core
namespace FS = IOS::HLE::FS; namespace FS = IOS::HLE::FS;
static std::string s_temp_wii_root; static std::string s_temp_wii_root;
static bool s_wii_root_initialized = false;
static bool CopyBackupFile(const std::string& path_from, const std::string& path_to) static bool CopyBackupFile(const std::string& path_from, const std::string& path_to)
{ {
@ -170,6 +171,8 @@ static void InitializeDeterministicWiiSaves(FS::FileSystem* session_fs)
void InitializeWiiRoot(bool use_temporary) void InitializeWiiRoot(bool use_temporary)
{ {
ASSERT(!s_wii_root_initialized);
if (use_temporary) if (use_temporary)
{ {
s_temp_wii_root = File::GetUserPath(D_USER_IDX) + "WiiSession" DIR_SEP; s_temp_wii_root = File::GetUserPath(D_USER_IDX) + "WiiSession" DIR_SEP;
@ -198,6 +201,8 @@ void InitializeWiiRoot(bool use_temporary)
{ {
File::SetUserPath(D_SESSION_WIIROOT_IDX, File::GetUserPath(D_WIIROOT_IDX)); File::SetUserPath(D_SESSION_WIIROOT_IDX, File::GetUserPath(D_WIIROOT_IDX));
} }
s_wii_root_initialized = true;
} }
void ShutdownWiiRoot() void ShutdownWiiRoot()
@ -207,6 +212,13 @@ void ShutdownWiiRoot()
File::DeleteDirRecursively(s_temp_wii_root); File::DeleteDirRecursively(s_temp_wii_root);
s_temp_wii_root.clear(); s_temp_wii_root.clear();
} }
s_wii_root_initialized = false;
}
bool WiiRootIsInitialized()
{
return s_wii_root_initialized;
} }
bool WiiRootIsTemporary() bool WiiRootIsTemporary()

View File

@ -15,6 +15,7 @@ enum class RestoreReason
void InitializeWiiRoot(bool use_temporary); void InitializeWiiRoot(bool use_temporary);
void ShutdownWiiRoot(); void ShutdownWiiRoot();
bool WiiRootIsInitialized();
bool WiiRootIsTemporary(); bool WiiRootIsTemporary();
void BackupWiiSettings(); void BackupWiiSettings();