summaryrefslogtreecommitdiff
path: root/src/core/loader/elf.cpp
diff options
context:
space:
mode:
authorGravatar bunnei2015-07-16 18:08:46 -0400
committerGravatar bunnei2015-07-16 18:08:46 -0400
commit946f0ee2f4f5e150167ad90f86a425b50baec144 (patch)
tree47586aae7237dddc7278ef5e579cf82ad1b64e11 /src/core/loader/elf.cpp
parentMerge pull request #931 from neobrain/move_default_attr_handler (diff)
parentLoader: Fix variable type and remove unused variable (diff)
downloadyuzu-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.cpp9
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]);