summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar bunnei2018-08-06 22:02:41 -0400
committerGravatar GitHub2018-08-06 22:02:41 -0400
commit826b1394e85720b62938c5f7af4a876e203316af (patch)
tree2660cb536c62d253419965f727e996b87c8a21f5 /src
parentMerge pull request #947 from lioncash/encoding (diff)
parentloader: Make AppLoader_NCA rely on directory loading code (diff)
downloadyuzu-826b1394e85720b62938c5f7af4a876e203316af.tar.gz
yuzu-826b1394e85720b62938c5f7af4a876e203316af.tar.xz
yuzu-826b1394e85720b62938c5f7af4a876e203316af.zip
Merge pull request #931 from DarkLordZach/nca-as-drd
loader: Make AppLoader_NCA rely on directory loading code
Diffstat (limited to 'src')
-rw-r--r--src/core/loader/deconstructed_rom_directory.cpp11
-rw-r--r--src/core/loader/deconstructed_rom_directory.h4
-rw-r--r--src/core/loader/nca.cpp44
-rw-r--r--src/core/loader/nca.h2
4 files changed, 24 insertions, 37 deletions
diff --git a/src/core/loader/deconstructed_rom_directory.cpp b/src/core/loader/deconstructed_rom_directory.cpp
index b0277a875..076927dff 100644
--- a/src/core/loader/deconstructed_rom_directory.cpp
+++ b/src/core/loader/deconstructed_rom_directory.cpp
@@ -20,6 +20,10 @@ namespace Loader {
20AppLoader_DeconstructedRomDirectory::AppLoader_DeconstructedRomDirectory(FileSys::VirtualFile file) 20AppLoader_DeconstructedRomDirectory::AppLoader_DeconstructedRomDirectory(FileSys::VirtualFile file)
21 : AppLoader(std::move(file)) {} 21 : AppLoader(std::move(file)) {}
22 22
23AppLoader_DeconstructedRomDirectory::AppLoader_DeconstructedRomDirectory(
24 FileSys::VirtualDir directory)
25 : AppLoader(directory->GetFile("main")), dir(std::move(directory)) {}
26
23FileType AppLoader_DeconstructedRomDirectory::IdentifyType(const FileSys::VirtualFile& file) { 27FileType AppLoader_DeconstructedRomDirectory::IdentifyType(const FileSys::VirtualFile& file) {
24 if (FileSys::IsDirectoryExeFS(file->GetContainingDirectory())) { 28 if (FileSys::IsDirectoryExeFS(file->GetContainingDirectory())) {
25 return FileType::DeconstructedRomDirectory; 29 return FileType::DeconstructedRomDirectory;
@@ -34,7 +38,12 @@ ResultStatus AppLoader_DeconstructedRomDirectory::Load(
34 return ResultStatus::ErrorAlreadyLoaded; 38 return ResultStatus::ErrorAlreadyLoaded;
35 } 39 }
36 40
37 const FileSys::VirtualDir dir = file->GetContainingDirectory(); 41 if (dir == nullptr) {
42 if (file == nullptr)
43 return ResultStatus::ErrorInvalidFormat;
44 const FileSys::VirtualDir dir = file->GetContainingDirectory();
45 }
46
38 const FileSys::VirtualFile npdm = dir->GetFile("main.npdm"); 47 const FileSys::VirtualFile npdm = dir->GetFile("main.npdm");
39 if (npdm == nullptr) 48 if (npdm == nullptr)
40 return ResultStatus::ErrorInvalidFormat; 49 return ResultStatus::ErrorInvalidFormat;
diff --git a/src/core/loader/deconstructed_rom_directory.h b/src/core/loader/deconstructed_rom_directory.h
index 7319ba6ea..7d5433563 100644
--- a/src/core/loader/deconstructed_rom_directory.h
+++ b/src/core/loader/deconstructed_rom_directory.h
@@ -22,6 +22,9 @@ class AppLoader_DeconstructedRomDirectory final : public AppLoader {
22public: 22public:
23 explicit AppLoader_DeconstructedRomDirectory(FileSys::VirtualFile main_file); 23 explicit AppLoader_DeconstructedRomDirectory(FileSys::VirtualFile main_file);
24 24
25 // Overload to accept exefs directory. Must contain 'main' and 'main.npdm'
26 explicit AppLoader_DeconstructedRomDirectory(FileSys::VirtualDir directory);
27
25 /** 28 /**
26 * Returns the type of the file 29 * Returns the type of the file
27 * @param file std::shared_ptr<VfsFile> open file 30 * @param file std::shared_ptr<VfsFile> open file
@@ -40,6 +43,7 @@ public:
40private: 43private:
41 FileSys::ProgramMetadata metadata; 44 FileSys::ProgramMetadata metadata;
42 FileSys::VirtualFile romfs; 45 FileSys::VirtualFile romfs;
46 FileSys::VirtualDir dir;
43}; 47};
44 48
45} // namespace Loader 49} // namespace Loader
diff --git a/src/core/loader/nca.cpp b/src/core/loader/nca.cpp
index a1f8235d1..dbc67c0b5 100644
--- a/src/core/loader/nca.cpp
+++ b/src/core/loader/nca.cpp
@@ -22,7 +22,8 @@
22 22
23namespace Loader { 23namespace Loader {
24 24
25AppLoader_NCA::AppLoader_NCA(FileSys::VirtualFile file) : AppLoader(std::move(file)) {} 25AppLoader_NCA::AppLoader_NCA(FileSys::VirtualFile file_)
26 : AppLoader(std::move(file_)), nca(std::make_unique<FileSys::NCA>(file)) {}
26 27
27FileType AppLoader_NCA::IdentifyType(const FileSys::VirtualFile& file) { 28FileType AppLoader_NCA::IdentifyType(const FileSys::VirtualFile& file) {
28 FileSys::NCA nca(file); 29 FileSys::NCA nca(file);
@@ -39,8 +40,7 @@ ResultStatus AppLoader_NCA::Load(Kernel::SharedPtr<Kernel::Process>& process) {
39 return ResultStatus::ErrorAlreadyLoaded; 40 return ResultStatus::ErrorAlreadyLoaded;
40 } 41 }
41 42
42 nca = std::make_unique<FileSys::NCA>(file); 43 const auto result = nca->GetStatus();
43 ResultStatus result = nca->GetStatus();
44 if (result != ResultStatus::Success) { 44 if (result != ResultStatus::Success) {
45 return result; 45 return result;
46 } 46 }
@@ -48,44 +48,16 @@ ResultStatus AppLoader_NCA::Load(Kernel::SharedPtr<Kernel::Process>& process) {
48 if (nca->GetType() != FileSys::NCAContentType::Program) 48 if (nca->GetType() != FileSys::NCAContentType::Program)
49 return ResultStatus::ErrorInvalidFormat; 49 return ResultStatus::ErrorInvalidFormat;
50 50
51 auto exefs = nca->GetExeFS(); 51 const auto exefs = nca->GetExeFS();
52 52
53 if (exefs == nullptr) 53 if (exefs == nullptr)
54 return ResultStatus::ErrorInvalidFormat; 54 return ResultStatus::ErrorInvalidFormat;
55 55
56 result = metadata.Load(exefs->GetFile("main.npdm")); 56 directory_loader = std::make_unique<AppLoader_DeconstructedRomDirectory>(exefs);
57 if (result != ResultStatus::Success) {
58 return result;
59 }
60 metadata.Print();
61
62 const FileSys::ProgramAddressSpaceType arch_bits{metadata.GetAddressSpaceType()};
63 if (arch_bits == FileSys::ProgramAddressSpaceType::Is32Bit) {
64 return ResultStatus::ErrorUnsupportedArch;
65 }
66
67 VAddr next_load_addr{Memory::PROCESS_IMAGE_VADDR};
68 for (const auto& module : {"rtld", "main", "subsdk0", "subsdk1", "subsdk2", "subsdk3",
69 "subsdk4", "subsdk5", "subsdk6", "subsdk7", "sdk"}) {
70 const VAddr load_addr = next_load_addr;
71
72 next_load_addr = AppLoader_NSO::LoadModule(exefs->GetFile(module), load_addr);
73 if (next_load_addr) {
74 LOG_DEBUG(Loader, "loaded module {} @ 0x{:X}", module, load_addr);
75 // Register module with GDBStub
76 GDBStub::RegisterModule(module, load_addr, next_load_addr - 1, false);
77 } else {
78 next_load_addr = load_addr;
79 }
80 }
81 57
82 process->program_id = metadata.GetTitleID(); 58 const auto load_result = directory_loader->Load(process);
83 process->svc_access_mask.set(); 59 if (load_result != ResultStatus::Success)
84 process->address_mappings = default_address_mappings; 60 return load_result;
85 process->resource_limit =
86 Kernel::ResourceLimit::GetForCategory(Kernel::ResourceLimitCategory::APPLICATION);
87 process->Run(Memory::PROCESS_IMAGE_VADDR, metadata.GetMainThreadPriority(),
88 metadata.GetMainThreadStackSize());
89 61
90 if (nca->GetRomFS() != nullptr && nca->GetRomFS()->GetSize() > 0) 62 if (nca->GetRomFS() != nullptr && nca->GetRomFS()->GetSize() > 0)
91 Service::FileSystem::RegisterRomFS(std::make_unique<FileSys::RomFSFactory>(*this)); 63 Service::FileSystem::RegisterRomFS(std::make_unique<FileSys::RomFSFactory>(*this));
diff --git a/src/core/loader/nca.h b/src/core/loader/nca.h
index e14d618b3..0fd2d0417 100644
--- a/src/core/loader/nca.h
+++ b/src/core/loader/nca.h
@@ -10,6 +10,7 @@
10#include "core/file_sys/program_metadata.h" 10#include "core/file_sys/program_metadata.h"
11#include "core/hle/kernel/object.h" 11#include "core/hle/kernel/object.h"
12#include "core/loader/loader.h" 12#include "core/loader/loader.h"
13#include "deconstructed_rom_directory.h"
13 14
14namespace Loader { 15namespace Loader {
15 16
@@ -41,6 +42,7 @@ private:
41 FileSys::ProgramMetadata metadata; 42 FileSys::ProgramMetadata metadata;
42 43
43 std::unique_ptr<FileSys::NCA> nca; 44 std::unique_ptr<FileSys::NCA> nca;
45 std::unique_ptr<AppLoader_DeconstructedRomDirectory> directory_loader;
44}; 46};
45 47
46} // namespace Loader 48} // namespace Loader