diff options
author | bunnei <bunneidev@gmail.com> | 2019-04-02 04:20:05 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-04-02 04:20:05 +0200 |
commit | 29df6bbbd368a8265a401e8d529453352b43d5e1 (patch) | |
tree | 36ed85250c33cea2623765e7bc6c3f1708932b2e /src/core/hle/kernel/process.cpp | |
parent | Merge pull request #2301 from FearlessTobi/remove-amiibo-setting (diff) | |
parent | kernel/codeset: Make CodeSet's memory data member a regular std::vector (diff) | |
download | yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar.gz yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar.bz2 yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar.lz yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar.xz yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.tar.zst yuzu-29df6bbbd368a8265a401e8d529453352b43d5e1.zip |
Diffstat (limited to 'src/core/hle/kernel/process.cpp')
-rw-r--r-- | src/core/hle/kernel/process.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/core/hle/kernel/process.cpp b/src/core/hle/kernel/process.cpp index b0b7af76b..a5144b8ad 100644 --- a/src/core/hle/kernel/process.cpp +++ b/src/core/hle/kernel/process.cpp @@ -218,11 +218,13 @@ void Process::FreeTLSSlot(VAddr tls_address) { } void Process::LoadModule(CodeSet module_, VAddr base_addr) { + const auto memory = std::make_shared<std::vector<u8>>(std::move(module_.memory)); + const auto MapSegment = [&](const CodeSet::Segment& segment, VMAPermission permissions, MemoryState memory_state) { const auto vma = vm_manager - .MapMemoryBlock(segment.addr + base_addr, module_.memory, - segment.offset, segment.size, memory_state) + .MapMemoryBlock(segment.addr + base_addr, memory, segment.offset, + segment.size, memory_state) .Unwrap(); vm_manager.Reprotect(vma, permissions); }; |