diff options
| author | 2018-11-01 20:24:32 -0400 | |
|---|---|---|
| committer | 2018-11-01 20:24:32 -0400 | |
| commit | 8f183a47dd3dca5247b893960afd09b6f603ae87 (patch) | |
| tree | 9926868be3c0e43cc0e746dfbd0ab91426bc5c8c /src | |
| parent | file_sys: Use common KeyManager in NCA container types (diff) | |
| download | yuzu-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.cpp | 13 | ||||
| -rw-r--r-- | src/core/hle/service/filesystem/filesystem.h | 2 |
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 | ||
| 322 | std::unique_ptr<FileSys::RegisteredCacheUnion> GetUnionContents() { | 322 | std::shared_ptr<FileSys::RegisteredCacheUnion> registered_cache_union; |
| 323 | return std::make_unique<FileSys::RegisteredCacheUnion>(std::vector<FileSys::RegisteredCache*>{ | 323 | |
| 324 | GetSystemNANDContents(), GetUserNANDContents(), GetSDMCContents()}); | 324 | std::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 | ||
| 327 | FileSys::RegisteredCache* GetSystemNANDContents() { | 334 | FileSys::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); |
| 48 | ResultVal<FileSys::VirtualDir> OpenSDMC(); | 48 | ResultVal<FileSys::VirtualDir> OpenSDMC(); |
| 49 | 49 | ||
| 50 | std::unique_ptr<FileSys::RegisteredCacheUnion> GetUnionContents(); | 50 | std::shared_ptr<FileSys::RegisteredCacheUnion> GetUnionContents(); |
| 51 | 51 | ||
| 52 | FileSys::RegisteredCache* GetSystemNANDContents(); | 52 | FileSys::RegisteredCache* GetSystemNANDContents(); |
| 53 | FileSys::RegisteredCache* GetUserNANDContents(); | 53 | FileSys::RegisteredCache* GetUserNANDContents(); |