BPStructs: ensure side effects are same
Missed this side effect when fixing crash in Mario Kart Wii wifi
This commit is contained in:
parent
a6baca6bf6
commit
ce80a96aee
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue