summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Zach Hilman2018-11-01 20:24:32 -0400
committerGravatar Zach Hilman2018-11-01 20:24:32 -0400
commit8f183a47dd3dca5247b893960afd09b6f603ae87 (patch)
tree9926868be3c0e43cc0e746dfbd0ab91426bc5c8c /src
parentfile_sys: Use common KeyManager in NCA container types (diff)
downloadyuzu-8f183a47dd3dca5247b893960afd09b6f603ae87.tar.gz
yuzu-8f183a47dd3dca5247b893960afd09b6f603ae87.tar.xz
yuzu-8f183a47dd3dca5247b893960afd09b6f603ae87.zip
filesystem: Cache RegisteredCacheUnion instead of constructing on demand
Prevents unnecessary re-reads of the metadata and unnecessary temporary objects.
Diffstat (limited to 'src')
-rw-r--r--src/core/hle/service/filesystem/filesystem.cpp13
-rw-r--r--src/core/hle/service/filesystem/filesystem.h2
2 files changed, 11 insertions, 4 deletions
diff --git a/src/core/hle/service/filesystem/filesystem.cpp b/src/core/hle/service/filesystem/filesystem.cpp
index e32a7c48e..ad865751f 100644
--- a/src/core/hle/service/filesystem/filesystem.cpp
+++ b/src/core/hle/service/filesystem/filesystem.cpp
@@ -319,9 +319,16 @@ ResultVal<FileSys::VirtualDir> OpenSDMC() {
319 return sdmc_factory->Open(); 319 return sdmc_factory->Open();
320} 320}
321 321
322std::unique_ptr<FileSys::RegisteredCacheUnion> GetUnionContents() { 322std::shared_ptr<FileSys::RegisteredCacheUnion> registered_cache_union;
323 return std::make_unique<FileSys::RegisteredCacheUnion>(std::vector<FileSys::RegisteredCache*>{ 323
324 GetSystemNANDContents(), GetUserNANDContents(), GetSDMCContents()}); 324std::shared_ptr<FileSys::RegisteredCacheUnion> GetUnionContents() {
325 if (registered_cache_union == nullptr) {
326 registered_cache_union =
327 std::make_shared<FileSys::RegisteredCacheUnion>(std::vector<FileSys::RegisteredCache*>{
328 GetSystemNANDContents(), GetUserNANDContents(), GetSDMCContents()});
329 }
330
331 return registered_cache_union;
325} 332}
326 333
327FileSys::RegisteredCache* GetSystemNANDContents() { 334FileSys::RegisteredCache* GetSystemNANDContents() {
diff --git a/src/core/hle/service/filesystem/filesystem.h b/src/core/hle/service/filesystem/filesystem.h
index 6ca5c5636..6f3e0cd03 100644
--- a/src/core/hle/service/filesystem/filesystem.h
+++ b/src/core/hle/service/filesystem/filesystem.h
@@ -47,7 +47,7 @@ ResultVal<FileSys::VirtualDir> OpenSaveData(FileSys::SaveDataSpaceId space,
47 FileSys::SaveDataDescriptor save_struct); 47 FileSys::SaveDataDescriptor save_struct);
48ResultVal<FileSys::VirtualDir> OpenSDMC(); 48ResultVal<FileSys::VirtualDir> OpenSDMC();
49 49
50std::unique_ptr<FileSys::RegisteredCacheUnion> GetUnionContents(); 50std::shared_ptr<FileSys::RegisteredCacheUnion> GetUnionContents();
51 51
52FileSys::RegisteredCache* GetSystemNANDContents(); 52FileSys::RegisteredCache* GetSystemNANDContents();
53FileSys::RegisteredCache* GetUserNANDContents(); 53FileSys::RegisteredCache* GetUserNANDContents();