summaryrefslogtreecommitdiffstats
path: root/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp
diff options
context:
space:
mode:
authorSebastian Valle <subv2112@gmail.com>2018-07-02 21:07:17 +0200
committerGitHub <noreply@github.com>2018-07-02 21:07:17 +0200
commit79167fc989f682ce54877df0ffc0d5b73d4aaed9 (patch)
treeff9994a63f8ad5c8ddd8840a263dcdfee85ae119 /src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp
parentMerge pull request #605 from Subv/dma_copy (diff)
parentGPU: Remove a surface from the cache when its backing memory is being unmapped from the GPU's MMU. (diff)
downloadyuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar.gz
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar.bz2
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar.lz
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar.xz
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.tar.zst
yuzu-79167fc989f682ce54877df0ffc0d5b73d4aaed9.zip
Diffstat (limited to 'src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp')
-rw-r--r--src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp b/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp
index c1eea861d..7d8ed6920 100644
--- a/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp
+++ b/src/core/hle/service/nvdrv/devices/nvhost_as_gpu.cpp
@@ -8,6 +8,8 @@
#include "core/core.h"
#include "core/hle/service/nvdrv/devices/nvhost_as_gpu.h"
#include "core/hle/service/nvdrv/devices/nvmap.h"
+#include "video_core/renderer_base.h"
+#include "video_core/video_core.h"
namespace Service::Nvidia::Devices {
@@ -154,6 +156,9 @@ u32 nvhost_as_gpu::UnmapBuffer(const std::vector<u8>& input, std::vector<u8>& ou
ASSERT_MSG(itr != buffer_mappings.end(), "Tried to unmap invalid mapping");
+ // Remove this memory region from the rasterizer cache.
+ VideoCore::g_renderer->Rasterizer()->FlushAndInvalidateRegion(params.offset, itr->second.size);
+
params.offset = gpu.memory_manager->UnmapBuffer(params.offset, itr->second.size);
buffer_mappings.erase(itr->second.offset);