From e1716fc53c96419183b2d0581d0c8b6febee6784 Mon Sep 17 00:00:00 2001 From: emoose Date: Thu, 26 Dec 2019 02:48:31 +0000 Subject: [PATCH] [XAM/User] Store profile inside content root instead of next to EXE eg. Documents/Xenia/content/profile/ --- src/xenia/kernel/kernel_state.cc | 2 +- src/xenia/kernel/xam/user_profile.cc | 41 ++++++++++++---------------- src/xenia/kernel/xam/user_profile.h | 9 +++++- 3 files changed, 27 insertions(+), 25 deletions(-) diff --git a/src/xenia/kernel/kernel_state.cc b/src/xenia/kernel/kernel_state.cc index 0d9f3f354..1620a941b 100644 --- a/src/xenia/kernel/kernel_state.cc +++ b/src/xenia/kernel/kernel_state.cc @@ -48,7 +48,7 @@ KernelState::KernelState(Emulator* emulator) file_system_ = emulator->file_system(); app_manager_ = std::make_unique(); - user_profile_ = std::make_unique(); + user_profile_ = std::make_unique(this); auto content_root = emulator_->content_root(); content_root = xe::to_absolute_path(content_root); diff --git a/src/xenia/kernel/xam/user_profile.cc b/src/xenia/kernel/xam/user_profile.cc index 5bb065643..d82d8b722 100644 --- a/src/xenia/kernel/xam/user_profile.cc +++ b/src/xenia/kernel/xam/user_profile.cc @@ -7,6 +7,8 @@ ****************************************************************************** */ +#include "xenia/kernel/xam/user_profile.h" + #include #include "xenia/base/clock.h" @@ -14,16 +16,13 @@ #include "xenia/base/filesystem.h" #include "xenia/base/logging.h" #include "xenia/base/mapped_memory.h" +#include "xenia/emulator.h" #include "xenia/kernel/kernel_state.h" #include "xenia/kernel/util/crypto_utils.h" #include "xenia/kernel/util/shim_utils.h" -#include "xenia/kernel/xam/user_profile.h" DECLARE_int32(license_mask); -DEFINE_string(profile_directory, "Content\\Profile\\", - "The directory to store profile data inside", "Kernel"); - namespace xe { namespace kernel { namespace xam { @@ -33,7 +32,8 @@ std::string X_XAMACCOUNTINFO::GetGamertagString() const { } std::wstring UserProfile::directory() const { - return xe::to_wstring(cvars::profile_directory); + return xe::to_absolute_path(kernel_state_->emulator()->content_root() + + L"\\profile\\"); } bool UserProfile::DecryptAccountFile(const uint8_t* data, @@ -106,7 +106,8 @@ void UserProfile::EncryptAccountFile(const X_XAMACCOUNTINFO* input, enc_data_size); } -UserProfile::UserProfile() : dash_gpd_(kDashboardID) { +UserProfile::UserProfile(KernelState* kernel_state) + : kernel_state_(kernel_state), dash_gpd_(kDashboardID) { account_.xuid_online = 0xE000BABEBABEBABE; wcscpy(account_.gamertag, L"XeniaUser"); @@ -116,11 +117,9 @@ UserProfile::UserProfile() : dash_gpd_(kDashboardID) { void UserProfile::LoadProfile() { auto mmap_ = - MappedMemory::Open(xe::to_wstring(cvars::profile_directory) + L"Account", - MappedMemory::Mode::kRead); + MappedMemory::Open(directory() + L"Account", MappedMemory::Mode::kRead); if (mmap_) { - XELOGI("Loading Account file from path %SAccount", - xe::to_wstring(cvars::profile_directory).c_str()); + XELOGI("Loading Account file from path %SAccount", directory().c_str()); X_XAMACCOUNTINFO tmp_acct; bool success = DecryptAccountFile(mmap_->data(), &tmp_acct); @@ -138,12 +137,10 @@ void UserProfile::LoadProfile() { mmap_->Close(); } - XELOGI("Loading profile GPDs from path %S", - xe::to_wstring(cvars::profile_directory).c_str()); + XELOGI("Loading profile GPDs from path %S", directory().c_str()); - mmap_ = MappedMemory::Open( - xe::to_wstring(cvars::profile_directory) + L"FFFE07D1.gpd", - MappedMemory::Mode::kRead); + mmap_ = MappedMemory::Open(directory() + L"FFFE07D1.gpd", + MappedMemory::Mode::kRead); if (mmap_) { dash_gpd_.Read(mmap_->data(), mmap_->size()); mmap_->Close(); @@ -232,8 +229,7 @@ void UserProfile::LoadProfile() { for (auto title : titles) { wchar_t fname[256]; swprintf(fname, 256, L"%X.gpd", title.title_id); - mmap_ = MappedMemory::Open(xe::to_wstring(cvars::profile_directory) + fname, - MappedMemory::Mode::kRead); + mmap_ = MappedMemory::Open(directory() + fname, MappedMemory::Mode::kRead); if (!mmap_) { XELOGE("Failed to open GPD for title %X (%s)!", title.title_id, xe::to_string(title.title_name).c_str()); @@ -539,17 +535,16 @@ bool UserProfile::UpdateGpd(uint32_t title_id, xdbf::GpdFile& gpd_data) { return false; } - if (!filesystem::PathExists(xe::to_wstring(cvars::profile_directory))) { - filesystem::CreateFolder(xe::to_wstring(cvars::profile_directory)); + if (!filesystem::PathExists(directory())) { + filesystem::CreateFolder(directory()); } wchar_t fname[256]; swprintf(fname, 256, L"%X.gpd", title_id); - filesystem::CreateFile(xe::to_wstring(cvars::profile_directory) + fname); - auto mmap_ = - MappedMemory::Open(xe::to_wstring(cvars::profile_directory) + fname, - MappedMemory::Mode::kReadWrite, 0, gpd_length); + filesystem::CreateFile(directory() + fname); + auto mmap_ = MappedMemory::Open( + directory() + fname, MappedMemory::Mode::kReadWrite, 0, gpd_length); if (!mmap_) { XELOGE("Failed to open %X.gpd for writing!", title_id); return false; diff --git a/src/xenia/kernel/xam/user_profile.h b/src/xenia/kernel/xam/user_profile.h index 1812de151..04f0726a3 100644 --- a/src/xenia/kernel/xam/user_profile.h +++ b/src/xenia/kernel/xam/user_profile.h @@ -18,6 +18,11 @@ #include "xenia/kernel/xam/xdbf/xdbf.h" #include "xenia/xbox.h" +namespace xe { +namespace kernel { +class KernelState; +} // namespace kernel +} // namespace xe namespace xe { namespace kernel { @@ -166,7 +171,7 @@ class UserProfile { static void EncryptAccountFile(const X_XAMACCOUNTINFO* input, uint8_t* output, bool devkit = false); - UserProfile(); + UserProfile(KernelState* kernel_state); uint64_t xuid() const { return account_.xuid_online; } std::string name() const { return account_.GetGamertagString(); } @@ -188,6 +193,8 @@ class UserProfile { bool AddSettingIfNotExist(xdbf::Setting& setting); + KernelState* kernel_state_; + X_XAMACCOUNTINFO account_; std::unordered_map title_gpds_;