diff options
| author | bunnei <bunneidev@gmail.com> | 2018-05-20 23:54:50 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-05-20 23:54:50 -0400 | 
| commit | 58857b9f46992753059aa8a6c31aff0ee14c9f99 (patch) | |
| tree | d49a9d594878a2c2a948b13109e1a6e6c07ffaba /src/video_core | |
| parent | c6eaf0b2cf993c25516f2ae1d27fed840e99b472 (diff) | |
| parent | 525492428d3b1ccbe2096944a7525b242d4c9e7b (diff) | |
Merge pull request #456 from Subv/unmap_buffer
Implemented nvhost-as-gpu's UnmapBuffer and nvmap's Free ioctls.
Diffstat (limited to 'src/video_core')
| -rw-r--r-- | src/video_core/memory_manager.cpp | 19 | ||||
| -rw-r--r-- | src/video_core/memory_manager.h | 1 | 
2 files changed, 20 insertions, 0 deletions
| diff --git a/src/video_core/memory_manager.cpp b/src/video_core/memory_manager.cpp index 25984439d..5cefce9fc 100644 --- a/src/video_core/memory_manager.cpp +++ b/src/video_core/memory_manager.cpp @@ -58,6 +58,25 @@ GPUVAddr MemoryManager::MapBufferEx(VAddr cpu_addr, GPUVAddr gpu_addr, u64 size)      return gpu_addr;  } +GPUVAddr MemoryManager::UnmapBuffer(GPUVAddr gpu_addr, u64 size) { +    ASSERT((gpu_addr & PAGE_MASK) == 0); + +    for (u64 offset = 0; offset < size; offset += PAGE_SIZE) { +        ASSERT(PageSlot(gpu_addr + offset) != static_cast<u64>(PageStatus::Allocated) && +               PageSlot(gpu_addr + offset) != static_cast<u64>(PageStatus::Unmapped)); +        PageSlot(gpu_addr + offset) = static_cast<u64>(PageStatus::Unmapped); +    } + +    // Delete the region mappings that are contained within the unmapped region +    mapped_regions.erase(std::remove_if(mapped_regions.begin(), mapped_regions.end(), +                                        [&](const MappedRegion& region) { +                                            return region.gpu_addr <= gpu_addr && +                                                   region.gpu_addr + region.size < gpu_addr + size; +                                        }), +                         mapped_regions.end()); +    return gpu_addr; +} +  boost::optional<GPUVAddr> MemoryManager::FindFreeBlock(u64 size, u64 align) {      GPUVAddr gpu_addr = 0;      u64 free_space = 0; diff --git a/src/video_core/memory_manager.h b/src/video_core/memory_manager.h index 08140c83a..86765e72a 100644 --- a/src/video_core/memory_manager.h +++ b/src/video_core/memory_manager.h @@ -25,6 +25,7 @@ public:      GPUVAddr AllocateSpace(GPUVAddr gpu_addr, u64 size, u64 align);      GPUVAddr MapBufferEx(VAddr cpu_addr, u64 size);      GPUVAddr MapBufferEx(VAddr cpu_addr, GPUVAddr gpu_addr, u64 size); +    GPUVAddr UnmapBuffer(GPUVAddr gpu_addr, u64 size);      boost::optional<VAddr> GpuToCpuAddress(GPUVAddr gpu_addr);      std::vector<GPUVAddr> CpuToGpuAddress(VAddr cpu_addr) const; | 
