From b2584dc45505dbfa3282756393251df87ed77e73 Mon Sep 17 00:00:00 2001 From: psucien Date: Sun, 28 Apr 2024 00:57:30 +0200 Subject: [PATCH] texture_cache: protection flags re-worked * actually I gave up on clang fmt --- src/video_core/texture_cache/texture_cache.cpp | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/src/video_core/texture_cache/texture_cache.cpp b/src/video_core/texture_cache/texture_cache.cpp index bf172ff81..3ec43bb4a 100644 --- a/src/video_core/texture_cache/texture_cache.cpp +++ b/src/video_core/texture_cache/texture_cache.cpp @@ -12,14 +12,11 @@ #include #include -#define PROT_READ_WRITE - (PROT_READ | PROT_WRITE) // There is no option to combine bitflags like this on Windows +#define PAGE_NOACCESS PROT_NONE +#define PAGE_READWRITE (PROT_READ | PROT_WRITE) #else #include -#define PROT_NONE PAGE_NOACCESS -#define PROT_READ_WRITE PAGE_READWRITE - void mprotect(void* addr, size_t len, int prot) { DWORD old_prot{}; BOOL result = VirtualProtect(addr, len, prot, &old_prot); @@ -228,9 +225,9 @@ void TextureCache::UpdatePagesCachedCount(VAddr addr, u64 size, s32 delta) { const u32 interval_size = interval_end_addr - interval_start_addr; void* addr = reinterpret_cast(interval_start_addr); if (delta > 0 && count == delta) { - mprotect(addr, interval_size, PROT_NONE); + mprotect(addr, interval_size, PAGE_NOACCESS); } else if (delta < 0 && count == -delta) { - mprotect(addr, interval_size, PROT_READ_WRITE); + mprotect(addr, interval_size, PAGE_READWRITE); } else { ASSERT(count >= 0); }