diff options
author | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2016-12-15 08:44:19 +0100 |
---|---|---|
committer | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2016-12-15 08:46:59 +0100 |
commit | f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93 (patch) | |
tree | 9b13959bffec5fd7d65527551f2076eb8e9c985c /src/core | |
parent | Merge pull request #2317 from yuriks/vertex-copy (diff) | |
download | yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar.gz yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar.bz2 yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar.lz yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar.xz yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.tar.zst yuzu-f2b9be9bd3837f4bc55cc92d82b8c567dfd98c93.zip |
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/memory.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/core/memory.cpp b/src/core/memory.cpp index 65e4bba85..d058dc844 100644 --- a/src/core/memory.cpp +++ b/src/core/memory.cpp @@ -357,14 +357,24 @@ void RasterizerMarkRegionCached(PAddr start, u32 size, int count_delta) { } } +static void RoundToPages(PAddr& start, u32& size) { + PAddr start_rounded_down = start & ~PAGE_MASK; + PAddr end_rounded_up = ((start + size) + PAGE_MASK) & ~PAGE_MASK; + + start = start_rounded_down; + size = end_rounded_up - start_rounded_down; +} + void RasterizerFlushRegion(PAddr start, u32 size) { if (VideoCore::g_renderer != nullptr) { + RoundToPages(start, size); VideoCore::g_renderer->Rasterizer()->FlushRegion(start, size); } } void RasterizerFlushAndInvalidateRegion(PAddr start, u32 size) { if (VideoCore::g_renderer != nullptr) { + RoundToPages(start, size); VideoCore::g_renderer->Rasterizer()->FlushAndInvalidateRegion(start, size); } } |