Unify the way of setting game ID, title ID, revision
The existing code from ConfigManager, ES and MIOS is merged into a new set of functions called SetRunningGameMetadata.
This commit is contained in:
parent
883bec873f
commit
ced1614cac
|
@ -415,8 +415,7 @@ void Stop()
|
||||||
void RestoreConfig()
|
void RestoreConfig()
|
||||||
{
|
{
|
||||||
SConfig::GetInstance().LoadSettingsFromSysconf();
|
SConfig::GetInstance().LoadSettingsFromSysconf();
|
||||||
SConfig::GetInstance().m_strGameID = "00000000";
|
SConfig::GetInstance().ResetRunningGameMetadata();
|
||||||
SConfig::GetInstance().m_title_id = 0;
|
|
||||||
config_cache.RestoreConfig(&SConfig::GetInstance());
|
config_cache.RestoreConfig(&SConfig::GetInstance());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,11 +21,16 @@
|
||||||
#include "Core/Boot/Boot.h"
|
#include "Core/Boot/Boot.h"
|
||||||
#include "Core/Boot/Boot_DOL.h"
|
#include "Core/Boot/Boot_DOL.h"
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/Core.h" // for bWii
|
#include "Core/Core.h"
|
||||||
#include "Core/FifoPlayer/FifoDataFile.h"
|
#include "Core/FifoPlayer/FifoDataFile.h"
|
||||||
|
#include "Core/HLE/HLE.h"
|
||||||
#include "Core/HW/SI/SI.h"
|
#include "Core/HW/SI/SI.h"
|
||||||
|
#include "Core/IOS/ES/Formats.h"
|
||||||
#include "Core/IOS/USB/Bluetooth/BTBase.h"
|
#include "Core/IOS/USB/Bluetooth/BTBase.h"
|
||||||
|
#include "Core/PatchEngine.h"
|
||||||
|
#include "Core/PowerPC/PPCSymbolDB.h"
|
||||||
#include "Core/PowerPC/PowerPC.h"
|
#include "Core/PowerPC/PowerPC.h"
|
||||||
|
#include "VideoCommon/HiresTextures.h"
|
||||||
|
|
||||||
#include "DiscIO/Enums.h"
|
#include "DiscIO/Enums.h"
|
||||||
#include "DiscIO/NANDContentLoader.h"
|
#include "DiscIO/NANDContentLoader.h"
|
||||||
|
@ -726,6 +731,67 @@ void SConfig::LoadSettingsFromSysconf()
|
||||||
bPAL60 = sysconf.GetData<u8>("IPL.E60") != 0;
|
bPAL60 = sysconf.GetData<u8>("IPL.E60") != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SConfig::ResetRunningGameMetadata()
|
||||||
|
{
|
||||||
|
SetRunningGameMetadata("00000000", 0, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void SConfig::SetRunningGameMetadata(const DiscIO::IVolume& volume)
|
||||||
|
{
|
||||||
|
u64 title_id = 0;
|
||||||
|
volume.GetTitleID(&title_id);
|
||||||
|
SetRunningGameMetadata(volume.GetGameID(), title_id, volume.GetRevision());
|
||||||
|
}
|
||||||
|
|
||||||
|
void SConfig::SetRunningGameMetadata(const IOS::ES::TMDReader& tmd)
|
||||||
|
{
|
||||||
|
const u64 title_id = tmd.GetTitleId();
|
||||||
|
std::string game_id;
|
||||||
|
|
||||||
|
if (IOS::ES::IsDiscTitle(title_id))
|
||||||
|
{
|
||||||
|
const u32 title_identifier = Common::swap32(static_cast<u32>(title_id));
|
||||||
|
const u16 group_id = Common::swap16(tmd.GetGroupId());
|
||||||
|
|
||||||
|
char ascii_game_id[6];
|
||||||
|
std::memcpy(ascii_game_id, &title_identifier, sizeof(title_identifier));
|
||||||
|
std::memcpy(ascii_game_id + sizeof(title_identifier), &group_id, sizeof(group_id));
|
||||||
|
|
||||||
|
game_id = ascii_game_id;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
game_id = StringFromFormat("%016" PRIX64, title_id);
|
||||||
|
}
|
||||||
|
|
||||||
|
SetRunningGameMetadata(game_id, title_id, tmd.GetTitleVersion());
|
||||||
|
}
|
||||||
|
|
||||||
|
void SConfig::SetRunningGameMetadata(const std::string& game_id, u64 title_id, u16 revision)
|
||||||
|
{
|
||||||
|
const bool was_changed = m_game_id != game_id || m_title_id != title_id || m_revision != revision;
|
||||||
|
m_game_id = game_id;
|
||||||
|
m_title_id = title_id;
|
||||||
|
m_revision = revision;
|
||||||
|
|
||||||
|
if (was_changed)
|
||||||
|
{
|
||||||
|
NOTICE_LOG(BOOT, "Game ID set to %s", game_id.c_str());
|
||||||
|
|
||||||
|
if (Core::IsRunning())
|
||||||
|
{
|
||||||
|
// TODO: have a callback mechanism for title changes?
|
||||||
|
g_symbolDB.Clear();
|
||||||
|
CBoot::LoadMapFromFilename();
|
||||||
|
HLE::Clear();
|
||||||
|
HLE::PatchFunctions();
|
||||||
|
PatchEngine::Shutdown();
|
||||||
|
PatchEngine::LoadPatches();
|
||||||
|
HiresTexture::Update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void SConfig::LoadDefaults()
|
void SConfig::LoadDefaults()
|
||||||
{
|
{
|
||||||
bEnableDebugging = false;
|
bEnableDebugging = false;
|
||||||
|
@ -783,9 +849,7 @@ void SConfig::LoadDefaults()
|
||||||
bJITSystemRegistersOff = false;
|
bJITSystemRegistersOff = false;
|
||||||
bJITBranchOff = false;
|
bJITBranchOff = false;
|
||||||
|
|
||||||
m_strGameID = "00000000";
|
ResetRunningGameMetadata();
|
||||||
m_title_id = 0;
|
|
||||||
m_revision = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SConfig::IsUSBDeviceWhitelisted(const std::pair<u16, u16> vid_pid) const
|
bool SConfig::IsUSBDeviceWhitelisted(const std::pair<u16, u16> vid_pid) const
|
||||||
|
@ -870,9 +934,7 @@ bool SConfig::AutoSetup(EBootBS2 _BootBS2)
|
||||||
m_strFilename.c_str());
|
m_strFilename.c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
m_strGameID = pVolume->GetGameID();
|
SetRunningGameMetadata(*pVolume);
|
||||||
pVolume->GetTitleID(&m_title_id);
|
|
||||||
m_revision = pVolume->GetRevision();
|
|
||||||
|
|
||||||
// Check if we have a Wii disc
|
// Check if we have a Wii disc
|
||||||
bWii = pVolume->GetVolumeType() == DiscIO::Platform::WII_DISC;
|
bWii = pVolume->GetVolumeType() == DiscIO::Platform::WII_DISC;
|
||||||
|
@ -916,11 +978,11 @@ bool SConfig::AutoSetup(EBootBS2 _BootBS2)
|
||||||
}
|
}
|
||||||
else if (DiscIO::CNANDContentManager::Access().GetNANDLoader(m_strFilename).IsValid())
|
else if (DiscIO::CNANDContentManager::Access().GetNANDLoader(m_strFilename).IsValid())
|
||||||
{
|
{
|
||||||
std::unique_ptr<DiscIO::IVolume> pVolume(DiscIO::CreateVolumeFromFilename(m_strFilename));
|
const DiscIO::CNANDContentLoader& content_loader =
|
||||||
const DiscIO::CNANDContentLoader& ContentLoader =
|
|
||||||
DiscIO::CNANDContentManager::Access().GetNANDLoader(m_strFilename);
|
DiscIO::CNANDContentManager::Access().GetNANDLoader(m_strFilename);
|
||||||
|
const IOS::ES::TMDReader& tmd = content_loader.GetTMD();
|
||||||
|
|
||||||
if (ContentLoader.GetContentByIndex(ContentLoader.GetTMD().GetBootIndex()) == nullptr)
|
if (content_loader.GetContentByIndex(tmd.GetBootIndex()) == nullptr)
|
||||||
{
|
{
|
||||||
// WAD is valid yet cannot be booted. Install instead.
|
// WAD is valid yet cannot be booted. Install instead.
|
||||||
u64 installed = DiscIO::CNANDContentManager::Access().Install_WiiWAD(m_strFilename);
|
u64 installed = DiscIO::CNANDContentManager::Access().Install_WiiWAD(m_strFilename);
|
||||||
|
@ -929,33 +991,11 @@ bool SConfig::AutoSetup(EBootBS2 _BootBS2)
|
||||||
return false; // do not boot
|
return false; // do not boot
|
||||||
}
|
}
|
||||||
|
|
||||||
SetRegion(ContentLoader.GetTMD().GetRegion(), &set_region_dir);
|
SetRegion(tmd.GetRegion(), &set_region_dir);
|
||||||
|
SetRunningGameMetadata(tmd);
|
||||||
|
|
||||||
bWii = true;
|
bWii = true;
|
||||||
m_BootType = BOOT_WII_NAND;
|
m_BootType = BOOT_WII_NAND;
|
||||||
|
|
||||||
if (pVolume)
|
|
||||||
{
|
|
||||||
m_strGameID = pVolume->GetGameID();
|
|
||||||
pVolume->GetTitleID(&m_title_id);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
// null pVolume means that we are loading from nand folder (Most Likely Wii Menu)
|
|
||||||
// if this is the second boot we would be using the Name and id of the last title
|
|
||||||
m_strGameID.clear();
|
|
||||||
m_title_id = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Use the TitleIDhex for name and/or game ID if launching
|
|
||||||
// from nand folder or if it is not ascii characters
|
|
||||||
// (specifically sysmenu could potentially apply to other things)
|
|
||||||
std::string titleidstr = StringFromFormat("%016" PRIx64, m_title_id);
|
|
||||||
|
|
||||||
if (m_strGameID.empty())
|
|
||||||
{
|
|
||||||
m_strGameID = titleidstr;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,6 +19,14 @@ namespace DiscIO
|
||||||
{
|
{
|
||||||
enum class Language;
|
enum class Language;
|
||||||
enum class Region;
|
enum class Region;
|
||||||
|
class IVolume;
|
||||||
|
}
|
||||||
|
namespace IOS
|
||||||
|
{
|
||||||
|
namespace ES
|
||||||
|
{
|
||||||
|
class TMDReader;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// DSP Backend Types
|
// DSP Backend Types
|
||||||
|
@ -209,17 +217,20 @@ struct SConfig : NonCopyable
|
||||||
std::string m_strDefaultISO;
|
std::string m_strDefaultISO;
|
||||||
std::string m_strDVDRoot;
|
std::string m_strDVDRoot;
|
||||||
std::string m_strApploader;
|
std::string m_strApploader;
|
||||||
std::string m_strGameID;
|
|
||||||
u64 m_title_id;
|
|
||||||
std::string m_strWiiSDCardPath;
|
std::string m_strWiiSDCardPath;
|
||||||
u16 m_revision;
|
|
||||||
|
|
||||||
std::string m_perfDir;
|
std::string m_perfDir;
|
||||||
|
|
||||||
|
const std::string& GetGameID() const { return m_game_id; }
|
||||||
|
u64 GetTitleID() const { return m_title_id; }
|
||||||
|
u16 GetRevision() const { return m_revision; }
|
||||||
|
void ResetRunningGameMetadata();
|
||||||
|
void SetRunningGameMetadata(const DiscIO::IVolume& volume);
|
||||||
|
void SetRunningGameMetadata(const IOS::ES::TMDReader& tmd);
|
||||||
|
|
||||||
void LoadDefaults();
|
void LoadDefaults();
|
||||||
static const char* GetDirectoryForRegion(DiscIO::Region region);
|
static const char* GetDirectoryForRegion(DiscIO::Region region);
|
||||||
bool AutoSetup(EBootBS2 _BootBS2);
|
bool AutoSetup(EBootBS2 _BootBS2);
|
||||||
const std::string& GetGameID() const { return m_strGameID; }
|
|
||||||
void CheckMemcardPath(std::string& memcardPath, const std::string& gameRegion, bool isSlotA);
|
void CheckMemcardPath(std::string& memcardPath, const std::string& gameRegion, bool isSlotA);
|
||||||
DiscIO::Language GetCurrentLanguage(bool wii) const;
|
DiscIO::Language GetCurrentLanguage(bool wii) const;
|
||||||
|
|
||||||
|
@ -373,7 +384,12 @@ private:
|
||||||
void LoadUSBPassthroughSettings(IniFile& ini);
|
void LoadUSBPassthroughSettings(IniFile& ini);
|
||||||
void LoadSysconfSettings(IniFile& ini);
|
void LoadSysconfSettings(IniFile& ini);
|
||||||
|
|
||||||
|
void SetRunningGameMetadata(const std::string& game_id, u64 title_id, u16 revision);
|
||||||
bool SetRegion(DiscIO::Region region, std::string* directory_name);
|
bool SetRegion(DiscIO::Region region, std::string* directory_name);
|
||||||
|
|
||||||
static SConfig* m_Instance;
|
static SConfig* m_Instance;
|
||||||
|
|
||||||
|
std::string m_game_id;
|
||||||
|
u64 m_title_id;
|
||||||
|
u16 m_revision;
|
||||||
};
|
};
|
||||||
|
|
|
@ -156,7 +156,7 @@ void CEXIMemoryCard::SetupGciFolder(u16 sizeMb)
|
||||||
{
|
{
|
||||||
DiscIO::Region region = SConfig::GetInstance().m_region;
|
DiscIO::Region region = SConfig::GetInstance().m_region;
|
||||||
|
|
||||||
std::string game_id = SConfig::GetInstance().m_strGameID;
|
const std::string& game_id = SConfig::GetInstance().GetGameID();
|
||||||
u32 CurrentGameId = 0;
|
u32 CurrentGameId = 0;
|
||||||
if (game_id.length() >= 4 && game_id != "00000000" && game_id != TITLEID_SYSMENU_STRING)
|
if (game_id.length() >= 4 && game_id != "00000000" && game_id != TITLEID_SYSMENU_STRING)
|
||||||
CurrentGameId = BE32((u8*)game_id.c_str());
|
CurrentGameId = BE32((u8*)game_id.c_str());
|
||||||
|
|
|
@ -24,17 +24,12 @@
|
||||||
#include "Common/MsgHandler.h"
|
#include "Common/MsgHandler.h"
|
||||||
#include "Common/NandPaths.h"
|
#include "Common/NandPaths.h"
|
||||||
#include "Common/Swap.h"
|
#include "Common/Swap.h"
|
||||||
#include "Core/Boot/Boot.h"
|
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/HLE/HLE.h"
|
|
||||||
#include "Core/HW/Memmap.h"
|
#include "Core/HW/Memmap.h"
|
||||||
#include "Core/IOS/ES/Formats.h"
|
#include "Core/IOS/ES/Formats.h"
|
||||||
#include "Core/PatchEngine.h"
|
|
||||||
#include "Core/PowerPC/PPCSymbolDB.h"
|
|
||||||
#include "Core/ec_wii.h"
|
#include "Core/ec_wii.h"
|
||||||
#include "DiscIO/NANDContentLoader.h"
|
#include "DiscIO/NANDContentLoader.h"
|
||||||
#include "DiscIO/Volume.h"
|
#include "DiscIO/Volume.h"
|
||||||
#include "VideoCommon/HiresTextures.h"
|
|
||||||
|
|
||||||
namespace IOS
|
namespace IOS
|
||||||
{
|
{
|
||||||
|
@ -48,7 +43,6 @@ struct TitleContext
|
||||||
void DoState(PointerWrap& p);
|
void DoState(PointerWrap& p);
|
||||||
void Update(const DiscIO::CNANDContentLoader& content_loader);
|
void Update(const DiscIO::CNANDContentLoader& content_loader);
|
||||||
void Update(const IOS::ES::TMDReader& tmd_, const IOS::ES::TicketReader& ticket_);
|
void Update(const IOS::ES::TMDReader& tmd_, const IOS::ES::TicketReader& ticket_);
|
||||||
void UpdateRunningGame() const;
|
|
||||||
|
|
||||||
IOS::ES::TicketReader ticket;
|
IOS::ES::TicketReader ticket;
|
||||||
IOS::ES::TMDReader tmd;
|
IOS::ES::TMDReader tmd;
|
||||||
|
@ -86,12 +80,6 @@ constexpr const u8* s_key_table[11] = {
|
||||||
s_key_empty, // Unknown
|
s_key_empty, // Unknown
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool IsDiscTitle(u64 title_id)
|
|
||||||
{
|
|
||||||
return IsTitleType(title_id, IOS::ES::TitleType::Game) ||
|
|
||||||
IsTitleType(title_id, IOS::ES::TitleType::GameWithChannel);
|
|
||||||
}
|
|
||||||
|
|
||||||
ES::ES(u32 device_id, const std::string& device_name) : Device(device_id, device_name)
|
ES::ES(u32 device_id, const std::string& device_name) : Device(device_id, device_name)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -145,43 +133,11 @@ void TitleContext::Update(const IOS::ES::TMDReader& tmd_, const IOS::ES::TicketR
|
||||||
// Interesting title changes (channel or disc game launch) always happen after an IOS reload.
|
// Interesting title changes (channel or disc game launch) always happen after an IOS reload.
|
||||||
if (first_change)
|
if (first_change)
|
||||||
{
|
{
|
||||||
UpdateRunningGame();
|
SConfig::GetInstance().SetRunningGameMetadata(tmd);
|
||||||
first_change = false;
|
first_change = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void TitleContext::UpdateRunningGame() const
|
|
||||||
{
|
|
||||||
if (IsDiscTitle(tmd.GetTitleId()))
|
|
||||||
{
|
|
||||||
const u32 title_identifier = Common::swap32(static_cast<u32>(tmd.GetTitleId()));
|
|
||||||
const u16 group_id = Common::swap16(tmd.GetGroupId());
|
|
||||||
|
|
||||||
char ascii_game_id[6];
|
|
||||||
std::memcpy(ascii_game_id, &title_identifier, sizeof(title_identifier));
|
|
||||||
std::memcpy(ascii_game_id + sizeof(title_identifier), &group_id, sizeof(group_id));
|
|
||||||
|
|
||||||
SConfig::GetInstance().m_strGameID = ascii_game_id;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
SConfig::GetInstance().m_strGameID = StringFromFormat("%016" PRIX64, tmd.GetTitleId());
|
|
||||||
}
|
|
||||||
|
|
||||||
SConfig::GetInstance().m_title_id = tmd.GetTitleId();
|
|
||||||
|
|
||||||
// TODO: have a callback mechanism for title changes?
|
|
||||||
g_symbolDB.Clear();
|
|
||||||
CBoot::LoadMapFromFilename();
|
|
||||||
::HLE::Clear();
|
|
||||||
::HLE::PatchFunctions();
|
|
||||||
PatchEngine::Shutdown();
|
|
||||||
PatchEngine::LoadPatches();
|
|
||||||
HiresTexture::Update();
|
|
||||||
|
|
||||||
NOTICE_LOG(IOS_ES, "Active title: %016" PRIx64, tmd.GetTitleId());
|
|
||||||
}
|
|
||||||
|
|
||||||
void ES::LoadWAD(const std::string& _rContentFile)
|
void ES::LoadWAD(const std::string& _rContentFile)
|
||||||
{
|
{
|
||||||
s_content_file = _rContentFile;
|
s_content_file = _rContentFile;
|
||||||
|
@ -1040,7 +996,8 @@ IPCCommandResult ES::GetTitles(const IOCtlVRequest& request)
|
||||||
static bool ShouldReturnFakeViewsForIOSes(u64 title_id)
|
static bool ShouldReturnFakeViewsForIOSes(u64 title_id)
|
||||||
{
|
{
|
||||||
const bool ios = IsTitleType(title_id, IOS::ES::TitleType::System) && title_id != TITLEID_SYSMENU;
|
const bool ios = IsTitleType(title_id, IOS::ES::TitleType::System) && title_id != TITLEID_SYSMENU;
|
||||||
const bool disc_title = s_title_context.active && IsDiscTitle(s_title_context.tmd.GetTitleId());
|
const bool disc_title =
|
||||||
|
s_title_context.active && IOS::ES::IsDiscTitle(s_title_context.tmd.GetTitleId());
|
||||||
return ios && SConfig::GetInstance().m_BootType == SConfig::BOOT_ISO && disc_title;
|
return ios && SConfig::GetInstance().m_BootType == SConfig::BOOT_ISO && disc_title;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,12 @@ bool IsTitleType(u64 title_id, TitleType title_type)
|
||||||
return static_cast<u32>(title_id >> 32) == static_cast<u32>(title_type);
|
return static_cast<u32>(title_id >> 32) == static_cast<u32>(title_type);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool IsDiscTitle(u64 title_id)
|
||||||
|
{
|
||||||
|
return IsTitleType(title_id, TitleType::Game) ||
|
||||||
|
IsTitleType(title_id, TitleType::GameWithChannel);
|
||||||
|
}
|
||||||
|
|
||||||
bool Content::IsShared() const
|
bool Content::IsShared() const
|
||||||
{
|
{
|
||||||
return (type & 0x8000) != 0;
|
return (type & 0x8000) != 0;
|
||||||
|
|
|
@ -30,6 +30,7 @@ enum class TitleType : u32
|
||||||
};
|
};
|
||||||
|
|
||||||
bool IsTitleType(u64 title_id, TitleType title_type);
|
bool IsTitleType(u64 title_id, TitleType title_type);
|
||||||
|
bool IsDiscTitle(u64 title_id);
|
||||||
|
|
||||||
#pragma pack(push, 4)
|
#pragma pack(push, 4)
|
||||||
struct TMDHeader
|
struct TMDHeader
|
||||||
|
|
|
@ -12,7 +12,6 @@
|
||||||
#include "Common/MsgHandler.h"
|
#include "Common/MsgHandler.h"
|
||||||
#include "Common/NandPaths.h"
|
#include "Common/NandPaths.h"
|
||||||
#include "Common/Swap.h"
|
#include "Common/Swap.h"
|
||||||
#include "Core/Boot/Boot.h"
|
|
||||||
#include "Core/Boot/ElfReader.h"
|
#include "Core/Boot/ElfReader.h"
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/Core.h"
|
#include "Core/Core.h"
|
||||||
|
@ -124,17 +123,8 @@ static void ReinitHardware()
|
||||||
static void UpdateRunningGame()
|
static void UpdateRunningGame()
|
||||||
{
|
{
|
||||||
DVDThread::WaitUntilIdle();
|
DVDThread::WaitUntilIdle();
|
||||||
const DiscIO::IVolume& volume = DVDInterface::GetVolume();
|
|
||||||
SConfig::GetInstance().m_BootType = SConfig::BOOT_MIOS;
|
SConfig::GetInstance().m_BootType = SConfig::BOOT_MIOS;
|
||||||
SConfig::GetInstance().m_strGameID = volume.GetGameID();
|
SConfig::GetInstance().SetRunningGameMetadata(DVDInterface::GetVolume());
|
||||||
SConfig::GetInstance().m_revision = volume.GetRevision();
|
|
||||||
|
|
||||||
g_symbolDB.Clear();
|
|
||||||
CBoot::LoadMapFromFilename();
|
|
||||||
::HLE::Clear();
|
|
||||||
::HLE::PatchFunctions();
|
|
||||||
|
|
||||||
NOTICE_LOG(IOS, "Running game: %s", SConfig::GetInstance().m_strGameID.c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
constexpr u32 ADDRESS_INIT_SEMAPHORE = 0x30f8;
|
constexpr u32 ADDRESS_INIT_SEMAPHORE = 0x30f8;
|
||||||
|
|
|
@ -1477,7 +1477,7 @@ void GetSettings()
|
||||||
s_bNetPlay = NetPlay::IsNetPlayRunning();
|
s_bNetPlay = NetPlay::IsNetPlayRunning();
|
||||||
if (SConfig::GetInstance().bWii)
|
if (SConfig::GetInstance().bWii)
|
||||||
{
|
{
|
||||||
u64 title_id = SConfig::GetInstance().m_title_id;
|
u64 title_id = SConfig::GetInstance().GetTitleID();
|
||||||
s_bClearSave =
|
s_bClearSave =
|
||||||
!File::Exists(Common::GetTitleDataPath(title_id, Common::FROM_SESSION_ROOT) + "banner.bin");
|
!File::Exists(Common::GetTitleDataPath(title_id, Common::FROM_SESSION_ROOT) + "banner.bin");
|
||||||
s_language = SConfig::GetInstance().m_wii_language;
|
s_language = SConfig::GetInstance().m_wii_language;
|
||||||
|
|
|
@ -27,9 +27,9 @@ static std::string s_temp_wii_root;
|
||||||
static void InitializeDeterministicWiiSaves()
|
static void InitializeDeterministicWiiSaves()
|
||||||
{
|
{
|
||||||
std::string save_path =
|
std::string save_path =
|
||||||
Common::GetTitleDataPath(SConfig::GetInstance().m_title_id, Common::FROM_SESSION_ROOT);
|
Common::GetTitleDataPath(SConfig::GetInstance().GetTitleID(), Common::FROM_SESSION_ROOT);
|
||||||
std::string user_save_path =
|
std::string user_save_path =
|
||||||
Common::GetTitleDataPath(SConfig::GetInstance().m_title_id, Common::FROM_CONFIGURED_ROOT);
|
Common::GetTitleDataPath(SConfig::GetInstance().GetTitleID(), Common::FROM_CONFIGURED_ROOT);
|
||||||
if (Movie::IsRecordingInput())
|
if (Movie::IsRecordingInput())
|
||||||
{
|
{
|
||||||
if (NetPlay::IsNetPlayRunning() && !SConfig::GetInstance().bCopyWiiSaveNetplay)
|
if (NetPlay::IsNetPlayRunning() && !SConfig::GetInstance().bCopyWiiSaveNetplay)
|
||||||
|
@ -93,13 +93,13 @@ void ShutdownWiiRoot()
|
||||||
if (!s_temp_wii_root.empty())
|
if (!s_temp_wii_root.empty())
|
||||||
{
|
{
|
||||||
std::string save_path =
|
std::string save_path =
|
||||||
Common::GetTitleDataPath(SConfig::GetInstance().m_title_id, Common::FROM_SESSION_ROOT);
|
Common::GetTitleDataPath(SConfig::GetInstance().GetTitleID(), Common::FROM_SESSION_ROOT);
|
||||||
std::string user_save_path =
|
std::string user_save_path =
|
||||||
Common::GetTitleDataPath(SConfig::GetInstance().m_title_id, Common::FROM_CONFIGURED_ROOT);
|
Common::GetTitleDataPath(SConfig::GetInstance().GetTitleID(), Common::FROM_CONFIGURED_ROOT);
|
||||||
std::string user_backup_path =
|
std::string user_backup_path =
|
||||||
File::GetUserPath(D_BACKUP_IDX) +
|
File::GetUserPath(D_BACKUP_IDX) +
|
||||||
StringFromFormat("%08x/%08x/", static_cast<u32>(SConfig::GetInstance().m_title_id >> 32),
|
StringFromFormat("%08x/%08x/", static_cast<u32>(SConfig::GetInstance().GetTitleID() >> 32),
|
||||||
static_cast<u32>(SConfig::GetInstance().m_title_id));
|
static_cast<u32>(SConfig::GetInstance().GetTitleID()));
|
||||||
if (File::Exists(save_path + "banner.bin") && SConfig::GetInstance().bEnableMemcardSdWriting)
|
if (File::Exists(save_path + "banner.bin") && SConfig::GetInstance().bEnableMemcardSdWriting)
|
||||||
{
|
{
|
||||||
// Backup the existing save just in case it's still needed.
|
// Backup the existing save just in case it's still needed.
|
||||||
|
|
|
@ -177,7 +177,7 @@ void wxCheatsWindow::UpdateGUI()
|
||||||
m_gameini_default = parameters.LoadDefaultGameIni();
|
m_gameini_default = parameters.LoadDefaultGameIni();
|
||||||
m_gameini_local = parameters.LoadLocalGameIni();
|
m_gameini_local = parameters.LoadLocalGameIni();
|
||||||
m_game_id = parameters.GetGameID();
|
m_game_id = parameters.GetGameID();
|
||||||
m_game_revision = parameters.m_revision;
|
m_game_revision = parameters.GetRevision();
|
||||||
m_gameini_local_path = File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini";
|
m_gameini_local_path = File::GetUserPath(D_GAMESETTINGS_IDX) + m_game_id + ".ini";
|
||||||
Load_ARCodes();
|
Load_ARCodes();
|
||||||
Load_GeckoCodes();
|
Load_GeckoCodes();
|
||||||
|
|
|
@ -232,7 +232,7 @@ void GFXDebuggerPanel::OnPauseAtNextFrameButton(wxCommandEvent& event)
|
||||||
void GFXDebuggerPanel::OnDumpButton(wxCommandEvent& event)
|
void GFXDebuggerPanel::OnDumpButton(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
std::string dump_path =
|
std::string dump_path =
|
||||||
File::GetUserPath(D_DUMP_IDX) + "Debug/" + SConfig::GetInstance().m_strGameID + "/";
|
File::GetUserPath(D_DUMP_IDX) + "Debug/" + SConfig::GetInstance().GetGameID() + "/";
|
||||||
if (!File::CreateFullPath(dump_path))
|
if (!File::CreateFullPath(dump_path))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
|
|
@ -164,7 +164,7 @@ void GeometryShaderCache::Init()
|
||||||
|
|
||||||
std::string cache_filename =
|
std::string cache_filename =
|
||||||
StringFromFormat("%sdx11-%s-gs.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
StringFromFormat("%sdx11-%s-gs.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str());
|
SConfig::GetInstance().GetGameID().c_str());
|
||||||
GeometryShaderCacheInserter inserter;
|
GeometryShaderCacheInserter inserter;
|
||||||
g_gs_disk_cache.OpenAndRead(cache_filename, inserter);
|
g_gs_disk_cache.OpenAndRead(cache_filename, inserter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -504,7 +504,7 @@ void PixelShaderCache::Init()
|
||||||
|
|
||||||
std::string cache_filename =
|
std::string cache_filename =
|
||||||
StringFromFormat("%sdx11-%s-ps.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
StringFromFormat("%sdx11-%s-ps.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str());
|
SConfig::GetInstance().GetGameID().c_str());
|
||||||
PixelShaderCacheInserter inserter;
|
PixelShaderCacheInserter inserter;
|
||||||
g_ps_disk_cache.OpenAndRead(cache_filename, inserter);
|
g_ps_disk_cache.OpenAndRead(cache_filename, inserter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -165,7 +165,7 @@ void VertexShaderCache::Init()
|
||||||
|
|
||||||
std::string cache_filename =
|
std::string cache_filename =
|
||||||
StringFromFormat("%sdx11-%s-vs.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
StringFromFormat("%sdx11-%s-vs.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str());
|
SConfig::GetInstance().GetGameID().c_str());
|
||||||
VertexShaderCacheInserter inserter;
|
VertexShaderCacheInserter inserter;
|
||||||
g_vs_disk_cache.OpenAndRead(cache_filename, inserter);
|
g_vs_disk_cache.OpenAndRead(cache_filename, inserter);
|
||||||
}
|
}
|
||||||
|
|
|
@ -143,7 +143,7 @@ void StateCache::Init()
|
||||||
|
|
||||||
std::string cache_filename =
|
std::string cache_filename =
|
||||||
StringFromFormat("%sdx12-%s-pso.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
StringFromFormat("%sdx12-%s-pso.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str());
|
SConfig::GetInstance().GetGameID().c_str());
|
||||||
|
|
||||||
PipelineStateCacheInserter inserter;
|
PipelineStateCacheInserter inserter;
|
||||||
s_pso_disk_cache.OpenAndRead(cache_filename, inserter);
|
s_pso_disk_cache.OpenAndRead(cache_filename, inserter);
|
||||||
|
|
|
@ -77,7 +77,7 @@ void ShaderCache::Init()
|
||||||
if (!File::Exists(shader_cache_path))
|
if (!File::Exists(shader_cache_path))
|
||||||
File::CreateDir(File::GetUserPath(D_SHADERCACHE_IDX));
|
File::CreateDir(File::GetUserPath(D_SHADERCACHE_IDX));
|
||||||
|
|
||||||
std::string title_game_id = SConfig::GetInstance().m_strGameID.c_str();
|
const std::string& title_game_id = SConfig::GetInstance().GetGameID();
|
||||||
|
|
||||||
std::string gs_cache_filename =
|
std::string gs_cache_filename =
|
||||||
StringFromFormat("%sdx11-%s-gs.cache", shader_cache_path.c_str(), title_game_id.c_str());
|
StringFromFormat("%sdx11-%s-gs.cache", shader_cache_path.c_str(), title_game_id.c_str());
|
||||||
|
|
|
@ -437,7 +437,7 @@ void ProgramShaderCache::Init()
|
||||||
|
|
||||||
std::string cache_filename =
|
std::string cache_filename =
|
||||||
StringFromFormat("%sogl-%s-shaders.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
StringFromFormat("%sogl-%s-shaders.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str());
|
SConfig::GetInstance().GetGameID().c_str());
|
||||||
|
|
||||||
ProgramShaderCacheInserter inserter;
|
ProgramShaderCacheInserter inserter;
|
||||||
g_program_disk_cache.OpenAndRead(cache_filename, inserter);
|
g_program_disk_cache.OpenAndRead(cache_filename, inserter);
|
||||||
|
|
|
@ -327,7 +327,7 @@ std::pair<VkPipeline, bool> ObjectCache::GetPipelineWithCacheResult(const Pipeli
|
||||||
std::string ObjectCache::GetDiskCacheFileName(const char* type)
|
std::string ObjectCache::GetDiskCacheFileName(const char* type)
|
||||||
{
|
{
|
||||||
return StringFromFormat("%svulkan-%s-%s.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
return StringFromFormat("%svulkan-%s-%s.cache", File::GetUserPath(D_SHADERCACHE_IDX).c_str(),
|
||||||
SConfig::GetInstance().m_strGameID.c_str(), type);
|
SConfig::GetInstance().GetGameID().c_str(), type);
|
||||||
}
|
}
|
||||||
|
|
||||||
class PipelineCacheReadCallback : public LinearDiskCacheReader<u32, u8>
|
class PipelineCacheReadCallback : public LinearDiskCacheReader<u32, u8>
|
||||||
|
|
|
@ -87,7 +87,7 @@ void HiresTexture::Update()
|
||||||
s_textureCache.clear();
|
s_textureCache.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::string& game_id = SConfig::GetInstance().m_strGameID;
|
const std::string& game_id = SConfig::GetInstance().GetGameID();
|
||||||
const std::string texture_directory = GetTextureDirectory(game_id);
|
const std::string texture_directory = GetTextureDirectory(game_id);
|
||||||
std::vector<std::string> extensions{
|
std::vector<std::string> extensions{
|
||||||
".png", ".bmp", ".tga", ".dds",
|
".png", ".bmp", ".tga", ".dds",
|
||||||
|
@ -226,7 +226,7 @@ std::string HiresTexture::GenBaseName(const u8* texture, size_t texture_size, co
|
||||||
u64 tlut_hash = tlut_size ? GetHashHiresTexture(tlut, (int)tlut_size,
|
u64 tlut_hash = tlut_size ? GetHashHiresTexture(tlut, (int)tlut_size,
|
||||||
g_ActiveConfig.iSafeTextureCache_ColorSamples) :
|
g_ActiveConfig.iSafeTextureCache_ColorSamples) :
|
||||||
0;
|
0;
|
||||||
name = StringFromFormat("%s_%08x_%i", SConfig::GetInstance().m_strGameID.c_str(),
|
name = StringFromFormat("%s_%08x_%i", SConfig::GetInstance().GetGameID().c_str(),
|
||||||
(u32)(tex_hash ^ tlut_hash), (u16)format);
|
(u32)(tex_hash ^ tlut_hash), (u16)format);
|
||||||
if (s_textureMap.find(name) != s_textureMap.end())
|
if (s_textureMap.find(name) != s_textureMap.end())
|
||||||
{
|
{
|
||||||
|
|
|
@ -437,7 +437,7 @@ TextureCacheBase::DoPartialTextureUpdates(TCacheEntryBase* entry_to_update, u8*
|
||||||
|
|
||||||
void TextureCacheBase::DumpTexture(TCacheEntryBase* entry, std::string basename, unsigned int level)
|
void TextureCacheBase::DumpTexture(TCacheEntryBase* entry, std::string basename, unsigned int level)
|
||||||
{
|
{
|
||||||
std::string szDir = File::GetUserPath(D_DUMPTEXTURES_IDX) + SConfig::GetInstance().m_strGameID;
|
std::string szDir = File::GetUserPath(D_DUMPTEXTURES_IDX) + SConfig::GetInstance().GetGameID();
|
||||||
|
|
||||||
// make sure that the directory exists
|
// make sure that the directory exists
|
||||||
if (!File::Exists(szDir) || !File::IsDirectory(szDir))
|
if (!File::Exists(szDir) || !File::IsDirectory(szDir))
|
||||||
|
|
Loading…
Reference in New Issue