summaryrefslogtreecommitdiff
path: root/src/core
diff options
context:
space:
mode:
authorGravatar bunnei2015-01-06 20:13:56 -0500
committerGravatar bunnei2015-01-06 20:13:56 -0500
commit088863c9219df896b316244ad05452ef05b15ea4 (patch)
tree66892c6362d7aae93b9349285234762e4e6ee189 /src/core
parentMerge pull request #402 from chrisvj/master (diff)
parentArchives/Exdata: Don't set concrete_mount_point in the ctor (diff)
downloadyuzu-088863c9219df896b316244ad05452ef05b15ea4.tar.gz
yuzu-088863c9219df896b316244ad05452ef05b15ea4.tar.xz
yuzu-088863c9219df896b316244ad05452ef05b15ea4.zip
Merge pull request #376 from Subv/arc_reorder
Archives: Change the folder layout of some archives.
Diffstat (limited to 'src/core')
-rw-r--r--src/core/file_sys/archive_extsavedata.cpp18
-rw-r--r--src/core/file_sys/archive_extsavedata.h2
-rw-r--r--src/core/file_sys/archive_savedata.cpp18
-rw-r--r--src/core/file_sys/archive_savedatacheck.cpp15
-rw-r--r--src/core/file_sys/archive_sdmc.cpp4
-rw-r--r--src/core/file_sys/archive_systemsavedata.cpp7
-rw-r--r--src/core/file_sys/archive_systemsavedata.h2
-rw-r--r--src/core/hle/service/cfg/cfg.cpp4
-rw-r--r--src/core/hle/service/fs/archive.cpp26
-rw-r--r--src/core/hle/service/fs/archive.h5
-rw-r--r--src/core/hle/service/ptm_u.cpp6
11 files changed, 73 insertions, 34 deletions
diff --git a/src/core/file_sys/archive_extsavedata.cpp b/src/core/file_sys/archive_extsavedata.cpp
index 4759ef3ae..0805f42ae 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////////////////////////////////////////////////////////////////////////////////////////////////////
@@ -19,15 +20,22 @@ namespace FileSys {
19static std::string GetExtSaveDataPath(const std::string& mount_point, const Path& path) { 20static std::string GetExtSaveDataPath(const std::string& mount_point, const Path& path) {
20 std::vector<u8> vec_data = path.AsBinary(); 21 std::vector<u8> vec_data = path.AsBinary();
21 const u32* data = reinterpret_cast<const u32*>(vec_data.data()); 22 const u32* data = reinterpret_cast<const u32*>(vec_data.data());
22 u32 media_type = data[0];
23 u32 save_low = data[1]; 23 u32 save_low = data[1];
24 u32 save_high = data[2]; 24 u32 save_high = data[2];
25 return Common::StringFromFormat("%s%s/%08X/%08X/", mount_point.c_str(), media_type == 0 ? "nand" : "sdmc", save_high, save_low); 25 return Common::StringFromFormat("%s%08X/%08X/", mount_point.c_str(), save_high, save_low);
26} 26}
27 27
28Archive_ExtSaveData::Archive_ExtSaveData(const std::string& mount_point) 28static std::string GetExtDataContainerPath(const std::string& mount_point, bool shared) {
29 : DiskArchive(mount_point), concrete_mount_point(mount_point) { 29 if (shared)
30 LOG_INFO(Service_FS, "Directory %s set as base for ExtSaveData.", this->mount_point.c_str()); 30 return Common::StringFromFormat("%sdata/%s/extdata/", mount_point.c_str(), SYSTEM_ID.c_str());
31
32 return Common::StringFromFormat("%sNintendo 3DS/%s/%s/extdata/", mount_point.c_str(),
33 SYSTEM_ID.c_str(), SDCARD_ID.c_str());
34}
35
36Archive_ExtSaveData::Archive_ExtSaveData(const std::string& mount_location, bool shared)
37 : DiskArchive(GetExtDataContainerPath(mount_location, shared)) {
38 LOG_INFO(Service_FS, "Directory %s set as base for ExtSaveData.", mount_point.c_str());
31} 39}
32 40
33bool Archive_ExtSaveData::Initialize() { 41bool 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..3baee5294 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,25 @@
16 17
17namespace FileSys { 18namespace FileSys {
18 19
19Archive_SaveData::Archive_SaveData(const std::string& mount_point) 20static std::string GetSaveDataContainerPath(const std::string& sdmc_directory) {
20 : DiskArchive(mount_point) { 21 return Common::StringFromFormat("%sNintendo 3DS/%s/%s/title/", sdmc_directory.c_str(),
22 SYSTEM_ID.c_str(), SDCARD_ID.c_str());
23}
24
25static std::string GetSaveDataPath(const std::string& mount_location, u64 program_id) {
26 u32 high = program_id >> 32;
27 u32 low = program_id & 0xFFFFFFFF;
28 return Common::StringFromFormat("%s%08x/%08x/data/00000001/", mount_location.c_str(), high, low);
29}
30
31Archive_SaveData::Archive_SaveData(const std::string& sdmc_directory)
32 : DiskArchive(GetSaveDataContainerPath(sdmc_directory)) {
21 LOG_INFO(Service_FS, "Directory %s set as SaveData.", this->mount_point.c_str()); 33 LOG_INFO(Service_FS, "Directory %s set as SaveData.", this->mount_point.c_str());
22} 34}
23 35
24ResultCode Archive_SaveData::Open(const Path& path) { 36ResultCode Archive_SaveData::Open(const Path& path) {
25 if (concrete_mount_point.empty()) 37 if (concrete_mount_point.empty())
26 concrete_mount_point = Common::StringFromFormat("%s%016X", mount_point.c_str(), Kernel::g_program_id) + DIR_SEP; 38 concrete_mount_point = GetSaveDataPath(mount_point, Kernel::g_program_id);
27 if (!FileUtil::Exists(concrete_mount_point)) { 39 if (!FileUtil::Exists(concrete_mount_point)) {
28 // When a SaveData archive is created for the first time, it is not yet formatted 40 // 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. 41 // 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 233158a0c..a7a507536 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& nand_directory) {
16 return Common::StringFromFormat("%s%s/title/", nand_directory.c_str(), SYSTEM_ID.c_str());
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& nand_directory) :
25 mount_point(GetSaveDataCheckContainerPath(nand_directory)) {
15} 26}
16 27
17ResultCode Archive_SaveDataCheck::Open(const Path& path) { 28ResultCode Archive_SaveDataCheck::Open(const Path& path) {
@@ -23,7 +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.bin", mount_point.c_str(), data[1], data[0]); 37 std::string file_path = GetSaveDataCheckPath(mount_point, data[1], data[0]);
27 FileUtil::IOFile file(file_path, "rb"); 38 FileUtil::IOFile file(file_path, "rb");
28 39
29 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_sdmc.cpp b/src/core/file_sys/archive_sdmc.cpp
index 1c1c170b6..26b03e82f 100644
--- a/src/core/file_sys/archive_sdmc.cpp
+++ b/src/core/file_sys/archive_sdmc.cpp
@@ -16,8 +16,8 @@
16 16
17namespace FileSys { 17namespace FileSys {
18 18
19Archive_SDMC::Archive_SDMC(const std::string& mount_point) : DiskArchive(mount_point) { 19Archive_SDMC::Archive_SDMC(const std::string& sdmc_directory) : DiskArchive(sdmc_directory) {
20 LOG_INFO(Service_FS, "Directory %s set as SDMC.", mount_point.c_str()); 20 LOG_INFO(Service_FS, "Directory %s set as SDMC.", sdmc_directory.c_str());
21} 21}
22 22
23bool Archive_SDMC::Initialize() { 23bool Archive_SDMC::Initialize() {
diff --git a/src/core/file_sys/archive_systemsavedata.cpp b/src/core/file_sys/archive_systemsavedata.cpp
index 0da32d510..c2a5d641a 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/%s/sysdata/", mount_point.c_str(), SYSTEM_ID.c_str());
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);
diff --git a/src/core/hle/service/cfg/cfg.cpp b/src/core/hle/service/cfg/cfg.cpp
index 161aa8531..8812c49ef 100644
--- a/src/core/hle/service/cfg/cfg.cpp
+++ b/src/core/hle/service/cfg/cfg.cpp
@@ -161,9 +161,9 @@ ResultCode FormatConfig() {
161void CFGInit() { 161void CFGInit() {
162 // TODO(Subv): In the future we should use the FS service to query this archive, 162 // TODO(Subv): In the future we should use the FS service to query this archive,
163 // currently it is not possible because you can only have one open archive of the same type at any time 163 // currently it is not possible because you can only have one open archive of the same type at any time
164 std::string syssavedata_directory = FileUtil::GetUserPath(D_SYSSAVEDATA_IDX); 164 std::string nand_directory = FileUtil::GetUserPath(D_NAND_IDX);
165 cfg_system_save_data = Common::make_unique<FileSys::Archive_SystemSaveData>( 165 cfg_system_save_data = Common::make_unique<FileSys::Archive_SystemSaveData>(
166 syssavedata_directory, CFG_SAVE_ID); 166 nand_directory, CFG_SAVE_ID);
167 if (!cfg_system_save_data->Initialize()) { 167 if (!cfg_system_save_data->Initialize()) {
168 LOG_CRITICAL(Service_CFG, "Could not initialize SystemSaveData archive for the CFG:U service"); 168 LOG_CRITICAL(Service_CFG, "Could not initialize SystemSaveData archive for the CFG:U service");
169 return; 169 return;
diff --git a/src/core/hle/service/fs/archive.cpp b/src/core/hle/service/fs/archive.cpp
index f761c6ab9..958dd9344 100644
--- a/src/core/hle/service/fs/archive.cpp
+++ b/src/core/hle/service/fs/archive.cpp
@@ -36,6 +36,10 @@ namespace std {
36 }; 36 };
37} 37}
38 38
39/// TODO(Subv): Confirm length of these strings
40const std::string SYSTEM_ID = "00000000000000000000000000000000";
41const std::string SDCARD_ID = "00000000000000000000000000000000";
42
39namespace Service { 43namespace Service {
40namespace FS { 44namespace FS {
41 45
@@ -432,11 +436,11 @@ ResultCode FormatSaveData() {
432void ArchiveInit() { 436void ArchiveInit() {
433 next_handle = 1; 437 next_handle = 1;
434 438
435 // TODO(Link Mauve): Add the other archive types (see here for the known types: 439 // TODO(Subv): Add the other archive types (see here for the known types:
436 // http://3dbrew.org/wiki/FS:OpenArchive#Archive_idcodes). Currently the only half-finished 440 // http://3dbrew.org/wiki/FS:OpenArchive#Archive_idcodes).
437 // archive type is SDMC, so it is the only one getting exposed.
438 441
439 std::string sdmc_directory = FileUtil::GetUserPath(D_SDMC_IDX); 442 std::string sdmc_directory = FileUtil::GetUserPath(D_SDMC_IDX);
443 std::string nand_directory = FileUtil::GetUserPath(D_NAND_IDX);
440 auto sdmc_archive = Common::make_unique<FileSys::Archive_SDMC>(sdmc_directory); 444 auto sdmc_archive = Common::make_unique<FileSys::Archive_SDMC>(sdmc_directory);
441 if (sdmc_archive->Initialize()) 445 if (sdmc_archive->Initialize())
442 CreateArchive(std::move(sdmc_archive), ArchiveIdCode::SDMC); 446 CreateArchive(std::move(sdmc_archive), ArchiveIdCode::SDMC);
@@ -444,28 +448,24 @@ void ArchiveInit() {
444 LOG_ERROR(Service_FS, "Can't instantiate SDMC archive with path %s", sdmc_directory.c_str()); 448 LOG_ERROR(Service_FS, "Can't instantiate SDMC archive with path %s", sdmc_directory.c_str());
445 449
446 // Create the SaveData archive 450 // Create the SaveData archive
447 std::string savedata_directory = FileUtil::GetUserPath(D_SAVEDATA_IDX); 451 auto savedata_archive = Common::make_unique<FileSys::Archive_SaveData>(sdmc_directory);
448 auto savedata_archive = Common::make_unique<FileSys::Archive_SaveData>(savedata_directory);
449 CreateArchive(std::move(savedata_archive), ArchiveIdCode::SaveData); 452 CreateArchive(std::move(savedata_archive), ArchiveIdCode::SaveData);
450 453
451 std::string extsavedata_directory = FileUtil::GetUserPath(D_EXTSAVEDATA); 454 auto extsavedata_archive = Common::make_unique<FileSys::Archive_ExtSaveData>(sdmc_directory, false);
452 auto extsavedata_archive = Common::make_unique<FileSys::Archive_ExtSaveData>(extsavedata_directory);
453 if (extsavedata_archive->Initialize()) 455 if (extsavedata_archive->Initialize())
454 CreateArchive(std::move(extsavedata_archive), ArchiveIdCode::ExtSaveData); 456 CreateArchive(std::move(extsavedata_archive), ArchiveIdCode::ExtSaveData);
455 else 457 else
456 LOG_ERROR(Service_FS, "Can't instantiate ExtSaveData archive with path %s", extsavedata_directory.c_str()); 458 LOG_ERROR(Service_FS, "Can't instantiate ExtSaveData archive with path %s", extsavedata_archive->GetMountPoint().c_str());
457 459
458 std::string sharedextsavedata_directory = FileUtil::GetUserPath(D_EXTSAVEDATA); 460 auto sharedextsavedata_archive = Common::make_unique<FileSys::Archive_ExtSaveData>(nand_directory, true);
459 auto sharedextsavedata_archive = Common::make_unique<FileSys::Archive_ExtSaveData>(sharedextsavedata_directory);
460 if (sharedextsavedata_archive->Initialize()) 461 if (sharedextsavedata_archive->Initialize())
461 CreateArchive(std::move(sharedextsavedata_archive), ArchiveIdCode::SharedExtSaveData); 462 CreateArchive(std::move(sharedextsavedata_archive), ArchiveIdCode::SharedExtSaveData);
462 else 463 else
463 LOG_ERROR(Service_FS, "Can't instantiate SharedExtSaveData archive with path %s", 464 LOG_ERROR(Service_FS, "Can't instantiate SharedExtSaveData archive with path %s",
464 sharedextsavedata_directory.c_str()); 465 sharedextsavedata_archive->GetMountPoint().c_str());
465 466
466 // Create the SaveDataCheck archive, basically a small variation of the RomFS archive 467 // Create the SaveDataCheck archive, basically a small variation of the RomFS archive
467 std::string savedatacheck_directory = FileUtil::GetUserPath(D_SAVEDATACHECK_IDX); 468 auto savedatacheck_archive = Common::make_unique<FileSys::Archive_SaveDataCheck>(nand_directory);
468 auto savedatacheck_archive = Common::make_unique<FileSys::Archive_SaveDataCheck>(savedatacheck_directory);
469 CreateArchive(std::move(savedatacheck_archive), ArchiveIdCode::SaveDataCheck); 469 CreateArchive(std::move(savedatacheck_archive), ArchiveIdCode::SaveDataCheck);
470} 470}
471 471
diff --git a/src/core/hle/service/fs/archive.h b/src/core/hle/service/fs/archive.h
index 9e9efa019..b3f2134f2 100644
--- a/src/core/hle/service/fs/archive.h
+++ b/src/core/hle/service/fs/archive.h
@@ -10,6 +10,11 @@
10#include "core/hle/kernel/kernel.h" 10#include "core/hle/kernel/kernel.h"
11#include "core/hle/result.h" 11#include "core/hle/result.h"
12 12
13/// The unique system identifier hash, also known as ID0
14extern const std::string SYSTEM_ID;
15/// The scrambled SD card CID, also known as ID1
16extern const std::string SDCARD_ID;
17
13namespace Service { 18namespace Service {
14namespace FS { 19namespace FS {
15 20
diff --git a/src/core/hle/service/ptm_u.cpp b/src/core/hle/service/ptm_u.cpp
index 9cc700c46..fd79cd8ab 100644
--- a/src/core/hle/service/ptm_u.cpp
+++ b/src/core/hle/service/ptm_u.cpp
@@ -142,10 +142,10 @@ Interface::Interface() {
142 Register(FunctionTable, ARRAY_SIZE(FunctionTable)); 142 Register(FunctionTable, ARRAY_SIZE(FunctionTable));
143 // Create the SharedExtSaveData archive 0xF000000B and the gamecoin.dat file 143 // Create the SharedExtSaveData archive 0xF000000B and the gamecoin.dat file
144 // TODO(Subv): In the future we should use the FS service to query this archive 144 // TODO(Subv): In the future we should use the FS service to query this archive
145 std::string extsavedata_directory = FileUtil::GetUserPath(D_EXTSAVEDATA); 145 std::string nand_directory = FileUtil::GetUserPath(D_NAND_IDX);
146 ptm_shared_extsavedata = Common::make_unique<FileSys::Archive_ExtSaveData>(extsavedata_directory); 146 ptm_shared_extsavedata = Common::make_unique<FileSys::Archive_ExtSaveData>(nand_directory, true);
147 if (!ptm_shared_extsavedata->Initialize()) { 147 if (!ptm_shared_extsavedata->Initialize()) {
148 LOG_CRITICAL(Service_PTM, "Could not initialize ExtSaveData archive for the PTM:U service"); 148 LOG_CRITICAL(Service_PTM, "Could not initialize SharedExtSaveData archive for the PTM:U service");
149 return; 149 return;
150 } 150 }
151 FileSys::Path archive_path(ptm_shared_extdata_id); 151 FileSys::Path archive_path(ptm_shared_extdata_id);