diff options
author | Subv <subv2112@gmail.com> | 2017-10-01 20:57:50 +0200 |
---|---|---|
committer | Subv <subv2112@gmail.com> | 2017-10-02 22:16:16 +0200 |
commit | b18589ecf780ca479e077529b789ec481e58f715 (patch) | |
tree | 047fc258707b66a31cbce27c76f006d19e988999 /src/core/hle/kernel | |
parent | Merge pull request #2973 from huwpascoe/down_count (diff) | |
download | yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar.gz yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar.bz2 yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar.lz yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar.xz yuzu-b18589ecf780ca479e077529b789ec481e58f715.tar.zst yuzu-b18589ecf780ca479e077529b789ec481e58f715.zip |
Diffstat (limited to 'src/core/hle/kernel')
-rw-r--r-- | src/core/hle/kernel/shared_memory.cpp | 27 |
1 files changed, 12 insertions, 15 deletions
diff --git a/src/core/hle/kernel/shared_memory.cpp b/src/core/hle/kernel/shared_memory.cpp index 02d5a7a36..d45daca35 100644 --- a/src/core/hle/kernel/shared_memory.cpp +++ b/src/core/hle/kernel/shared_memory.cpp @@ -55,22 +55,19 @@ SharedPtr<SharedMemory> SharedMemory::Create(SharedPtr<Process> owner_process, u Kernel::g_current_process->vm_manager.RefreshMemoryBlockMappings(linheap_memory.get()); } } else { - // TODO(Subv): What happens if an application tries to create multiple memory blocks - // pointing to the same address? auto& vm_manager = shared_memory->owner_process->vm_manager; // The memory is already available and mapped in the owner process. - auto vma = vm_manager.FindVMA(address)->second; - // Copy it over to our own storage - shared_memory->backing_block = std::make_shared<std::vector<u8>>( - vma.backing_block->data() + vma.offset, vma.backing_block->data() + vma.offset + size); - shared_memory->backing_block_offset = 0; - // Unmap the existing pages - vm_manager.UnmapRange(address, size); - // Map our own block into the address space - vm_manager.MapMemoryBlock(address, shared_memory->backing_block, 0, size, - MemoryState::Shared); - // Reprotect the block with the new permissions - vm_manager.ReprotectRange(address, size, ConvertPermissions(permissions)); + auto vma = vm_manager.FindVMA(address); + ASSERT_MSG(vma != vm_manager.vma_map.end(), "Invalid memory address"); + ASSERT_MSG(vma->second.backing_block, "Backing block doesn't exist for address"); + + // The returned VMA might be a bigger one encompassing the desired address. + auto vma_offset = address - vma->first; + ASSERT_MSG(vma_offset + size <= vma->second.size, + "Shared memory exceeds bounds of mapped block"); + + shared_memory->backing_block = vma->second.backing_block; + shared_memory->backing_block_offset = vma->second.offset + vma_offset; } shared_memory->base_address = address; @@ -184,4 +181,4 @@ u8* SharedMemory::GetPointer(u32 offset) { return backing_block->data() + backing_block_offset + offset; } -} // namespace +} // namespace Kernel |