diff options
| author | 2015-07-16 18:08:46 -0400 | |
|---|---|---|
| committer | 2015-07-16 18:08:46 -0400 | |
| commit | 946f0ee2f4f5e150167ad90f86a425b50baec144 (patch) | |
| tree | 47586aae7237dddc7278ef5e579cf82ad1b64e11 /src/core/loader/elf.cpp | |
| parent | Merge pull request #931 from neobrain/move_default_attr_handler (diff) | |
| parent | Loader: Fix variable type and remove unused variable (diff) | |
| download | yuzu-946f0ee2f4f5e150167ad90f86a425b50baec144.tar.gz yuzu-946f0ee2f4f5e150167ad90f86a425b50baec144.tar.xz yuzu-946f0ee2f4f5e150167ad90f86a425b50baec144.zip | |
Merge pull request #918 from yuriks/romfs
Do not load entire RomFS to memory, read from the file as needed instead (rebased)
Diffstat (limited to 'src/core/loader/elf.cpp')
| -rw-r--r-- | src/core/loader/elf.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/src/core/loader/elf.cpp b/src/core/loader/elf.cpp index ca3c18a9f..5d7264f12 100644 --- a/src/core/loader/elf.cpp +++ b/src/core/loader/elf.cpp | |||
| @@ -273,7 +273,6 @@ SharedPtr<CodeSet> ElfReader::LoadInto(u32 vaddr) { | |||
| 273 | LOG_DEBUG(Loader, "%i segments:", header->e_phnum); | 273 | LOG_DEBUG(Loader, "%i segments:", header->e_phnum); |
| 274 | 274 | ||
| 275 | // First pass : Get the bits into RAM | 275 | // First pass : Get the bits into RAM |
| 276 | u32 segment_addr[32]; | ||
| 277 | u32 base_addr = relocate ? vaddr : 0; | 276 | u32 base_addr = relocate ? vaddr : 0; |
| 278 | 277 | ||
| 279 | u32 total_image_size = 0; | 278 | u32 total_image_size = 0; |
| @@ -392,15 +391,15 @@ ResultStatus AppLoader_ELF::Load() { | |||
| 392 | if (is_loaded) | 391 | if (is_loaded) |
| 393 | return ResultStatus::ErrorAlreadyLoaded; | 392 | return ResultStatus::ErrorAlreadyLoaded; |
| 394 | 393 | ||
| 395 | if (!file->IsOpen()) | 394 | if (!file.IsOpen()) |
| 396 | return ResultStatus::Error; | 395 | return ResultStatus::Error; |
| 397 | 396 | ||
| 398 | // Reset read pointer in case this file has been read before. | 397 | // Reset read pointer in case this file has been read before. |
| 399 | file->Seek(0, SEEK_SET); | 398 | file.Seek(0, SEEK_SET); |
| 400 | 399 | ||
| 401 | u32 size = static_cast<u32>(file->GetSize()); | 400 | size_t size = file.GetSize(); |
| 402 | std::unique_ptr<u8[]> buffer(new u8[size]); | 401 | std::unique_ptr<u8[]> buffer(new u8[size]); |
| 403 | if (file->ReadBytes(&buffer[0], size) != size) | 402 | if (file.ReadBytes(&buffer[0], size) != size) |
| 404 | return ResultStatus::Error; | 403 | return ResultStatus::Error; |
| 405 | 404 | ||
| 406 | ElfReader elf_reader(&buffer[0]); | 405 | ElfReader elf_reader(&buffer[0]); |