summaryrefslogtreecommitdiff
path: root/src/core/file_sys
diff options
context:
space:
mode:
authorGravatar Subv2015-01-03 20:46:05 -0500
committerGravatar Subv2015-01-03 20:46:05 -0500
commit71a063f45cba961ee07730f4ab79f2bcc3ff9b5b (patch)
tree3c134bc71fd404b33a6d6fcaed743457d7fb7e66 /src/core/file_sys
parentSaveDataCheck: Move the files to nand/title (diff)
downloadyuzu-71a063f45cba961ee07730f4ab79f2bcc3ff9b5b.tar.gz
yuzu-71a063f45cba961ee07730f4ab79f2bcc3ff9b5b.tar.xz
yuzu-71a063f45cba961ee07730f4ab79f2bcc3ff9b5b.zip
Archives: Changed the way paths are built for the archives.
Each archive now takes a mount point of either NAND or SDMC, and builds its own directory structure there, trying to simulate an HLE-friendly hardware layout
Diffstat (limited to 'src/core/file_sys')
-rw-r--r--src/core/file_sys/archive_extsavedata.cpp14
-rw-r--r--src/core/file_sys/archive_extsavedata.h2
-rw-r--r--src/core/file_sys/archive_savedata.cpp15
-rw-r--r--src/core/file_sys/archive_savedatacheck.cpp16
-rw-r--r--src/core/file_sys/archive_systemsavedata.cpp7
-rw-r--r--src/core/file_sys/archive_systemsavedata.h2
6 files changed, 44 insertions, 12 deletions
diff --git a/src/core/file_sys/archive_extsavedata.cpp b/src/core/file_sys/archive_extsavedata.cpp
index 2f00bf067..5de2aae43 100644
--- a/src/core/file_sys/archive_extsavedata.cpp
+++ b/src/core/file_sys/archive_extsavedata.cpp
@@ -9,6 +9,7 @@
9 9
10#include "core/file_sys/archive_extsavedata.h" 10#include "core/file_sys/archive_extsavedata.h"
11#include "core/file_sys/disk_archive.h" 11#include "core/file_sys/disk_archive.h"
12#include "core/hle/service/fs/archive.h"
12#include "core/settings.h" 13#include "core/settings.h"
13 14
14//////////////////////////////////////////////////////////////////////////////////////////////////// 15////////////////////////////////////////////////////////////////////////////////////////////////////
@@ -24,9 +25,16 @@ static std::string GetExtSaveDataPath(const std::string& mount_point, const Path
24 return Common::StringFromFormat("%s%08X/%08X/", mount_point.c_str(), save_high, save_low); 25 return Common::StringFromFormat("%s%08X/%08X/", mount_point.c_str(), save_high, save_low);
25} 26}
26 27
27Archive_ExtSaveData::Archive_ExtSaveData(const std::string& mount_point) 28static std::string GetExtDataContainerPath(const std::string& mount_point, bool shared) {
28 : DiskArchive(mount_point), concrete_mount_point(mount_point) { 29 if (shared)
29 LOG_INFO(Service_FS, "Directory %s set as base for ExtSaveData.", this->mount_point.c_str()); 30 return Common::StringFromFormat("%sdata/%32x/extdata/", mount_point.c_str(), ID0);
31
32 return Common::StringFromFormat("%sNintendo 3DS/%32x/%32x/extdata/", mount_point.c_str(), ID0, ID1);
33}
34
35Archive_ExtSaveData::Archive_ExtSaveData(const std::string& mount_location, bool shared)
36 : DiskArchive(GetExtDataContainerPath(mount_location, shared)), concrete_mount_point(mount_point) {
37 LOG_INFO(Service_FS, "Directory %s set as base for ExtSaveData.", mount_point.c_str());
30} 38}
31 39
32bool Archive_ExtSaveData::Initialize() { 40bool Archive_ExtSaveData::Initialize() {
diff --git a/src/core/file_sys/archive_extsavedata.h b/src/core/file_sys/archive_extsavedata.h
index a3a144799..fb7f209d2 100644
--- a/src/core/file_sys/archive_extsavedata.h
+++ b/src/core/file_sys/archive_extsavedata.h
@@ -17,7 +17,7 @@ namespace FileSys {
17/// File system interface to the ExtSaveData archive 17/// File system interface to the ExtSaveData archive
18class Archive_ExtSaveData final : public DiskArchive { 18class Archive_ExtSaveData final : public DiskArchive {
19public: 19public:
20 Archive_ExtSaveData(const std::string& mount_point); 20 Archive_ExtSaveData(const std::string& mount_point, bool shared);
21 21
22 /** 22 /**
23 * Initialize the archive. 23 * Initialize the archive.
diff --git a/src/core/file_sys/archive_savedata.cpp b/src/core/file_sys/archive_savedata.cpp
index 280d4ff5d..f189692fa 100644
--- a/src/core/file_sys/archive_savedata.cpp
+++ b/src/core/file_sys/archive_savedata.cpp
@@ -9,6 +9,7 @@
9 9
10#include "core/file_sys/archive_savedata.h" 10#include "core/file_sys/archive_savedata.h"
11#include "core/file_sys/disk_archive.h" 11#include "core/file_sys/disk_archive.h"
12#include "core/hle/service/fs/archive.h"
12#include "core/settings.h" 13#include "core/settings.h"
13 14
14//////////////////////////////////////////////////////////////////////////////////////////////////// 15////////////////////////////////////////////////////////////////////////////////////////////////////
@@ -16,14 +17,24 @@
16 17
17namespace FileSys { 18namespace FileSys {
18 19
20static std::string GetSaveDataContainerPath(const std::string& mount_point) {
21 return Common::StringFromFormat("%sNintendo 3DS/%32x/%32x/title/", mount_point.c_str(), ID0, ID1);
22}
23
24static std::string GetSaveDataPath(const std::string& mount_point, u64 program_id) {
25 u32 high = program_id >> 32;
26 u32 low = program_id & 0xFFFFFFFF;
27 return Common::StringFromFormat("%s%08x/%08x/data/00000001/", mount_point.c_str(), high, low);
28}
29
19Archive_SaveData::Archive_SaveData(const std::string& mount_point) 30Archive_SaveData::Archive_SaveData(const std::string& mount_point)
20 : DiskArchive(mount_point) { 31 : DiskArchive(GetSaveDataContainerPath(mount_point)) {
21 LOG_INFO(Service_FS, "Directory %s set as SaveData.", this->mount_point.c_str()); 32 LOG_INFO(Service_FS, "Directory %s set as SaveData.", this->mount_point.c_str());
22} 33}
23 34
24ResultCode Archive_SaveData::Open(const Path& path) { 35ResultCode Archive_SaveData::Open(const Path& path) {
25 if (concrete_mount_point.empty()) 36 if (concrete_mount_point.empty())
26 concrete_mount_point = Common::StringFromFormat("%s%016X", mount_point.c_str(), Kernel::g_program_id) + DIR_SEP; 37 concrete_mount_point = GetSaveDataPath(mount_point, Kernel::g_program_id);
27 if (!FileUtil::Exists(concrete_mount_point)) { 38 if (!FileUtil::Exists(concrete_mount_point)) {
28 // When a SaveData archive is created for the first time, it is not yet formatted 39 // When a SaveData archive is created for the first time, it is not yet formatted
29 // and the save file/directory structure expected by the game has not yet been initialized. 40 // and the save file/directory structure expected by the game has not yet been initialized.
diff --git a/src/core/file_sys/archive_savedatacheck.cpp b/src/core/file_sys/archive_savedatacheck.cpp
index 1b1e01c6e..dcd563773 100644
--- a/src/core/file_sys/archive_savedatacheck.cpp
+++ b/src/core/file_sys/archive_savedatacheck.cpp
@@ -5,13 +5,24 @@
5#include "common/file_util.h" 5#include "common/file_util.h"
6 6
7#include "core/file_sys/archive_savedatacheck.h" 7#include "core/file_sys/archive_savedatacheck.h"
8#include "core/hle/service/fs/archive.h"
8 9
9//////////////////////////////////////////////////////////////////////////////////////////////////// 10////////////////////////////////////////////////////////////////////////////////////////////////////
10// FileSys namespace 11// FileSys namespace
11 12
12namespace FileSys { 13namespace FileSys {
13 14
14Archive_SaveDataCheck::Archive_SaveDataCheck(const std::string& mount_loc) : mount_point(mount_loc) { 15static std::string GetSaveDataCheckContainerPath(const std::string& mount_point) {
16 return Common::StringFromFormat("%stitle/", mount_point.c_str(), ID0);
17}
18
19static std::string GetSaveDataCheckPath(const std::string& mount_point, u32 high, u32 low) {
20 return Common::StringFromFormat("%s%08x/%08x/content/00000000.app.romfs",
21 mount_point.c_str(), high, low);
22}
23
24Archive_SaveDataCheck::Archive_SaveDataCheck(const std::string& mount_loc) :
25mount_point(GetSaveDataCheckContainerPath(mount_loc)) {
15} 26}
16 27
17ResultCode Archive_SaveDataCheck::Open(const Path& path) { 28ResultCode Archive_SaveDataCheck::Open(const Path& path) {
@@ -23,8 +34,7 @@ ResultCode Archive_SaveDataCheck::Open(const Path& path) {
23 // this archive again with a different path, will corrupt the previously open file. 34 // this archive again with a different path, will corrupt the previously open file.
24 auto vec = path.AsBinary(); 35 auto vec = path.AsBinary();
25 const u32* data = reinterpret_cast<u32*>(vec.data()); 36 const u32* data = reinterpret_cast<u32*>(vec.data());
26 std::string file_path = Common::StringFromFormat("%s%08x/%08x/content/00000000.app.romfs", 37 std::string file_path = GetSaveDataCheckPath(mount_point, data[1], data[0]);
27 mount_point.c_str(), data[1], data[0]);
28 FileUtil::IOFile file(file_path, "rb"); 38 FileUtil::IOFile file(file_path, "rb");
29 39
30 std::fill(raw_data.begin(), raw_data.end(), 0); 40 std::fill(raw_data.begin(), raw_data.end(), 0);
diff --git a/src/core/file_sys/archive_systemsavedata.cpp b/src/core/file_sys/archive_systemsavedata.cpp
index 0da32d510..615f50e20 100644
--- a/src/core/file_sys/archive_systemsavedata.cpp
+++ b/src/core/file_sys/archive_systemsavedata.cpp
@@ -9,6 +9,7 @@
9 9
10#include "core/file_sys/archive_systemsavedata.h" 10#include "core/file_sys/archive_systemsavedata.h"
11#include "core/file_sys/disk_archive.h" 11#include "core/file_sys/disk_archive.h"
12#include "core/hle/service/fs/archive.h"
12#include "core/settings.h" 13#include "core/settings.h"
13 14
14//////////////////////////////////////////////////////////////////////////////////////////////////// 15////////////////////////////////////////////////////////////////////////////////////////////////////
@@ -22,8 +23,12 @@ static std::string GetSystemSaveDataPath(const std::string& mount_point, u64 sav
22 return Common::StringFromFormat("%s%08X/%08X/", mount_point.c_str(), save_low, save_high); 23 return Common::StringFromFormat("%s%08X/%08X/", mount_point.c_str(), save_low, save_high);
23} 24}
24 25
26static std::string GetSystemSaveDataContainerPath(const std::string& mount_point) {
27 return Common::StringFromFormat("%sdata/%32x/sysdata/", mount_point.c_str(), ID0);
28}
29
25Archive_SystemSaveData::Archive_SystemSaveData(const std::string& mount_point, u64 save_id) 30Archive_SystemSaveData::Archive_SystemSaveData(const std::string& mount_point, u64 save_id)
26 : DiskArchive(GetSystemSaveDataPath(mount_point, save_id)) { 31 : DiskArchive(GetSystemSaveDataPath(GetSystemSaveDataContainerPath(mount_point), save_id)) {
27 LOG_INFO(Service_FS, "Directory %s set as SystemSaveData.", this->mount_point.c_str()); 32 LOG_INFO(Service_FS, "Directory %s set as SystemSaveData.", this->mount_point.c_str());
28} 33}
29 34
diff --git a/src/core/file_sys/archive_systemsavedata.h b/src/core/file_sys/archive_systemsavedata.h
index 55d85193c..c8f5845ca 100644
--- a/src/core/file_sys/archive_systemsavedata.h
+++ b/src/core/file_sys/archive_systemsavedata.h
@@ -15,8 +15,6 @@
15namespace FileSys { 15namespace FileSys {
16 16
17/// File system interface to the SystemSaveData archive 17/// File system interface to the SystemSaveData archive
18/// TODO(Subv): This archive should point to a location in the NAND,
19/// specifically nand:/data/<ID0>/sysdata/<SaveID-Low>/<SaveID-High>
20class Archive_SystemSaveData final : public DiskArchive { 18class Archive_SystemSaveData final : public DiskArchive {
21public: 19public:
22 Archive_SystemSaveData(const std::string& mount_point, u64 save_id); 20 Archive_SystemSaveData(const std::string& mount_point, u64 save_id);