diff options
| author | 2020-04-21 18:59:16 -0400 | |
|---|---|---|
| committer | 2020-04-21 18:59:16 -0400 | |
| commit | cd47ccec496c9a961abf1dc58f8d2a4165c1bf2b (patch) | |
| tree | ec4adafd6b8f513a4d37e4594dfa864df4d6bb17 /src/core/loader/elf.cpp | |
| parent | Merge pull request #3718 from ReinUsesLisp/better-pipeline-state (diff) | |
| parent | loader: nro: Fix process initialization using ProgramMetadata default. (diff) | |
| download | yuzu-cd47ccec496c9a961abf1dc58f8d2a4165c1bf2b.tar.gz yuzu-cd47ccec496c9a961abf1dc58f8d2a4165c1bf2b.tar.xz yuzu-cd47ccec496c9a961abf1dc58f8d2a4165c1bf2b.zip | |
Merge pull request #3745 from bunnei/fix-homebrew-load
Fix process memory initialization for ELF and NRO
Diffstat (limited to 'src/core/loader/elf.cpp')
| -rw-r--r-- | src/core/loader/elf.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/core/loader/elf.cpp b/src/core/loader/elf.cpp index 1e9ed2837..8f7615115 100644 --- a/src/core/loader/elf.cpp +++ b/src/core/loader/elf.cpp | |||
| @@ -398,6 +398,11 @@ AppLoader_ELF::LoadResult AppLoader_ELF::Load(Kernel::Process& process) { | |||
| 398 | Kernel::CodeSet codeset = elf_reader.LoadInto(base_address); | 398 | Kernel::CodeSet codeset = elf_reader.LoadInto(base_address); |
| 399 | const VAddr entry_point = codeset.entrypoint; | 399 | const VAddr entry_point = codeset.entrypoint; |
| 400 | 400 | ||
| 401 | // Setup the process code layout | ||
| 402 | if (process.LoadFromMetadata(FileSys::ProgramMetadata::GetDefault(), buffer.size()).IsError()) { | ||
| 403 | return {ResultStatus::ErrorNotInitialized, {}}; | ||
| 404 | } | ||
| 405 | |||
| 401 | process.LoadModule(std::move(codeset), entry_point); | 406 | process.LoadModule(std::move(codeset), entry_point); |
| 402 | 407 | ||
| 403 | is_loaded = true; | 408 | is_loaded = true; |