GSdx: Adjust CRC hacks.

Purge Sengoku Basara crc hacks. Texture shuffle is emulated correctly on
d3d11/ogl. d3d9 skips the bad draw call.

Move Eternal Poison crc hack to d3d level. Not needed on ogl since
the game is emulated correctly.

Move hack that removes texture shuffle for Demon Stoneback back to ogl level,
half screen bottom issue remains.

Extent CRC hack for The Getaway and The Getaway Black Monday to work on
EU regions.
This commit is contained in:
lightningterror 2018-03-29 08:45:04 +02:00 committed by refractionpcsx2
parent ee3038c5b7
commit 4cb164b795
1 changed files with 62 additions and 63 deletions

View File

@ -91,8 +91,7 @@ bool GSC_DBZBT3(const GSFrameInfo& fi, int& skip)
} }
else if(fi.TME && (fi.FBP == 0x00000 || fi.FBP == 0x00e00 || fi.FBP == 0x01000) && fi.FPSM == PSM_PSMCT16 && fi.TPSM == PSM_PSMZ16) else if(fi.TME && (fi.FBP == 0x00000 || fi.FBP == 0x00e00 || fi.FBP == 0x01000) && fi.FPSM == PSM_PSMCT16 && fi.TPSM == PSM_PSMZ16)
{ {
// Texture shuffling works on OpenGL only for the NTSC version. The PAL version still has some issues. // Sky texture (Depth) is properly rendered on OpenGL only for the NTSC version. The PAL version still has some issues (half screen bottom issue).
// Sky texture (depth related). On Direct3D the blue sky texture is shown on the whole screen in front of the player if hack is disabled.
if(g_crc_region == CRC::EU || Dx_only) if(g_crc_region == CRC::EU || Dx_only)
{ {
skip = 5; skip = 5;
@ -109,6 +108,27 @@ bool GSC_DBZBT3(const GSFrameInfo& fi, int& skip)
return true; return true;
} }
bool GSC_DemonStone(const GSFrameInfo& fi, int& skip)
{
if(skip == 0)
{
if(fi.TME && fi.FBP == 0x01400 && fi.FPSM == fi.TPSM && (fi.TBP0 == 0x00000 || fi.TBP0 == 0x01000) && fi.TPSM == PSM_PSMCT16)
{
// Texture shuffle half screen bottom issue.
skip = 1000;
}
}
else
{
if(Dx_only && fi.TME && (fi.FBP == 0x00000 || fi.FBP == 0x01000) && fi.FPSM == PSM_PSMCT32)
{
skip = 2;
}
}
return true;
}
bool GSC_WildArmsGames(const GSFrameInfo& fi, int& skip) bool GSC_WildArmsGames(const GSFrameInfo& fi, int& skip)
{ {
if(skip == 0) if(skip == 0)
@ -382,19 +402,6 @@ bool GSC_Naruto(const GSFrameInfo& fi, int& skip)
return true; return true;
} }
bool GSC_EternalPoison(const GSFrameInfo& fi, int& skip)
{
if(skip == 0)
{
// Texture shuffle ???
if(fi.TPSM == PSM_PSMCT16S && fi.TBP0 == 0x3200)
{
skip = 1;
}
}
return true;
}
bool GSC_SakuraTaisen(const GSFrameInfo& fi, int& skip) bool GSC_SakuraTaisen(const GSFrameInfo& fi, int& skip)
{ {
if(skip == 0) if(skip == 0)
@ -433,10 +440,13 @@ bool GSC_ShadowofRome(const GSFrameInfo& fi, int& skip)
{ {
if(fi.FBP && fi.TPSM == PSM_PSMT8H && ( fi.FBMSK ==0x00FFFFFF)) if(fi.FBP && fi.TPSM == PSM_PSMT8H && ( fi.FBMSK ==0x00FFFFFF))
{ {
skip =1; // Depth issues on all renders, white wall and white duplicate characters.
skip = 1;
} }
else if(fi.TME ==0x0001 && (fi.TBP0==0x1300 || fi.TBP0==0x0f00) && fi.FBMSK>=0xFFFFFF) else if(fi.TME ==0x0001 && (fi.TBP0==0x1300 || fi.TBP0==0x0f00) && fi.FBMSK>=0xFFFFFF)
{ {
// Cause a grey transparent wall (D3D) and a transparent vertical grey line (all renders) on the left side of the screen.
// Blur effect maybe ?
skip = 1; skip = 1;
} }
else if(fi.TME && fi.FPSM == PSM_PSMCT32 && (fi.TBP0 ==0x0160 ||fi.TBP0==0x01e0 || fi.TBP0<=0x0800) && fi.TPSM == PSM_PSMT8) else if(fi.TME && fi.FPSM == PSM_PSMCT32 && (fi.TBP0 ==0x0160 ||fi.TBP0==0x01e0 || fi.TBP0<=0x0800) && fi.TPSM == PSM_PSMT8)
@ -1034,19 +1044,6 @@ bool GSC_HummerBadlands(const GSFrameInfo& fi, int& skip)
return true; return true;
} }
bool GSC_SengokuBasara(const GSFrameInfo& fi, int& skip)
{
if(skip == 0)
{
if(fi.TME && (fi.TBP0==0x1800 ) && fi.FBMSK==0xFF000000)
{
skip = 1;
}
}
return true;
}
bool GSC_TalesofSymphonia(const GSFrameInfo& fi, int& skip) bool GSC_TalesofSymphonia(const GSFrameInfo& fi, int& skip)
{ {
if(skip == 0) if(skip == 0)
@ -1122,6 +1119,21 @@ bool GSC_SteambotChronicles(const GSFrameInfo& fi, int& skip)
// Correctly emulated on OpenGL but can be used as potential speed hack // Correctly emulated on OpenGL but can be used as potential speed hack
//////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////
bool GSC_EternalPoison(const GSFrameInfo& fi, int& skip)
{
if(skip == 0)
{
// Texture shuffle or hdr colclip ???
if(fi.TPSM == PSM_PSMCT16S && fi.TBP0 == 0x3200)
{
// Removes shadows.
skip = 1;
}
}
return true;
}
bool GSC_FinalFightStreetwise(const GSFrameInfo& fi, int& skip) bool GSC_FinalFightStreetwise(const GSFrameInfo& fi, int& skip)
{ {
if (skip == 0) if (skip == 0)
@ -1178,11 +1190,11 @@ bool GSC_HauntingGround(const GSFrameInfo& fi, int& skip)
bool GSC_GetaWay(const GSFrameInfo& fi, int& skip) bool GSC_GetaWay(const GSFrameInfo& fi, int& skip)
{ {
if (skip == 0) if(skip == 0)
{ {
if ((fi.FBP == 0 || fi.FBP == 0x1180) && fi.TPSM == PSM_PSMT8H && fi.FBMSK == 0) if((fi.FBP == 0 || fi.FBP == 0x1180 || fi.FBP == 0x1400) && fi.TPSM == PSM_PSMT8H && fi.FBMSK == 0)
{ {
skip = 1; // US version only. Removes fog wall. skip = 1; // Removes fog wall.
} }
} }
@ -1664,6 +1676,7 @@ bool GSC_Tenchu(const GSFrameInfo& fi, int& skip)
{ {
if(fi.TME && fi.TPSM == PSM_PSMZ16 && fi.FPSM == PSM_PSMCT16 && fi.FBMSK == 0x03FFF) if(fi.TME && fi.TPSM == PSM_PSMZ16 && fi.FPSM == PSM_PSMCT16 && fi.FBMSK == 0x03FFF)
{ {
// Depth issues. D3D only.
skip = 3; skip = 3;
} }
} }
@ -1711,26 +1724,6 @@ bool GSC_Sly2(const GSFrameInfo& fi, int& skip)
return true; return true;
} }
bool GSC_DemonStone(const GSFrameInfo& fi, int& skip)
{
if(skip == 0)
{
if(fi.TME && fi.FBP == 0x01400 && fi.FPSM == fi.TPSM && (fi.TBP0 == 0x00000 || fi.TBP0 == 0x01000) && fi.TPSM == PSM_PSMCT16)
{
skip = 1000;
}
}
else
{
if(fi.TME && (fi.FBP == 0x00000 || fi.FBP == 0x01000) && fi.FPSM == PSM_PSMCT32)
{
skip = 2;
}
}
return true;
}
bool GSC_BigMuthaTruckers(const GSFrameInfo& fi, int& skip) bool GSC_BigMuthaTruckers(const GSFrameInfo& fi, int& skip)
{ {
if(skip == 0) if(skip == 0)
@ -2234,15 +2227,11 @@ void GSState::SetupCrcHack()
lut[CRC::BurnoutTakedown] = GSC_Burnout; lut[CRC::BurnoutTakedown] = GSC_Burnout;
lut[CRC::CaptainTsubasa] = GSC_CaptainTsubasa; lut[CRC::CaptainTsubasa] = GSC_CaptainTsubasa;
lut[CRC::CrashBandicootWoC] = GSC_CrashBandicootWoC; lut[CRC::CrashBandicootWoC] = GSC_CrashBandicootWoC;
lut[CRC::DBZBT2] = GSC_DBZBT2;
lut[CRC::DBZBT3] = GSC_DBZBT3;
lut[CRC::DevilMayCry3] = GSC_DevilMayCry3; lut[CRC::DevilMayCry3] = GSC_DevilMayCry3;
lut[CRC::EternalPoison] = GSC_EternalPoison;
lut[CRC::EvangelionJo] = GSC_EvangelionJo; lut[CRC::EvangelionJo] = GSC_EvangelionJo;
lut[CRC::FightingBeautyWulong] = GSC_FightingBeautyWulong; lut[CRC::FightingBeautyWulong] = GSC_FightingBeautyWulong;
lut[CRC::FrontMission5] = GSC_FrontMission5; lut[CRC::FrontMission5] = GSC_FrontMission5;
lut[CRC::Genji] = GSC_Genji; lut[CRC::Genji] = GSC_Genji;
lut[CRC::GiTS] = GSC_GiTS;
lut[CRC::GodHand] = GSC_GodHand; lut[CRC::GodHand] = GSC_GodHand;
lut[CRC::HeavyMetalThunder] = GSC_HeavyMetalThunder; lut[CRC::HeavyMetalThunder] = GSC_HeavyMetalThunder;
lut[CRC::HummerBadlands] = GSC_HummerBadlands; lut[CRC::HummerBadlands] = GSC_HummerBadlands;
@ -2260,17 +2249,14 @@ void GSState::SetupCrcHack()
lut[CRC::SacredBlaze] = GSC_SacredBlaze; lut[CRC::SacredBlaze] = GSC_SacredBlaze;
lut[CRC::SakuraTaisen] = GSC_SakuraTaisen; lut[CRC::SakuraTaisen] = GSC_SakuraTaisen;
lut[CRC::SakuraWarsSoLongMyLove] = GSC_SakuraWarsSoLongMyLove; lut[CRC::SakuraWarsSoLongMyLove] = GSC_SakuraWarsSoLongMyLove;
lut[CRC::SengokuBasara] = GSC_SengokuBasara;
lut[CRC::ShadowofRome] = GSC_ShadowofRome; lut[CRC::ShadowofRome] = GSC_ShadowofRome;
lut[CRC::ShinOnimusha] = GSC_ShinOnimusha; lut[CRC::ShinOnimusha] = GSC_ShinOnimusha;
lut[CRC::Simple2000Vol114] = GSC_Simple2000Vol114; lut[CRC::Simple2000Vol114] = GSC_Simple2000Vol114;
lut[CRC::Spartan] = GSC_Spartan; lut[CRC::Spartan] = GSC_Spartan;
lut[CRC::StarWarsForceUnleashed] = GSC_StarWarsForceUnleashed; lut[CRC::StarWarsForceUnleashed] = GSC_StarWarsForceUnleashed;
lut[CRC::SteambotChronicles] = GSC_SteambotChronicles;
lut[CRC::SFEX3] = GSC_SFEX3; lut[CRC::SFEX3] = GSC_SFEX3;
lut[CRC::TalesOfLegendia] = GSC_TalesOfLegendia; lut[CRC::TalesOfLegendia] = GSC_TalesOfLegendia;
lut[CRC::TalesofSymphonia] = GSC_TalesofSymphonia; lut[CRC::TalesofSymphonia] = GSC_TalesofSymphonia;
lut[CRC::Tekken5] = GSC_Tekken5;
lut[CRC::TimeSplitters2] = GSC_TimeSplitters2; lut[CRC::TimeSplitters2] = GSC_TimeSplitters2;
lut[CRC::TombRaiderAnniversary] = GSC_TombRaider; lut[CRC::TombRaiderAnniversary] = GSC_TombRaider;
lut[CRC::TombRaiderLegend] = GSC_TombRaiderLegend; lut[CRC::TombRaiderLegend] = GSC_TombRaiderLegend;
@ -2282,10 +2268,22 @@ void GSState::SetupCrcHack()
lut[CRC::Yakuza2] = GSC_Yakuza2; lut[CRC::Yakuza2] = GSC_Yakuza2;
lut[CRC::Yakuza] = GSC_Yakuza; lut[CRC::Yakuza] = GSC_Yakuza;
lut[CRC::ZettaiZetsumeiToshi2] = GSC_ZettaiZetsumeiToshi2; lut[CRC::ZettaiZetsumeiToshi2] = GSC_ZettaiZetsumeiToshi2;
// Channel Effect
lut[CRC::GiTS] = GSC_GiTS;
lut[CRC::SteambotChronicles] = GSC_SteambotChronicles;
// Half Screen bottom issue
lut[CRC::DBZBT2] = GSC_DBZBT2;
lut[CRC::DBZBT3] = GSC_DBZBT3;
lut[CRC::DemonStone] = GSC_DemonStone;
lut[CRC::Tekken5] = GSC_Tekken5;
// These games emulate a stencil buffer with the alpha channel of the RT (too slow to move to DX only) // These games emulate a stencil buffer with the alpha channel of the RT (too slow to move to DX only)
lut[CRC::RadiataStories] = GSC_RadiataStories; lut[CRC::RadiataStories] = GSC_RadiataStories;
lut[CRC::StarOcean3] = GSC_StarOcean3; lut[CRC::StarOcean3] = GSC_StarOcean3;
lut[CRC::ValkyrieProfile2] = GSC_ValkyrieProfile2; lut[CRC::ValkyrieProfile2] = GSC_ValkyrieProfile2;
// Only Aggressive // Only Aggressive
lut[CRC::BleachBladeBattlers] = GSC_BleachBladeBattlers; lut[CRC::BleachBladeBattlers] = GSC_BleachBladeBattlers;
lut[CRC::FFX2] = GSC_FFXGames; lut[CRC::FFX2] = GSC_FFXGames;
@ -2304,7 +2302,7 @@ void GSState::SetupCrcHack()
// Depth // Depth
lut[CRC::Bully] = GSC_Bully; lut[CRC::Bully] = GSC_Bully;
lut[CRC::BullyCC] = GSC_BullyCC; lut[CRC::BullyCC] = GSC_BullyCC;
lut[CRC::FinalFightStreetwise] = GSC_FinalFightStreetwise; lut[CRC::FinalFightStreetwise] = GSC_FinalFightStreetwise; // + blending
lut[CRC::GodOfWar2] = GSC_GodOfWar2; lut[CRC::GodOfWar2] = GSC_GodOfWar2;
lut[CRC::ICO] = GSC_ICO; lut[CRC::ICO] = GSC_ICO;
lut[CRC::LordOfTheRingsTwoTowers] = GSC_LordOfTheRingsTwoTowers; lut[CRC::LordOfTheRingsTwoTowers] = GSC_LordOfTheRingsTwoTowers;
@ -2312,6 +2310,8 @@ void GSState::SetupCrcHack()
lut[CRC::SoulCalibur2] = GSC_SoulCaliburGames; lut[CRC::SoulCalibur2] = GSC_SoulCaliburGames;
lut[CRC::SoulCalibur3] = GSC_SoulCaliburGames; lut[CRC::SoulCalibur3] = GSC_SoulCaliburGames;
lut[CRC::SuikodenTactics] = GSC_SuikodenTactics; lut[CRC::SuikodenTactics] = GSC_SuikodenTactics;
lut[CRC::TenchuFS] = GSC_Tenchu;
lut[CRC::TenchuWoH] = GSC_Tenchu;
lut[CRC::XE3] = GSC_XE3; lut[CRC::XE3] = GSC_XE3;
// Depth + Texture cache issue + Date (AKA a real mess) // Depth + Texture cache issue + Date (AKA a real mess)
@ -2319,16 +2319,14 @@ void GSState::SetupCrcHack()
// Not tested but must be fixed with texture shuffle // Not tested but must be fixed with texture shuffle
lut[CRC::BigMuthaTruckers] = GSC_BigMuthaTruckers; lut[CRC::BigMuthaTruckers] = GSC_BigMuthaTruckers;
lut[CRC::DemonStone] = GSC_DemonStone;
lut[CRC::CrashNburn] = GSC_CrashNburn; // seem to be a basic depth effect lut[CRC::CrashNburn] = GSC_CrashNburn; // seem to be a basic depth effect
lut[CRC::EternalPoison] = GSC_EternalPoison;
lut[CRC::LegoBatman] = GSC_LegoBatman; lut[CRC::LegoBatman] = GSC_LegoBatman;
lut[CRC::OnePieceGrandAdventure] = GSC_OnePieceGrandAdventure; lut[CRC::OnePieceGrandAdventure] = GSC_OnePieceGrandAdventure;
lut[CRC::OnePieceGrandBattle] = GSC_OnePieceGrandBattle; lut[CRC::OnePieceGrandBattle] = GSC_OnePieceGrandBattle;
lut[CRC::SpyroEternalNight] = GSC_SpyroEternalNight; lut[CRC::SpyroEternalNight] = GSC_SpyroEternalNight;
lut[CRC::SpyroNewBeginning] = GSC_SpyroNewBeginning; lut[CRC::SpyroNewBeginning] = GSC_SpyroNewBeginning;
lut[CRC::SonicUnleashed] = GSC_SonicUnleashed; lut[CRC::SonicUnleashed] = GSC_SonicUnleashed;
lut[CRC::TenchuFS] = GSC_Tenchu;
lut[CRC::TenchuWoH] = GSC_Tenchu;
// Those games might requires accurate fbmask // Those games might requires accurate fbmask
lut[CRC::Sly2] = GSC_Sly2; lut[CRC::Sly2] = GSC_Sly2;
@ -2352,6 +2350,7 @@ void GSState::SetupCrcHack()
lut[CRC::SkyGunner] = GSC_SkyGunner; lut[CRC::SkyGunner] = GSC_SkyGunner;
lut[CRC::StarWarsBattlefront2] = GSC_StarWarsBattlefront2; lut[CRC::StarWarsBattlefront2] = GSC_StarWarsBattlefront2;
lut[CRC::StarWarsBattlefront] = GSC_StarWarsBattlefront; lut[CRC::StarWarsBattlefront] = GSC_StarWarsBattlefront;
// Dedicated shader for channel effect // Dedicated shader for channel effect
lut[CRC::TalesOfAbyss] = GSC_TalesOfAbyss; lut[CRC::TalesOfAbyss] = GSC_TalesOfAbyss;