diff options
| -rw-r--r-- | src/core/loader/elf.cpp | 3 | ||||
| -rw-r--r-- | src/core/loader/kip.cpp | 5 | ||||
| -rw-r--r-- | src/core/loader/nso.cpp | 12 | 
3 files changed, 12 insertions, 8 deletions
diff --git a/src/core/loader/elf.cpp b/src/core/loader/elf.cpp index f1795fdd6..8908e5328 100644 --- a/src/core/loader/elf.cpp +++ b/src/core/loader/elf.cpp @@ -335,7 +335,8 @@ Kernel::CodeSet ElfReader::LoadInto(VAddr vaddr) {              codeset_segment->addr = segment_addr;              codeset_segment->size = aligned_size; -            memcpy(&program_image[current_image_position], GetSegmentPtr(i), p->p_filesz); +            std::memcpy(program_image.data() + current_image_position, GetSegmentPtr(i), +                        p->p_filesz);              current_image_position += aligned_size;          }      } diff --git a/src/core/loader/kip.cpp b/src/core/loader/kip.cpp index 474b55cb1..092103abe 100644 --- a/src/core/loader/kip.cpp +++ b/src/core/loader/kip.cpp @@ -2,6 +2,7 @@  // Licensed under GPLv2 or any later version  // Refer to the license.txt file included. +#include <cstring>  #include "core/file_sys/kernel_executable.h"  #include "core/file_sys/program_metadata.h"  #include "core/gdbstub/gdbstub.h" @@ -76,8 +77,8 @@ AppLoader::LoadResult AppLoader_KIP::Load(Kernel::Process& process) {          segment.addr = offset;          segment.offset = offset;          segment.size = PageAlignSize(static_cast<u32>(data.size())); -        program_image.resize(offset); -        program_image.insert(program_image.end(), data.begin(), data.end()); +        program_image.resize(offset + data.size()); +        std::memcpy(program_image.data() + offset, data.data(), data.size());      };      load_segment(codeset.CodeSegment(), kip->GetTextSection(), kip->GetTextOffset()); diff --git a/src/core/loader/nso.cpp b/src/core/loader/nso.cpp index f629892ae..515c5accb 100644 --- a/src/core/loader/nso.cpp +++ b/src/core/loader/nso.cpp @@ -3,6 +3,7 @@  // Refer to the license.txt file included.  #include <cinttypes> +#include <cstring>  #include <vector>  #include "common/common_funcs.h" @@ -96,8 +97,9 @@ std::optional<VAddr> AppLoader_NSO::LoadModule(Kernel::Process& process,          if (nso_header.IsSegmentCompressed(i)) {              data = DecompressSegment(data, nso_header.segments[i]);          } -        program_image.resize(nso_header.segments[i].location); -        program_image.insert(program_image.end(), data.begin(), data.end()); +        program_image.resize(nso_header.segments[i].location + data.size()); +        std::memcpy(program_image.data() + nso_header.segments[i].location, data.data(), +                    data.size());          codeset.segments[i].addr = nso_header.segments[i].location;          codeset.segments[i].offset = nso_header.segments[i].location;          codeset.segments[i].size = PageAlignSize(static_cast<u32>(data.size())); @@ -139,12 +141,12 @@ std::optional<VAddr> AppLoader_NSO::LoadModule(Kernel::Process& process,          std::vector<u8> pi_header;          pi_header.insert(pi_header.begin(), reinterpret_cast<u8*>(&nso_header),                           reinterpret_cast<u8*>(&nso_header) + sizeof(NSOHeader)); -        pi_header.insert(pi_header.begin() + sizeof(NSOHeader), program_image.begin(), -                         program_image.end()); +        pi_header.insert(pi_header.begin() + sizeof(NSOHeader), program_image.data(), +                         program_image.data() + program_image.size());          pi_header = pm->PatchNSO(pi_header, file.GetName()); -        std::copy(pi_header.begin() + sizeof(NSOHeader), pi_header.end(), program_image.begin()); +        std::copy(pi_header.begin() + sizeof(NSOHeader), pi_header.end(), program_image.data());      }      // Apply cheats if they exist and the program has a valid title ID  | 
