Add a mode to use a dummy Wii NAND.
Eventually, netplay will be able to use the host's NAND, but this could still be useful in some cases; for TAS it definitely makes sense to have a way to avoid using any preexisting NAND. In terms of implementation: remove D_WIIUSER_IDX, which was just WIIROOT + "/", as well as some other indices which are pointless to have as separate variables rather than just using the actual path (fixed, since they're actual Wii NAND paths) at the call site. Then split off D_SESSION_WIIROOT_IDX, which can point to the dummy NAND directory, from D_WIIROOT_IDX, which always points to the "real" one the user configured.
This commit is contained in:
parent
f6c6822f71
commit
dc91e8b607
|
@ -20,6 +20,7 @@
|
||||||
#include <commdlg.h> // for GetSaveFileName
|
#include <commdlg.h> // for GetSaveFileName
|
||||||
#include <direct.h> // getcwd
|
#include <direct.h> // getcwd
|
||||||
#include <io.h>
|
#include <io.h>
|
||||||
|
#include <objbase.h> // guid stuff
|
||||||
#include <shellapi.h>
|
#include <shellapi.h>
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#else
|
#else
|
||||||
|
@ -666,6 +667,32 @@ bool SetCurrentDir(const std::string &directory)
|
||||||
return __chdir(directory.c_str()) == 0;
|
return __chdir(directory.c_str()) == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string CreateTempDir()
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
TCHAR temp[MAX_PATH];
|
||||||
|
if (!GetTempPath(MAX_PATH, temp))
|
||||||
|
return "";
|
||||||
|
|
||||||
|
GUID guid;
|
||||||
|
CoCreateGuid(&guid);
|
||||||
|
TCHAR tguid[40];
|
||||||
|
StringFromGUID2(guid, tguid, 39);
|
||||||
|
tguid[39] = 0;
|
||||||
|
std::string dir = TStrToUTF8(temp) + "/" + TStrToUTF8(tguid);
|
||||||
|
if (!CreateDir(dir))
|
||||||
|
return "";
|
||||||
|
dir = ReplaceAll(dir, "\\", DIR_SEP);
|
||||||
|
return dir;
|
||||||
|
#else
|
||||||
|
const char* base = getenv("TMPDIR") ?: "/tmp";
|
||||||
|
std::string path = std::string(base) + "/DolphinWii.XXXXXX";
|
||||||
|
if (!mkdtemp(&path[0]))
|
||||||
|
return "";
|
||||||
|
return path;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
std::string GetTempFilenameForAtomicWrite(const std::string &path)
|
std::string GetTempFilenameForAtomicWrite(const std::string &path)
|
||||||
{
|
{
|
||||||
std::string abs = path;
|
std::string abs = path;
|
||||||
|
@ -734,17 +761,9 @@ static void RebuildUserDirectories(unsigned int dir_index)
|
||||||
{
|
{
|
||||||
switch (dir_index)
|
switch (dir_index)
|
||||||
{
|
{
|
||||||
case D_WIIROOT_IDX:
|
|
||||||
s_user_paths[D_WIIUSER_IDX] = s_user_paths[D_WIIROOT_IDX] + DIR_SEP;
|
|
||||||
s_user_paths[D_WIISYSCONF_IDX] = s_user_paths[D_WIIUSER_IDX] + WII_SYSCONF_DIR + DIR_SEP;
|
|
||||||
s_user_paths[D_WIIWC24_IDX] = s_user_paths[D_WIIUSER_IDX] + WII_WC24CONF_DIR DIR_SEP;
|
|
||||||
s_user_paths[F_WIISYSCONF_IDX] = s_user_paths[D_WIISYSCONF_IDX] + WII_SYSCONF;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case D_USER_IDX:
|
case D_USER_IDX:
|
||||||
s_user_paths[D_GCUSER_IDX] = s_user_paths[D_USER_IDX] + GC_USER_DIR DIR_SEP;
|
s_user_paths[D_GCUSER_IDX] = s_user_paths[D_USER_IDX] + GC_USER_DIR DIR_SEP;
|
||||||
s_user_paths[D_WIIROOT_IDX] = s_user_paths[D_USER_IDX] + WII_USER_DIR;
|
s_user_paths[D_WIIROOT_IDX] = s_user_paths[D_USER_IDX] + WII_USER_DIR;
|
||||||
s_user_paths[D_WIIUSER_IDX] = s_user_paths[D_WIIROOT_IDX] + DIR_SEP;
|
|
||||||
s_user_paths[D_CONFIG_IDX] = s_user_paths[D_USER_IDX] + CONFIG_DIR DIR_SEP;
|
s_user_paths[D_CONFIG_IDX] = s_user_paths[D_USER_IDX] + CONFIG_DIR DIR_SEP;
|
||||||
s_user_paths[D_GAMESETTINGS_IDX] = s_user_paths[D_USER_IDX] + GAMESETTINGS_DIR DIR_SEP;
|
s_user_paths[D_GAMESETTINGS_IDX] = s_user_paths[D_USER_IDX] + GAMESETTINGS_DIR DIR_SEP;
|
||||||
s_user_paths[D_MAPS_IDX] = s_user_paths[D_USER_IDX] + MAPS_DIR DIR_SEP;
|
s_user_paths[D_MAPS_IDX] = s_user_paths[D_USER_IDX] + MAPS_DIR DIR_SEP;
|
||||||
|
@ -762,14 +781,11 @@ static void RebuildUserDirectories(unsigned int dir_index)
|
||||||
s_user_paths[D_DUMPDSP_IDX] = s_user_paths[D_DUMP_IDX] + DUMP_DSP_DIR DIR_SEP;
|
s_user_paths[D_DUMPDSP_IDX] = s_user_paths[D_DUMP_IDX] + DUMP_DSP_DIR DIR_SEP;
|
||||||
s_user_paths[D_LOGS_IDX] = s_user_paths[D_USER_IDX] + LOGS_DIR DIR_SEP;
|
s_user_paths[D_LOGS_IDX] = s_user_paths[D_USER_IDX] + LOGS_DIR DIR_SEP;
|
||||||
s_user_paths[D_MAILLOGS_IDX] = s_user_paths[D_LOGS_IDX] + MAIL_LOGS_DIR DIR_SEP;
|
s_user_paths[D_MAILLOGS_IDX] = s_user_paths[D_LOGS_IDX] + MAIL_LOGS_DIR DIR_SEP;
|
||||||
s_user_paths[D_WIISYSCONF_IDX] = s_user_paths[D_WIIUSER_IDX] + WII_SYSCONF_DIR DIR_SEP;
|
|
||||||
s_user_paths[D_WIIWC24_IDX] = s_user_paths[D_WIIUSER_IDX] + WII_WC24CONF_DIR DIR_SEP;
|
|
||||||
s_user_paths[D_THEMES_IDX] = s_user_paths[D_USER_IDX] + THEMES_DIR DIR_SEP;
|
s_user_paths[D_THEMES_IDX] = s_user_paths[D_USER_IDX] + THEMES_DIR DIR_SEP;
|
||||||
s_user_paths[F_DOLPHINCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DOLPHIN_CONFIG;
|
s_user_paths[F_DOLPHINCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DOLPHIN_CONFIG;
|
||||||
s_user_paths[F_DEBUGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DEBUGGER_CONFIG;
|
s_user_paths[F_DEBUGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + DEBUGGER_CONFIG;
|
||||||
s_user_paths[F_LOGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + LOGGER_CONFIG;
|
s_user_paths[F_LOGGERCONFIG_IDX] = s_user_paths[D_CONFIG_IDX] + LOGGER_CONFIG;
|
||||||
s_user_paths[F_MAINLOG_IDX] = s_user_paths[D_LOGS_IDX] + MAIN_LOG;
|
s_user_paths[F_MAINLOG_IDX] = s_user_paths[D_LOGS_IDX] + MAIN_LOG;
|
||||||
s_user_paths[F_WIISYSCONF_IDX] = s_user_paths[D_WIISYSCONF_IDX] + WII_SYSCONF;
|
|
||||||
s_user_paths[F_RAMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + RAM_DUMP;
|
s_user_paths[F_RAMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + RAM_DUMP;
|
||||||
s_user_paths[F_ARAMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + ARAM_DUMP;
|
s_user_paths[F_ARAMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + ARAM_DUMP;
|
||||||
s_user_paths[F_FAKEVMEMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + FAKEVMEM_DUMP;
|
s_user_paths[F_FAKEVMEMDUMP_IDX] = s_user_paths[D_DUMP_IDX] + FAKEVMEM_DUMP;
|
||||||
|
|
|
@ -20,8 +20,8 @@
|
||||||
enum {
|
enum {
|
||||||
D_USER_IDX,
|
D_USER_IDX,
|
||||||
D_GCUSER_IDX,
|
D_GCUSER_IDX,
|
||||||
D_WIIROOT_IDX,
|
D_WIIROOT_IDX, // always points to User/Wii or global user-configured directory
|
||||||
D_WIIUSER_IDX,
|
D_SESSION_WIIROOT_IDX, // may point to minimal temporary directory for determinism
|
||||||
D_CONFIG_IDX, // global settings
|
D_CONFIG_IDX, // global settings
|
||||||
D_GAMESETTINGS_IDX, // user-specified settings which override both the global and the default settings (per game)
|
D_GAMESETTINGS_IDX, // user-specified settings which override both the global and the default settings (per game)
|
||||||
D_MAPS_IDX,
|
D_MAPS_IDX,
|
||||||
|
@ -39,14 +39,11 @@ enum {
|
||||||
D_LOAD_IDX,
|
D_LOAD_IDX,
|
||||||
D_LOGS_IDX,
|
D_LOGS_IDX,
|
||||||
D_MAILLOGS_IDX,
|
D_MAILLOGS_IDX,
|
||||||
D_WIISYSCONF_IDX,
|
|
||||||
D_WIIWC24_IDX,
|
|
||||||
D_THEMES_IDX,
|
D_THEMES_IDX,
|
||||||
F_DOLPHINCONFIG_IDX,
|
F_DOLPHINCONFIG_IDX,
|
||||||
F_DEBUGGERCONFIG_IDX,
|
F_DEBUGGERCONFIG_IDX,
|
||||||
F_LOGGERCONFIG_IDX,
|
F_LOGGERCONFIG_IDX,
|
||||||
F_MAINLOG_IDX,
|
F_MAINLOG_IDX,
|
||||||
F_WIISYSCONF_IDX,
|
|
||||||
F_RAMDUMP_IDX,
|
F_RAMDUMP_IDX,
|
||||||
F_ARAMDUMP_IDX,
|
F_ARAMDUMP_IDX,
|
||||||
F_FAKEVMEMDUMP_IDX,
|
F_FAKEVMEMDUMP_IDX,
|
||||||
|
@ -122,6 +119,9 @@ void CopyDir(const std::string &source_path, const std::string &dest_path);
|
||||||
// Set the current directory to given directory
|
// Set the current directory to given directory
|
||||||
bool SetCurrentDir(const std::string &directory);
|
bool SetCurrentDir(const std::string &directory);
|
||||||
|
|
||||||
|
// Creates and returns the path to a new temporary directory.
|
||||||
|
std::string CreateTempDir();
|
||||||
|
|
||||||
// Get a filename that can hopefully be atomically renamed to the given path.
|
// Get a filename that can hopefully be atomically renamed to the given path.
|
||||||
std::string GetTempFilenameForAtomicWrite(const std::string &path);
|
std::string GetTempFilenameForAtomicWrite(const std::string &path);
|
||||||
|
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
#include "Common/CommonPaths.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
#include "Common/NandPaths.h"
|
#include "Common/NandPaths.h"
|
||||||
|
@ -15,17 +16,55 @@
|
||||||
namespace Common
|
namespace Common
|
||||||
{
|
{
|
||||||
|
|
||||||
|
static std::string s_temp_wii_root;
|
||||||
|
|
||||||
|
void InitializeWiiRoot(bool use_dummy)
|
||||||
|
{
|
||||||
|
ShutdownWiiRoot();
|
||||||
|
if (use_dummy)
|
||||||
|
{
|
||||||
|
s_temp_wii_root = File::CreateTempDir();
|
||||||
|
if (s_temp_wii_root.empty())
|
||||||
|
{
|
||||||
|
ERROR_LOG(WII_IPC_FILEIO, "Could not create temporary directory");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
File::CopyDir(File::GetSysDirectory() + WII_USER_DIR, s_temp_wii_root);
|
||||||
|
WARN_LOG(WII_IPC_FILEIO, "Using temporary directory %s for minimal Wii FS", s_temp_wii_root.c_str());
|
||||||
|
static bool s_registered;
|
||||||
|
if (!s_registered)
|
||||||
|
{
|
||||||
|
s_registered = true;
|
||||||
|
atexit(ShutdownWiiRoot);
|
||||||
|
}
|
||||||
|
File::SetUserPath(D_SESSION_WIIROOT_IDX, s_temp_wii_root);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
File::SetUserPath(D_SESSION_WIIROOT_IDX, File::GetUserPath(D_WIIROOT_IDX));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ShutdownWiiRoot()
|
||||||
|
{
|
||||||
|
if (!s_temp_wii_root.empty())
|
||||||
|
{
|
||||||
|
File::DeleteDirRecursively(s_temp_wii_root);
|
||||||
|
s_temp_wii_root.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::string GetTicketFileName(u64 _titleID)
|
std::string GetTicketFileName(u64 _titleID)
|
||||||
{
|
{
|
||||||
return StringFromFormat("%sticket/%08x/%08x.tik",
|
return StringFromFormat("%s/ticket/%08x/%08x.tik",
|
||||||
File::GetUserPath(D_WIIUSER_IDX).c_str(),
|
File::GetUserPath(D_SESSION_WIIROOT_IDX).c_str(),
|
||||||
(u32)(_titleID >> 32), (u32)_titleID);
|
(u32)(_titleID >> 32), (u32)_titleID);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string GetTitleDataPath(u64 _titleID)
|
std::string GetTitleDataPath(u64 _titleID)
|
||||||
{
|
{
|
||||||
return StringFromFormat("%stitle/%08x/%08x/data/",
|
return StringFromFormat("%s/title/%08x/%08x/data/",
|
||||||
File::GetUserPath(D_WIIUSER_IDX).c_str(),
|
File::GetUserPath(D_SESSION_WIIROOT_IDX).c_str(),
|
||||||
(u32)(_titleID >> 32), (u32)_titleID);
|
(u32)(_titleID >> 32), (u32)_titleID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,8 +74,8 @@ std::string GetTMDFileName(u64 _titleID)
|
||||||
}
|
}
|
||||||
std::string GetTitleContentPath(u64 _titleID)
|
std::string GetTitleContentPath(u64 _titleID)
|
||||||
{
|
{
|
||||||
return StringFromFormat("%stitle/%08x/%08x/content/",
|
return StringFromFormat("%s/title/%08x/%08x/content/",
|
||||||
File::GetUserPath(D_WIIUSER_IDX).c_str(),
|
File::GetUserPath(D_SESSION_WIIROOT_IDX).c_str(),
|
||||||
(u32)(_titleID >> 32), (u32)_titleID);
|
(u32)(_titleID >> 32), (u32)_titleID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -89,8 +128,7 @@ void ReadReplacements(replace_v& replacements)
|
||||||
{
|
{
|
||||||
replacements.clear();
|
replacements.clear();
|
||||||
const std::string replace_fname = "/sys/replace";
|
const std::string replace_fname = "/sys/replace";
|
||||||
std::string filename(File::GetUserPath(D_WIIROOT_IDX));
|
std::string filename = File::GetUserPath(D_SESSION_WIIROOT_IDX) + replace_fname;
|
||||||
filename += replace_fname;
|
|
||||||
|
|
||||||
if (!File::Exists(filename))
|
if (!File::Exists(filename))
|
||||||
CreateReplacementFile(filename);
|
CreateReplacementFile(filename);
|
||||||
|
|
|
@ -18,6 +18,9 @@ namespace Common
|
||||||
typedef std::pair<char, std::string> replace_t;
|
typedef std::pair<char, std::string> replace_t;
|
||||||
typedef std::vector<replace_t> replace_v;
|
typedef std::vector<replace_t> replace_v;
|
||||||
|
|
||||||
|
void InitializeWiiRoot(bool use_temporary);
|
||||||
|
void ShutdownWiiRoot();
|
||||||
|
|
||||||
std::string GetTicketFileName(u64 _titleID);
|
std::string GetTicketFileName(u64 _titleID);
|
||||||
std::string GetTMDFileName(u64 _titleID);
|
std::string GetTMDFileName(u64 _titleID);
|
||||||
std::string GetTitleDataPath(u64 _titleID);
|
std::string GetTitleDataPath(u64 _titleID);
|
||||||
|
|
|
@ -8,6 +8,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
|
#include "Common/CommonPaths.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
#include "Common/SysConf.h"
|
#include "Common/SysConf.h"
|
||||||
|
@ -15,8 +16,7 @@
|
||||||
SysConf::SysConf()
|
SysConf::SysConf()
|
||||||
: m_IsValid(false)
|
: m_IsValid(false)
|
||||||
{
|
{
|
||||||
m_FilenameDefault = File::GetUserPath(F_WIISYSCONF_IDX);
|
UpdateLocation();
|
||||||
m_IsValid = LoadFromFile(m_FilenameDefault);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SysConf::~SysConf()
|
SysConf::~SysConf()
|
||||||
|
@ -409,7 +409,10 @@ void SysConf::UpdateLocation()
|
||||||
// Clear the old filename and set the default filename to the new user path
|
// Clear the old filename and set the default filename to the new user path
|
||||||
// So that it can be generated if the file does not exist in the new location
|
// So that it can be generated if the file does not exist in the new location
|
||||||
m_Filename.clear();
|
m_Filename.clear();
|
||||||
m_FilenameDefault = File::GetUserPath(F_WIISYSCONF_IDX);
|
// Note: We don't use the dummy Wii root here (if in use) because this is
|
||||||
|
// all tied up with the configuration code. In the future this should
|
||||||
|
// probably just be synced with the other settings.
|
||||||
|
m_FilenameDefault = File::GetUserPath(D_WIIROOT_IDX) + DIR_SEP WII_SYSCONF_DIR DIR_SEP WII_SYSCONF;
|
||||||
Reload();
|
Reload();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -475,8 +475,6 @@ void SConfig::LoadGeneralSettings(IniFile& ini)
|
||||||
|
|
||||||
general->Get("NANDRootPath", &m_NANDPath);
|
general->Get("NANDRootPath", &m_NANDPath);
|
||||||
File::SetUserPath(D_WIIROOT_IDX, m_NANDPath);
|
File::SetUserPath(D_WIIROOT_IDX, m_NANDPath);
|
||||||
DiscIO::cUIDsys::AccessInstance().UpdateLocation();
|
|
||||||
DiscIO::CSharedContent::AccessInstance().UpdateLocation();
|
|
||||||
general->Get("WirelessMac", &m_WirelessMac);
|
general->Get("WirelessMac", &m_WirelessMac);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -832,6 +832,7 @@ void UpdateWantDeterminism(bool initial)
|
||||||
g_video_backend->UpdateWantDeterminism(new_want_determinism);
|
g_video_backend->UpdateWantDeterminism(new_want_determinism);
|
||||||
// We need to clear the cache because some parts of the JIT depend on want_determinism, e.g. use of FMA.
|
// We need to clear the cache because some parts of the JIT depend on want_determinism, e.g. use of FMA.
|
||||||
JitInterface::ClearCache();
|
JitInterface::ClearCache();
|
||||||
|
Common::InitializeWiiRoot(g_want_determinism);
|
||||||
|
|
||||||
Core::PauseAndLock(false, was_unpaused);
|
Core::PauseAndLock(false, was_unpaused);
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
|
|
||||||
#include "Common/ChunkFile.h"
|
#include "Common/ChunkFile.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
|
#include "Common/NandPaths.h"
|
||||||
|
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/Core.h"
|
#include "Core/Core.h"
|
||||||
|
@ -25,6 +26,7 @@
|
||||||
#include "Core/IPC_HLE/WII_IPC_HLE.h"
|
#include "Core/IPC_HLE/WII_IPC_HLE.h"
|
||||||
#include "Core/PowerPC/PowerPC.h"
|
#include "Core/PowerPC/PowerPC.h"
|
||||||
#include "Core/PowerPC/PPCAnalyst.h"
|
#include "Core/PowerPC/PPCAnalyst.h"
|
||||||
|
#include "DiscIO/NANDContentLoader.h"
|
||||||
|
|
||||||
namespace HW
|
namespace HW
|
||||||
{
|
{
|
||||||
|
@ -50,6 +52,9 @@ namespace HW
|
||||||
|
|
||||||
if (SConfig::GetInstance().m_LocalCoreStartupParameter.bWii)
|
if (SConfig::GetInstance().m_LocalCoreStartupParameter.bWii)
|
||||||
{
|
{
|
||||||
|
Common::InitializeWiiRoot(Core::g_want_determinism);
|
||||||
|
DiscIO::cUIDsys::AccessInstance().UpdateLocation();
|
||||||
|
DiscIO::CSharedContent::AccessInstance().UpdateLocation();
|
||||||
WII_IPCInterface::Init();
|
WII_IPCInterface::Init();
|
||||||
WII_IPC_HLE_Interface::Init();
|
WII_IPC_HLE_Interface::Init();
|
||||||
}
|
}
|
||||||
|
@ -70,6 +75,7 @@ namespace HW
|
||||||
{
|
{
|
||||||
WII_IPCInterface::Shutdown();
|
WII_IPCInterface::Shutdown();
|
||||||
WII_IPC_HLE_Interface::Shutdown();
|
WII_IPC_HLE_Interface::Shutdown();
|
||||||
|
Common::ShutdownWiiRoot();
|
||||||
}
|
}
|
||||||
|
|
||||||
State::Shutdown();
|
State::Shutdown();
|
||||||
|
|
|
@ -62,7 +62,7 @@ bool CWiiSaveCrypted::ExportWiiSave(u64 title_id)
|
||||||
|
|
||||||
void CWiiSaveCrypted::ExportAllSaves()
|
void CWiiSaveCrypted::ExportAllSaves()
|
||||||
{
|
{
|
||||||
std::string title_folder = File::GetUserPath(D_WIIUSER_IDX) + "title";
|
std::string title_folder = File::GetUserPath(D_WIIROOT_IDX) + "/title";
|
||||||
std::vector<u64> titles;
|
std::vector<u64> titles;
|
||||||
const u32 path_mask = 0x00010000;
|
const u32 path_mask = 0x00010000;
|
||||||
for (int i = 0; i < 8; ++i)
|
for (int i = 0; i < 8; ++i)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
|
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
|
#include "Common/NandPaths.h"
|
||||||
|
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
#include "Core/HW/WiimoteEmu/WiimoteEmu.h"
|
||||||
#include "Core/HW/WiimoteEmu/WiimoteHid.h"
|
#include "Core/HW/WiimoteEmu/WiimoteHid.h"
|
||||||
|
@ -275,7 +276,7 @@ void Wiimote::WriteData(const wm_write_data* const wd)
|
||||||
{
|
{
|
||||||
// writing the whole mii block each write :/
|
// writing the whole mii block each write :/
|
||||||
std::ofstream file;
|
std::ofstream file;
|
||||||
OpenFStream(file, File::GetUserPath(D_WIIUSER_IDX) + "mii.bin", std::ios::binary | std::ios::out);
|
OpenFStream(file, File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/mii.bin", std::ios::binary | std::ios::out);
|
||||||
file.write((char*)m_eeprom + 0x0FCA, 0x02f0);
|
file.write((char*)m_eeprom + 0x0FCA, 0x02f0);
|
||||||
file.close();
|
file.close();
|
||||||
}
|
}
|
||||||
|
@ -417,7 +418,7 @@ void Wiimote::ReadData(const wm_read_data* const rd)
|
||||||
{
|
{
|
||||||
// reading the whole mii block :/
|
// reading the whole mii block :/
|
||||||
std::ifstream file;
|
std::ifstream file;
|
||||||
file.open((File::GetUserPath(D_WIIUSER_IDX) + "mii.bin").c_str(), std::ios::binary | std::ios::in);
|
file.open((File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/mii.bin").c_str(), std::ios::binary | std::ios::in);
|
||||||
file.read((char*)m_eeprom + 0x0FCA, 0x02f0);
|
file.read((char*)m_eeprom + 0x0FCA, 0x02f0);
|
||||||
file.close();
|
file.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,11 +5,14 @@
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
#include "Common/ChunkFile.h"
|
#include "Common/ChunkFile.h"
|
||||||
|
#include "Common/CommonPaths.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
#include "Common/NandPaths.h"
|
#include "Common/NandPaths.h"
|
||||||
#include "Common/StringUtil.h"
|
#include "Common/StringUtil.h"
|
||||||
|
|
||||||
|
#include "Core/Core.h"
|
||||||
|
#include "Core/IPC_HLE/WII_IPC_HLE.h"
|
||||||
#include "Core/IPC_HLE/WII_IPC_HLE_Device_FileIO.h"
|
#include "Core/IPC_HLE/WII_IPC_HLE_Device_FileIO.h"
|
||||||
#include "Core/IPC_HLE/WII_IPC_HLE_Device_fs.h"
|
#include "Core/IPC_HLE/WII_IPC_HLE_Device_fs.h"
|
||||||
|
|
||||||
|
@ -19,7 +22,7 @@ static Common::replace_v replacements;
|
||||||
// This is used by several of the FileIO and /dev/fs functions
|
// This is used by several of the FileIO and /dev/fs functions
|
||||||
std::string HLE_IPC_BuildFilename(std::string path_wii)
|
std::string HLE_IPC_BuildFilename(std::string path_wii)
|
||||||
{
|
{
|
||||||
std::string path_full = File::GetUserPath(D_WIIROOT_IDX);
|
std::string path_full = File::GetUserPath(D_SESSION_WIIROOT_IDX);
|
||||||
|
|
||||||
// Replaces chars that FAT32 can't support with strings defined in /sys/replace
|
// Replaces chars that FAT32 can't support with strings defined in /sys/replace
|
||||||
for (auto& replacement : replacements)
|
for (auto& replacement : replacements)
|
||||||
|
|
|
@ -32,7 +32,7 @@ IPCCommandResult CWII_IPC_HLE_Device_fs::Open(u32 _CommandAddress, u32 _Mode)
|
||||||
{
|
{
|
||||||
// clear tmp folder
|
// clear tmp folder
|
||||||
{
|
{
|
||||||
std::string Path = File::GetUserPath(D_WIIUSER_IDX) + "tmp";
|
std::string Path = HLE_IPC_BuildFilename("/tmp");
|
||||||
File::DeleteDirRecursively(Path);
|
File::DeleteDirRecursively(Path);
|
||||||
File::CreateDir(Path);
|
File::CreateDir(Path);
|
||||||
}
|
}
|
||||||
|
@ -221,7 +221,6 @@ IPCCommandResult CWII_IPC_HLE_Device_fs::IOCtlV(u32 _CommandAddress)
|
||||||
IPCCommandResult CWII_IPC_HLE_Device_fs::IOCtl(u32 _CommandAddress)
|
IPCCommandResult CWII_IPC_HLE_Device_fs::IOCtl(u32 _CommandAddress)
|
||||||
{
|
{
|
||||||
//u32 DeviceID = Memory::Read_U32(_CommandAddress + 8);
|
//u32 DeviceID = Memory::Read_U32(_CommandAddress + 8);
|
||||||
//LOG(WII_IPC_FILEIO, "FS: IOCtl (Device=%s, DeviceID=%08x)", GetDeviceName().c_str(), DeviceID);
|
|
||||||
|
|
||||||
u32 Parameter = Memory::Read_U32(_CommandAddress + 0xC);
|
u32 Parameter = Memory::Read_U32(_CommandAddress + 0xC);
|
||||||
u32 BufferIn = Memory::Read_U32(_CommandAddress + 0x10);
|
u32 BufferIn = Memory::Read_U32(_CommandAddress + 0x10);
|
||||||
|
@ -483,7 +482,7 @@ void CWII_IPC_HLE_Device_fs::DoState(PointerWrap& p)
|
||||||
|
|
||||||
// handle /tmp
|
// handle /tmp
|
||||||
|
|
||||||
std::string Path = File::GetUserPath(D_WIIUSER_IDX) + "tmp";
|
std::string Path = File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/tmp";
|
||||||
if (p.GetMode() == PointerWrap::MODE_READ)
|
if (p.GetMode() == PointerWrap::MODE_READ)
|
||||||
{
|
{
|
||||||
File::DeleteDirRecursively(Path);
|
File::DeleteDirRecursively(Path);
|
||||||
|
|
|
@ -4,7 +4,9 @@
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "Common/CommonPaths.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
|
#include "Common/NandPaths.h"
|
||||||
#include "Common/Timer.h"
|
#include "Common/Timer.h"
|
||||||
|
|
||||||
#include "Core/HW/EXI_DeviceIPL.h"
|
#include "Core/HW/EXI_DeviceIPL.h"
|
||||||
|
@ -172,7 +174,7 @@ private:
|
||||||
public:
|
public:
|
||||||
NWC24Config()
|
NWC24Config()
|
||||||
{
|
{
|
||||||
path = File::GetUserPath(D_WIIWC24_IDX) + "nwc24msg.cfg";
|
path = File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/" WII_WC24CONF_DIR "/nwc24msg.cfg";
|
||||||
ReadConfig();
|
ReadConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -211,7 +213,7 @@ public:
|
||||||
{
|
{
|
||||||
if (!File::Exists(path))
|
if (!File::Exists(path))
|
||||||
{
|
{
|
||||||
if (!File::CreateFullPath(File::GetUserPath(D_WIIWC24_IDX)))
|
if (!File::CreateFullPath(File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/" WII_WC24CONF_DIR))
|
||||||
{
|
{
|
||||||
ERROR_LOG(WII_IPC_WC24, "Failed to create directory for WC24");
|
ERROR_LOG(WII_IPC_WC24, "Failed to create directory for WC24");
|
||||||
}
|
}
|
||||||
|
@ -322,7 +324,7 @@ class WiiNetConfig
|
||||||
public:
|
public:
|
||||||
WiiNetConfig()
|
WiiNetConfig()
|
||||||
{
|
{
|
||||||
path = File::GetUserPath(D_WIISYSCONF_IDX) + "net/02/config.dat";
|
path = File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/" WII_SYSCONF_DIR "/net/02/config.dat";
|
||||||
ReadConfig();
|
ReadConfig();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -347,7 +349,7 @@ public:
|
||||||
{
|
{
|
||||||
if (!File::Exists(path))
|
if (!File::Exists(path))
|
||||||
{
|
{
|
||||||
if (!File::CreateFullPath(std::string(File::GetUserPath(D_WIISYSCONF_IDX) + "net/02/")))
|
if (!File::CreateFullPath(std::string(File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/" WII_SYSCONF_DIR "/net/02/")))
|
||||||
{
|
{
|
||||||
ERROR_LOG(WII_IPC_NET, "Failed to create directory for network config file");
|
ERROR_LOG(WII_IPC_NET, "Failed to create directory for network config file");
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
|
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
|
#include "Common/NandPaths.h"
|
||||||
#include "Core/Core.h"
|
#include "Core/Core.h"
|
||||||
#include "Core/IPC_HLE/WII_IPC_HLE_Device_net_ssl.h"
|
#include "Core/IPC_HLE/WII_IPC_HLE_Device_net_ssl.h"
|
||||||
#include "Core/IPC_HLE/WII_Socket.h"
|
#include "Core/IPC_HLE/WII_Socket.h"
|
||||||
|
@ -286,7 +287,7 @@ _SSL_NEW_ERROR:
|
||||||
if (SSLID_VALID(sslID))
|
if (SSLID_VALID(sslID))
|
||||||
{
|
{
|
||||||
WII_SSL* ssl = &_SSL[sslID];
|
WII_SSL* ssl = &_SSL[sslID];
|
||||||
std::string cert_base_path(File::GetUserPath(D_WIIUSER_IDX));
|
std::string cert_base_path = File::GetUserPath(D_SESSION_WIIROOT_IDX);
|
||||||
int ret = x509_crt_parse_file(&ssl->clicert, (cert_base_path + "clientca.pem").c_str());
|
int ret = x509_crt_parse_file(&ssl->clicert, (cert_base_path + "clientca.pem").c_str());
|
||||||
int pk_ret = pk_parse_keyfile(&ssl->pk, (cert_base_path + "clientcakey.pem").c_str(), nullptr);
|
int pk_ret = pk_parse_keyfile(&ssl->pk, (cert_base_path + "clientcakey.pem").c_str(), nullptr);
|
||||||
if (ret || pk_ret)
|
if (ret || pk_ret)
|
||||||
|
@ -343,9 +344,8 @@ _SSL_NEW_ERROR:
|
||||||
if (SSLID_VALID(sslID))
|
if (SSLID_VALID(sslID))
|
||||||
{
|
{
|
||||||
WII_SSL* ssl = &_SSL[sslID];
|
WII_SSL* ssl = &_SSL[sslID];
|
||||||
std::string cert_base_path(File::GetUserPath(D_WIIUSER_IDX));
|
|
||||||
|
|
||||||
int ret = x509_crt_parse_file(&ssl->cacert, (cert_base_path + "rootca.pem").c_str());
|
int ret = x509_crt_parse_file(&ssl->cacert, (File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/rootca.pem").c_str());
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
x509_crt_free(&ssl->clicert);
|
x509_crt_free(&ssl->clicert);
|
||||||
|
|
|
@ -61,7 +61,7 @@ void CWII_IPC_HLE_Device_sdio_slot0::EventNotify()
|
||||||
|
|
||||||
void CWII_IPC_HLE_Device_sdio_slot0::OpenInternal()
|
void CWII_IPC_HLE_Device_sdio_slot0::OpenInternal()
|
||||||
{
|
{
|
||||||
const std::string filename = File::GetUserPath(D_WIIUSER_IDX) + "sd.raw";
|
const std::string filename = File::GetUserPath(D_WIIROOT_IDX) + "/sd.raw";
|
||||||
m_Card.Open(filename, "r+b");
|
m_Card.Open(filename, "r+b");
|
||||||
if (!m_Card)
|
if (!m_Card)
|
||||||
{
|
{
|
||||||
|
|
|
@ -119,7 +119,7 @@ void make_blanksig_ec_cert(u8 *cert_out, const char *signer, const char *name, c
|
||||||
EcWii::EcWii()
|
EcWii::EcWii()
|
||||||
{
|
{
|
||||||
bool init = true;
|
bool init = true;
|
||||||
std::string keys_path = File::GetUserPath(D_WIIUSER_IDX) + "keys.bin";
|
std::string keys_path = File::GetUserPath(D_WIIROOT_IDX) + "/keys.bin";
|
||||||
if (File::Exists(keys_path))
|
if (File::Exists(keys_path))
|
||||||
{
|
{
|
||||||
File::IOFile keys_f(keys_path, "rb");
|
File::IOFile keys_f(keys_path, "rb");
|
||||||
|
|
|
@ -35,7 +35,7 @@ void CSharedContent::UpdateLocation()
|
||||||
{
|
{
|
||||||
m_Elements.clear();
|
m_Elements.clear();
|
||||||
m_lastID = 0;
|
m_lastID = 0;
|
||||||
m_contentMap = StringFromFormat("%sshared1/content.map", File::GetUserPath(D_WIIUSER_IDX).c_str());
|
m_contentMap = StringFromFormat("%s/shared1/content.map", File::GetUserPath(D_WIIROOT_IDX).c_str());
|
||||||
|
|
||||||
File::IOFile pFile(m_contentMap, "rb");
|
File::IOFile pFile(m_contentMap, "rb");
|
||||||
SElement Element;
|
SElement Element;
|
||||||
|
@ -55,7 +55,7 @@ std::string CSharedContent::GetFilenameFromSHA1(const u8* _pHash)
|
||||||
{
|
{
|
||||||
if (memcmp(_pHash, Element.SHA1Hash, 20) == 0)
|
if (memcmp(_pHash, Element.SHA1Hash, 20) == 0)
|
||||||
{
|
{
|
||||||
return StringFromFormat("%sshared1/%c%c%c%c%c%c%c%c.app", File::GetUserPath(D_WIIUSER_IDX).c_str(),
|
return StringFromFormat("%s/shared1/%c%c%c%c%c%c%c%c.app", File::GetUserPath(D_WIIROOT_IDX).c_str(),
|
||||||
Element.FileName[0], Element.FileName[1], Element.FileName[2], Element.FileName[3],
|
Element.FileName[0], Element.FileName[1], Element.FileName[2], Element.FileName[3],
|
||||||
Element.FileName[4], Element.FileName[5], Element.FileName[6], Element.FileName[7]);
|
Element.FileName[4], Element.FileName[5], Element.FileName[6], Element.FileName[7]);
|
||||||
}
|
}
|
||||||
|
@ -80,7 +80,7 @@ std::string CSharedContent::AddSharedContent(const u8* _pHash)
|
||||||
File::IOFile pFile(m_contentMap, "ab");
|
File::IOFile pFile(m_contentMap, "ab");
|
||||||
pFile.WriteArray(&Element, 1);
|
pFile.WriteArray(&Element, 1);
|
||||||
|
|
||||||
filename = StringFromFormat("%sshared1/%s.app", File::GetUserPath(D_WIIUSER_IDX).c_str(), id.c_str());
|
filename = StringFromFormat("%s/shared1/%s.app", File::GetUserPath(D_WIIROOT_IDX).c_str(), id.c_str());
|
||||||
m_lastID++;
|
m_lastID++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -371,7 +371,7 @@ void cUIDsys::UpdateLocation()
|
||||||
{
|
{
|
||||||
m_Elements.clear();
|
m_Elements.clear();
|
||||||
m_lastUID = 0x00001000;
|
m_lastUID = 0x00001000;
|
||||||
m_uidSys = StringFromFormat("%ssys/uid.sys", File::GetUserPath(D_WIIUSER_IDX).c_str());
|
m_uidSys = File::GetUserPath(D_SESSION_WIIROOT_IDX) + "/sys/uid.sys";
|
||||||
|
|
||||||
File::IOFile pFile(m_uidSys, "rb");
|
File::IOFile pFile(m_uidSys, "rb");
|
||||||
SElement Element;
|
SElement Element;
|
||||||
|
|
|
@ -33,8 +33,8 @@ std::vector<u32> IVolume::GetBanner(int* width, int* height) const
|
||||||
GetTitleID((u8*)&TitleID);
|
GetTitleID((u8*)&TitleID);
|
||||||
TitleID = Common::swap64(TitleID);
|
TitleID = Common::swap64(TitleID);
|
||||||
|
|
||||||
std::string file_name = StringFromFormat("%stitle/%08x/%08x/data/banner.bin",
|
std::string file_name = StringFromFormat("%s/title/%08x/%08x/data/banner.bin",
|
||||||
File::GetUserPath(D_WIIUSER_IDX).c_str(), (u32)(TitleID >> 32), (u32)TitleID);
|
File::GetUserPath(D_WIIROOT_IDX).c_str(), (u32)(TitleID >> 32), (u32)TitleID);
|
||||||
if (!File::Exists(file_name))
|
if (!File::Exists(file_name))
|
||||||
return std::vector<u32>();
|
return std::vector<u32>();
|
||||||
|
|
||||||
|
|
|
@ -292,7 +292,7 @@ const QString GameFile::GetWiiFSPath() const
|
||||||
volume->GetTitleID((u8*)&title);
|
volume->GetTitleID((u8*)&title);
|
||||||
title = Common::swap64(title);
|
title = Common::swap64(title);
|
||||||
|
|
||||||
path = StringFromFormat("%stitle/%08x/%08x/data/", File::GetUserPath(D_WIIUSER_IDX).c_str(), (u32)(title >> 32), (u32)title);
|
path = StringFromFormat("%s/title/%08x/%08x/data/", File::GetUserPath(D_WIIROOT_IDX).c_str(), (u32)(title >> 32), (u32)title);
|
||||||
|
|
||||||
if (!File::Exists(path))
|
if (!File::Exists(path))
|
||||||
File::CreateFullPath(path);
|
File::CreateFullPath(path);
|
||||||
|
|
|
@ -182,8 +182,6 @@ void PathConfigPane::OnNANDRootChanged(wxCommandEvent& event)
|
||||||
m_nand_root_dirpicker->SetPath(StrToWxStr(nand_path));
|
m_nand_root_dirpicker->SetPath(StrToWxStr(nand_path));
|
||||||
|
|
||||||
SConfig::GetInstance().m_SYSCONF->UpdateLocation();
|
SConfig::GetInstance().m_SYSCONF->UpdateLocation();
|
||||||
DiscIO::cUIDsys::AccessInstance().UpdateLocation();
|
|
||||||
DiscIO::CSharedContent::AccessInstance().UpdateLocation();
|
|
||||||
|
|
||||||
main_frame->UpdateWiiMenuChoice();
|
main_frame->UpdateWiiMenuChoice();
|
||||||
}
|
}
|
||||||
|
|
|
@ -259,8 +259,8 @@ const std::string GameListItem::GetWiiFSPath() const
|
||||||
iso->GetTitleID((u8*)&title);
|
iso->GetTitleID((u8*)&title);
|
||||||
title = Common::swap64(title);
|
title = Common::swap64(title);
|
||||||
|
|
||||||
const std::string path = StringFromFormat("%stitle/%08x/%08x/data/",
|
const std::string path = StringFromFormat("%s/title/%08x/%08x/data/",
|
||||||
File::GetUserPath(D_WIIUSER_IDX).c_str(), (u32)(title>>32), (u32)title);
|
File::GetUserPath(D_WIIROOT_IDX).c_str(), (u32)(title>>32), (u32)title);
|
||||||
|
|
||||||
if (!File::Exists(path))
|
if (!File::Exists(path))
|
||||||
File::CreateFullPath(path);
|
File::CreateFullPath(path);
|
||||||
|
|
|
@ -537,7 +537,7 @@ JNIEXPORT void JNICALL Java_org_dolphinemu_dolphinemu_NativeLibrary_CreateUserFo
|
||||||
{
|
{
|
||||||
File::CreateFullPath(File::GetUserPath(D_CONFIG_IDX));
|
File::CreateFullPath(File::GetUserPath(D_CONFIG_IDX));
|
||||||
File::CreateFullPath(File::GetUserPath(D_GCUSER_IDX));
|
File::CreateFullPath(File::GetUserPath(D_GCUSER_IDX));
|
||||||
File::CreateFullPath(File::GetUserPath(D_WIIUSER_IDX));
|
File::CreateFullPath(File::GetUserPath(D_WIIROOT_IDX) + DIR_SEP);
|
||||||
File::CreateFullPath(File::GetUserPath(D_CACHE_IDX));
|
File::CreateFullPath(File::GetUserPath(D_CACHE_IDX));
|
||||||
File::CreateFullPath(File::GetUserPath(D_DUMPDSP_IDX));
|
File::CreateFullPath(File::GetUserPath(D_DUMPDSP_IDX));
|
||||||
File::CreateFullPath(File::GetUserPath(D_DUMPTEXTURES_IDX));
|
File::CreateFullPath(File::GetUserPath(D_DUMPTEXTURES_IDX));
|
||||||
|
|
|
@ -51,8 +51,8 @@ void Shutdown()
|
||||||
void CreateDirectories()
|
void CreateDirectories()
|
||||||
{
|
{
|
||||||
// Copy initial Wii NAND data from Sys to User.
|
// Copy initial Wii NAND data from Sys to User.
|
||||||
File::CopyDir(File::GetSysDirectory() + WII_USER_DIR DIR_SEP,
|
File::CopyDir(File::GetSysDirectory() + WII_USER_DIR,
|
||||||
File::GetUserPath(D_WIIUSER_IDX));
|
File::GetUserPath(D_WIIROOT_IDX));
|
||||||
|
|
||||||
File::CreateFullPath(File::GetUserPath(D_USER_IDX));
|
File::CreateFullPath(File::GetUserPath(D_USER_IDX));
|
||||||
File::CreateFullPath(File::GetUserPath(D_CACHE_IDX));
|
File::CreateFullPath(File::GetUserPath(D_CACHE_IDX));
|
||||||
|
|
Loading…
Reference in New Issue