From 7c7609f5b94e681bce278b1bc0259c7243828377 Mon Sep 17 00:00:00 2001 From: Scott Mansell Date: Fri, 17 Sep 2021 12:39:06 +1200 Subject: [PATCH] BPStructs: Ignore malformed efb copies --- Source/Core/VideoCommon/BPStructs.cpp | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/Source/Core/VideoCommon/BPStructs.cpp b/Source/Core/VideoCommon/BPStructs.cpp index 57a418e8d0..42ca1545a5 100644 --- a/Source/Core/VideoCommon/BPStructs.cpp +++ b/Source/Core/VideoCommon/BPStructs.cpp @@ -244,6 +244,15 @@ static void BPWritten(const BPCmd& bp) WARN_LOG_FMT(VIDEO, "Oversized EFB copy: {}x{} (offset {},{} stride {})", srcRect.GetWidth(), srcRect.GetHeight(), srcRect.left, srcRect.top, destStride); + if (u32(srcRect.left) >= EFB_WIDTH || u32(srcRect.top) >= EFB_HEIGHT) + { + // This is not a sane src rectangle, it doesn't touch any valid image data at all + // Just ignore it + // Apparently Mario Kart Wii in wifi mode can generate a deformed EFB copy of size 4x4 + // at offset (328,1020) + return; + } + // Clamp the copy region to fit within EFB. So that we don't end up with a stretched image. srcRect.right = std::clamp(srcRect.right, 0, EFB_WIDTH); srcRect.bottom = std::clamp(srcRect.bottom, 0, EFB_HEIGHT);