GSdx: Add an Enumeration for CRC Hack level

This commit is contained in:
Akash 2017-02-13 16:46:27 +05:30 committed by Gregory Hainaut
parent 726f9d5312
commit ff89619b09
8 changed files with 22 additions and 14 deletions

View File

@ -1425,3 +1425,12 @@ enum class Filtering : uint8
Trilinear_Bilinear_Forced, Trilinear_Bilinear_Forced,
Trilinear_Always Trilinear_Always
}; };
enum class CRCHackLevel : uint8
{
None,
Minimum,
Partial,
Full,
Aggressive
};

View File

@ -23,11 +23,11 @@
#include "GSState.h" #include "GSState.h"
#include "GSdx.h" #include "GSdx.h"
int s_crc_hack_level = 3; CRCHackLevel s_crc_hack_level = CRCHackLevel::Full;
// hacks // hacks
#define Aggresive (s_crc_hack_level > 3) #define Aggresive (s_crc_hack_level >= CRCHackLevel::Aggressive)
#define Dx_only (s_crc_hack_level > 2) #define Dx_only (s_crc_hack_level >= CRCHackLevel::Full)
CRC::Region g_crc_region = CRC::NoRegion; CRC::Region g_crc_region = CRC::NoRegion;
@ -2419,11 +2419,11 @@ void GSState::SetupCrcHack()
{ {
GetSkipCount lut[CRC::TitleCount]; GetSkipCount lut[CRC::TitleCount];
s_crc_hack_level = theApp.GetConfigI("crc_hack_level"); s_crc_hack_level = static_cast<CRCHackLevel>(theApp.GetConfigI("crc_hack_level"));
memset(lut, 0, sizeof(lut)); memset(lut, 0, sizeof(lut));
if (s_crc_hack_level > 1) { if (s_crc_hack_level > CRCHackLevel::Minimum) {
lut[CRC::AceCombat4] = GSC_AceCombat4; lut[CRC::AceCombat4] = GSC_AceCombat4;
lut[CRC::BlackHawkDown] = GSC_BlackHawkDown; lut[CRC::BlackHawkDown] = GSC_BlackHawkDown;
lut[CRC::BleachBladeBattlers] = GSC_BleachBladeBattlers; lut[CRC::BleachBladeBattlers] = GSC_BleachBladeBattlers;

View File

@ -299,7 +299,7 @@ void GSRendererDX::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sourc
// Gregory: code is not yet ready so let's only enable it when // Gregory: code is not yet ready so let's only enable it when
// CRC is below the FULL level // CRC is below the FULL level
if (m_texture_shuffle && (m_crc_hack_level < 3)) { if (m_texture_shuffle && (m_crc_hack_level < CRCHackLevel::Full)) {
ps_sel.shuffle = 1; ps_sel.shuffle = 1;
ps_sel.fmt = 0; ps_sel.fmt = 0;

View File

@ -23,7 +23,6 @@
#include "GSState.h" #include "GSState.h"
#include "GSdx.h" #include "GSdx.h"
extern int g_crc_hack_level;
//#define Offset_ST // Fixes Persona3 mini map alignment which is off even in software rendering //#define Offset_ST // Fixes Persona3 mini map alignment which is off even in software rendering
@ -79,7 +78,7 @@ GSState::GSState()
//s_savel = 0; //s_savel = 0;
UserHacks_WildHack = theApp.GetConfigB("UserHacks") ? theApp.GetConfigI("UserHacks_WildHack") : 0; UserHacks_WildHack = theApp.GetConfigB("UserHacks") ? theApp.GetConfigI("UserHacks_WildHack") : 0;
m_crc_hack_level = theApp.GetConfigI("crc_hack_level"); m_crc_hack_level = static_cast<CRCHackLevel>(theApp.GetConfigI("crc_hack_level"));
memset(&m_v, 0, sizeof(m_v)); memset(&m_v, 0, sizeof(m_v));
memset(&m_vertex, 0, sizeof(m_vertex)); memset(&m_vertex, 0, sizeof(m_vertex));
@ -2519,7 +2518,7 @@ void GSState::SetGameCRC(uint32 crc, int options)
{ {
m_crc = crc; m_crc = crc;
m_options = options; m_options = options;
m_game = CRC::Lookup(m_crc_hack_level ? crc : 0); m_game = CRC::Lookup(m_crc_hack_level != CRCHackLevel::None ? crc : 0);
SetupCrcHack(); SetupCrcHack();
// Until we find a solution that work for all games. // Until we find a solution that work for all games.

View File

@ -160,7 +160,7 @@ protected:
int UserHacks_WildHack; int UserHacks_WildHack;
bool isPackedUV_HackFlag; bool isPackedUV_HackFlag;
int m_crc_hack_level; CRCHackLevel m_crc_hack_level;
GetSkipCount m_gsc; GetSkipCount m_gsc;
int m_skip; int m_skip;
int m_userhacks_skipdraw; int m_userhacks_skipdraw;

View File

@ -51,7 +51,7 @@ GSTextureCache::GSTextureCache(GSRenderer* r)
m_paltex = theApp.GetConfigB("paltex"); m_paltex = theApp.GetConfigB("paltex");
m_can_convert_depth &= s_IS_OPENGL; // only supported by openGL so far m_can_convert_depth &= s_IS_OPENGL; // only supported by openGL so far
m_crc_hack_level = theApp.GetConfigI("crc_hack_level"); m_crc_hack_level = static_cast<CRCHackLevel>(theApp.GetConfigI("crc_hack_level"));
// In theory 4MB is enough but 9MB is safer for overflow (8MB // In theory 4MB is enough but 9MB is safer for overflow (8MB
// isn't enough in custom resolution) // isn't enough in custom resolution)
@ -281,7 +281,7 @@ GSTextureCache::Source* GSTextureCache::LookupSource(const GIFRegTEX0& TEX0, con
// Gregory: to avoid a massive slow down for nothing, let's only enable // Gregory: to avoid a massive slow down for nothing, let's only enable
// this code when CRC is below the FULL level // this code when CRC is below the FULL level
if (m_crc_hack_level < 3) if (m_crc_hack_level < CRCHackLevel::Full)
Read(t, t->m_valid); Read(t, t->m_valid);
else else
dst = t; dst = t;

View File

@ -129,7 +129,7 @@ protected:
bool m_preload_frame; bool m_preload_frame;
uint8* m_temp; uint8* m_temp;
bool m_can_convert_depth; bool m_can_convert_depth;
int m_crc_hack_level; CRCHackLevel m_crc_hack_level;
static bool m_disable_partial_invalidation; static bool m_disable_partial_invalidation;
bool m_texture_inside_rt; bool m_texture_inside_rt;
static bool m_wrap_gs_mem; static bool m_wrap_gs_mem;

View File

@ -294,7 +294,7 @@ void GSdxApp::Init()
m_default_configuration["CaptureHeight"] = "480"; m_default_configuration["CaptureHeight"] = "480";
m_default_configuration["CaptureWidth"] = "640"; m_default_configuration["CaptureWidth"] = "640";
m_default_configuration["clut_load_before_draw"] = "0"; m_default_configuration["clut_load_before_draw"] = "0";
m_default_configuration["crc_hack_level"] = "3"; m_default_configuration["crc_hack_level"] = to_string(static_cast<int8>(CRCHackLevel::Full));
m_default_configuration["CrcHacksExclusions"] = ""; m_default_configuration["CrcHacksExclusions"] = "";
m_default_configuration["debug_glsl_shader"] = "0"; m_default_configuration["debug_glsl_shader"] = "0";
m_default_configuration["debug_opengl"] = "0"; m_default_configuration["debug_opengl"] = "0";