From d7c6a7522deb2a4f99212ed1639a7c2e29c01f9c Mon Sep 17 00:00:00 2001 From: Lioncash Date: Wed, 4 Feb 2015 08:18:11 -0500 Subject: [PATCH] Memmap: Fix switch fallthroughs Fixes a bug where out of range MEM2 accesses would hit the locked cache. --- Source/Core/Core/HW/Memmap.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Source/Core/Core/HW/Memmap.cpp b/Source/Core/Core/HW/Memmap.cpp index fc8dc39f34..adc04468d0 100644 --- a/Source/Core/Core/HW/Memmap.cpp +++ b/Source/Core/Core/HW/Memmap.cpp @@ -278,6 +278,7 @@ u8* GetPointer(const u32 address) case 0xcc: case 0xcd: _dbg_assert_msg_(MEMMAP, 0, "GetPointer from IO Bridge doesnt work"); + break; case 0xc8: // EFB. We don't want to return a pointer here since we have no memory mapped for it. break; @@ -286,6 +287,7 @@ u8* GetPointer(const u32 address) if ((address & 0xfffffff) < REALRAM_SIZE) return m_pRAM + (address & RAM_MASK); } + break; case 0x1: case 0x9: @@ -295,8 +297,7 @@ u8* GetPointer(const u32 address) if ((address & 0xfffffff) < EXRAM_SIZE) return m_pEXRAM + (address & EXRAM_MASK); } - else - break; + break; case 0xe: if (address < (0xE0000000 + L1_CACHE_SIZE)) @@ -307,6 +308,7 @@ u8* GetPointer(const u32 address) default: if (bFakeVMEM) return m_pFakeVMEM + (address & FAKEVMEM_MASK); + break; } ERROR_LOG(MEMMAP, "Unknown Pointer %#8x PC %#8x LR %#8x", address, PC, LR);