Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

GS: Clamp ST coordinates to valid range in GS vertex trace. #12201

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

TJnotJT
Copy link

@TJnotJT TJnotJT commented Jan 16, 2025

Description of Changes

In the vertex trace, clamp floating point UV coordinates to valid UV ranges [-2047, 2047].

Rationale behind Changes

In the vertex trace, input float texture coordinates can sometimes be buggy (for reasons not totally clear, it might be emulation or game bugs), so they might be outside the valid ranges that the GS can process. Casting such values to integer can causes issues down stream with functions that use the vertex trace min/max texture coordinates, so this should fix some of those issues. In all the example I found, the issue was with SW renderer not loading a full texture (because it depends on vertex trace calulations) and thus sampling from garbage values.

Suggested Testing Steps

Testing on GS dumps/games that are known to have buggy/huge texture coordinates as described above. I didn't find anything that was obviously broken in testing, though any help testing on more games/dumps or feedback on the changes would be greatly appreciated.

Here are the most visible fixes that I could find in testing (before is left and after is right)

counter_terror
Should be a slight blurring effect (Counter_Terrorist_Special_Forces_-_Fire_for_Effect_SLES-53046_20230830195729.gs.xz).

bakugan
Should not have double eyebrows (Bakugan_Battle_Brawlers_shadows.gs.xz).

psychonauts
Should have a faint star-like patterns (Psychonauts_SLUS-21120_20231013005852.gs.xz).

tomb_raider
Should have character's shadow (Tomb_Raider_-_Legend_SLUS-21203_20230905130255.gs.xz).

testdrives
Should not have dark road (testdriveswminmax.gs.xz).

@TJnotJT TJnotJT changed the title GS: Clamp huge ST coordinates before casting in GetTextureMinMax GS: Clamp ST coordinates before casting in GetTextureMinMax Jan 16, 2025
@github-actions github-actions bot added the GS label Jan 16, 2025
@TJnotJT TJnotJT force-pushed the clamp-huge-st branch 2 times, most recently from 28bd2ef to 9a9d41c Compare January 16, 2025 02:09
@TJnotJT TJnotJT changed the title GS: Clamp ST coordinates before casting in GetTextureMinMax GS: Clamp ST coordinates before casting in GSVertexTraceFMM::FindMinMax() Jan 16, 2025
@TJnotJT TJnotJT changed the title GS: Clamp ST coordinates before casting in GSVertexTraceFMM::FindMinMax() GS: Clamp ST coordinates to valid range in GSVertexTraceFMM::FindMinMax() Jan 16, 2025
@lightningterror
Copy link
Contributor

TODO: On the dumps that I saw a difference should be checked on a ps2 to compare how they should look like.

@TJnotJT
Copy link
Author

TJnotJT commented Jan 20, 2025

TODO: On the dumps that I saw a difference should be checked on a ps2 to compare how they should look like.

Lightning, would you be able to provide the dump name (if it is in gspack-10-july-2024)? I will try to work on this further given the new info from the hardware tests Ziemas ran.

@lightningterror
Copy link
Contributor

007 Agent Under Fire - door blend
187 - Ride or Die_SLUS-21116_In_Game
2002 FIFA World Cup
50 Cent - Bulletproof_SLUS-21315_20230329231035
Ace Combat 04 - Shattered Skies_SLUS-20152_20230511225232
Ace_Combat_04_-_Shattered_Skies_SLUS-20152_20230502010138
AFL Premiership 2007_SCES-54639
Alfa Romeo
Ape Escape 2_SLUS-20685_20220914200448
Dave_Mirra_Freestyle_BMX_2_SLES-50217_20230213220044

There's more but the list is huge, ace combat 4, ape escape 2 dave mirra seem broken.

@TJnotJT
Copy link
Author

TJnotJT commented Jan 20, 2025

Thanks much, this should keep me busy for some time

@TJnotJT
Copy link
Author

TJnotJT commented Jan 24, 2025

I've fixed a few issues and the dump run seems to look good now on my end. Edit: Actually, there was a big error in the last force push that I didn't test. Should be fixed now hopefully.

@TJnotJT TJnotJT changed the title GS: Clamp ST coordinates to valid range in GSVertexTraceFMM::FindMinMax() GS: Clamp ST coordinates to valid range in GS vertex trace. Jan 24, 2025
@TJnotJT TJnotJT marked this pull request as ready for review January 25, 2025 03:49
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants