"SLPS01919", "SLPS01920",
};
+static const char * const gpu_centering_hack_db[] =
+{
+ /* Gradius Gaiden */
+ "SLPM86042", "SLPM86103", "SLPM87323",
+ /* Sexy Parodius */
+ "SLPM86009",
+};
+
+static const char * const dualshock_init_analog_hack_db[] =
+{
+ /* Formula 1 Championship Edition */
+ "SLUS00546",
+ /* Gran Turismo 2 */
+ "SCUS94455", "SCUS94488", "SCPS10116", "SCPS10117", "SCES02380", "SCES12380",
+};
+
#define HACK_ENTRY(var, list) \
{ #var, &Config.hacks.var, list, ARRAY_SIZE(list) }
{
HACK_ENTRY(cdr_read_timing, cdr_read_hack_db),
HACK_ENTRY(gpu_slow_list_walking, gpu_slow_llist_db),
- HACK_ENTRY(gpu_busy_hack, gpu_busy_hack_db),
+ HACK_ENTRY(gpu_busy, gpu_busy_hack_db),
+ HACK_ENTRY(gpu_centering, gpu_centering_hack_db),
+ HACK_ENTRY(dualshock_init_analog, dualshock_init_analog_hack_db),
};
static const struct
{
- const char * const id;
int mult;
+ const char * const id[4];
}
cycle_multiplier_overrides[] =
{
/* note: values are = (10000 / gui_option) */
/* Internal Section - fussy about timings */
- { "SLPS01868", 202 },
+ { 202, { "SLPS01868" } },
/* Super Robot Taisen Alpha - on the edge with 175,
* changing memcard settings is enough to break/unbreak it */
- { "SLPS02528", 190 },
- { "SLPS02636", 190 },
+ { 190, { "SLPS02528", "SLPS02636" } },
/* Brave Fencer Musashi - cd sectors arrive too fast */
- { "SLUS00726", 170 },
- { "SLPS01490", 170 },
+ { 170, { "SLUS00726", "SLPS01490" } },
#if defined(DRC_DISABLE) || defined(LIGHTREC) /* new_dynarec has a hack for this game */
/* Parasite Eve II - internal timer checks */
- { "SLUS01042", 125 },
- { "SLUS01055", 125 },
- { "SLES02558", 125 },
- { "SLES12558", 125 },
+ { 125, { "SLUS01042", "SLUS01055", "SLES02558", "SLES12558" } },
#endif
/* Discworld Noir - audio skips if CPU runs too fast */
- { "SLES01549", 222 },
- { "SLES02063", 222 },
- { "SLES02064", 222 },
+ { 222, { "SLES01549", "SLES02063", "SLES02064" } },
/* Judge Dredd - could also be poor MDEC timing */
- { "SLUS00630", 128 },
- { "SLES00755", 128 },
+ { 128, { "SLUS00630", "SLES00755" } },
/* Digimon World */
- { "SLUS01032", 153 },
- { "SLES02914", 153 },
+ { 153, { "SLUS01032", "SLES02914" } },
+ /* Syphon Filter - reportedly hangs under unknown conditions */
+ { 169, { "SCUS94240" } },
+ /* Psychic Detective - some weird race condition in the game's cdrom code */
+ { 222, { "SLUS00165", "SLUS00166", "SLUS00167" } },
+ { 222, { "SLES00070", "SLES10070", "SLES20070" } },
};
/* Function for automatic patching according to GameID. */
}
}
+ if (Config.hacks.dualshock_init_analog) {
+ // assume the default is off, see LoadPAD1plugin()
+ for (i = 0; i < 8; i++)
+ padToggleAnalog(i);
+ }
+
/* Apply Memory card hack for Codename Tenka. (The game needs one of the memory card slots to be empty) */
for (i = 0; i < ARRAY_SIZE(MemorycardHack_db); i++)
{
for (i = 0; i < ARRAY_SIZE(cycle_multiplier_overrides); i++)
{
- if (strcmp(CdromId, cycle_multiplier_overrides[i].id) == 0)
+ const char * const * const ids = cycle_multiplier_overrides[i].id;
+ for (j = 0; j < ARRAY_SIZE(cycle_multiplier_overrides[i].id); j++)
+ if (ids[j] && strcmp(ids[j], CdromId) == 0)
+ break;
+ if (j < ARRAY_SIZE(cycle_multiplier_overrides[i].id))
{
Config.cycle_multiplier_override = cycle_multiplier_overrides[i].mult;
new_dynarec_hacks_pergame |= NDHACK_OVERRIDE_CYCLE_M;