BPStructs: ensure side effects are same

Missed this side effect when fixing crash in Mario Kart Wii wifi
This commit is contained in:
Scott Mansell 2021-09-18 17:29:46 +12:00
parent a6baca6bf6
commit ce80a96aee
1 changed files with 8 additions and 1 deletions

View File

@ -226,6 +226,8 @@ static void BPWritten(const BPCmd& bp)
srcRect.right = bpmem.copyTexSrcXY.x + bpmem.copyTexSrcWH.x + 1; srcRect.right = bpmem.copyTexSrcXY.x + bpmem.copyTexSrcWH.x + 1;
srcRect.bottom = bpmem.copyTexSrcXY.y + bpmem.copyTexSrcWH.y + 1; srcRect.bottom = bpmem.copyTexSrcXY.y + bpmem.copyTexSrcWH.y + 1;
const UPE_Copy PE_copy = bpmem.triggerEFBCopy;
// Since the copy X and Y coordinates/sizes are 10-bit, the game can configure a copy region up // Since the copy X and Y coordinates/sizes are 10-bit, the game can configure a copy region up
// to 1024x1024. Hardware tests have found that the number of bytes written does not depend on // to 1024x1024. Hardware tests have found that the number of bytes written does not depend on
// the configured stride, instead it is based on the size registers, writing beyond the length // the configured stride, instead it is based on the size registers, writing beyond the length
@ -250,6 +252,12 @@ static void BPWritten(const BPCmd& bp)
// Just ignore it // Just ignore it
// Apparently Mario Kart Wii in wifi mode can generate a deformed EFB copy of size 4x4 // Apparently Mario Kart Wii in wifi mode can generate a deformed EFB copy of size 4x4
// at offset (328,1020) // at offset (328,1020)
if (PE_copy.copy_to_xfb == 1)
{
// Make sure we disable Bounding box to match the side effects of the non-failure path
BoundingBox::Disable();
}
return; return;
} }
@ -262,7 +270,6 @@ static void BPWritten(const BPCmd& bp)
const u32 copy_height = srcRect.GetHeight(); const u32 copy_height = srcRect.GetHeight();
// Check if we are to copy from the EFB or draw to the XFB // Check if we are to copy from the EFB or draw to the XFB
const UPE_Copy PE_copy = bpmem.triggerEFBCopy;
if (PE_copy.copy_to_xfb == 0) if (PE_copy.copy_to_xfb == 0)
{ {
// bpmem.zcontrol.pixel_format to PixelFormat::Z24 is when the game wants to copy from ZBuffer // bpmem.zcontrol.pixel_format to PixelFormat::Z24 is when the game wants to copy from ZBuffer