From 85c754b45662cd2d4f63fe4fae990fcf18392449 Mon Sep 17 00:00:00 2001 From: refractionpcsx2 Date: Mon, 2 May 2022 04:41:57 +0100 Subject: [PATCH] GS: Limit scissor optimisation, fix repeat condition Only allow scissors to happen on single draws, multiple draws (likely using it as a texture map) will possibly falsely limit the range. --- pcsx2/GS/GSState.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/pcsx2/GS/GSState.cpp b/pcsx2/GS/GSState.cpp index d302c9d6ff..9815a09bb1 100644 --- a/pcsx2/GS/GSState.cpp +++ b/pcsx2/GS/GSState.cpp @@ -3184,7 +3184,7 @@ GSState::TextureMinMaxResult GSState::GetTextureMinMax(const GIFRegTEX0& TEX0, c // Adjust texture range when sprites get scissor clipped. Since we linearly interpolate, this // optimization doesn't work when perspective correction is enabled. - if (m_vt.m_primclass == GS_SPRITE_CLASS && PRIM->FST == 1) + if (m_vt.m_primclass == GS_SPRITE_CLASS && PRIM->FST == 1 && m_index.tail < 3) { // When coordinates are fractional, GS appears to draw to the right/bottom (effectively // taking the ceiling), not to the top/left (taking the floor). @@ -3198,14 +3198,14 @@ GSState::TextureMinMaxResult GSState::GetTextureMinMax(const GIFRegTEX0& TEX0, c const GSVector2 grad(uv_range / pos_range); // we need to check that it's not going to repeat over the non-clipped part - if (wms != CLAMP_REGION_REPEAT && (wms != CLAMP_REPEAT || (static_cast(st.x) & ~tw_mask) != (static_cast(st.z) & ~tw_mask))) + if (wms != CLAMP_REGION_REPEAT && (wms != CLAMP_REPEAT || (static_cast(st.x) & ~tw_mask) == (static_cast(st.z) & ~tw_mask))) { if (int_rc.left < scissored_rc.left) st.x += floor(static_cast(scissored_rc.left - int_rc.left)* grad.x); if (int_rc.right > scissored_rc.right) st.z -= floor(static_cast(int_rc.right - scissored_rc.right) * grad.x); } - if (wmt != CLAMP_REGION_REPEAT && (wmt != CLAMP_REPEAT || (static_cast(st.y) & ~th_mask) != (static_cast(st.w) & ~th_mask))) + if (wmt != CLAMP_REGION_REPEAT && (wmt != CLAMP_REPEAT || (static_cast(st.y) & ~th_mask) == (static_cast(st.w) & ~th_mask))) { if (int_rc.top < scissored_rc.top) st.y += floor(static_cast(scissored_rc.top - int_rc.top) * grad.y);