mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-15 20:59:08 +01:00
fixed cheat codes handling when multiple codes affect identical ROM address
This commit is contained in:
parent
ef8efa2c10
commit
5567576861
@ -121,39 +121,27 @@ void ggenie_switch(int enable)
|
|||||||
int i,j;
|
int i,j;
|
||||||
if (enable)
|
if (enable)
|
||||||
{
|
{
|
||||||
|
/* enable cheats */
|
||||||
for (i=0; i<6; i++)
|
for (i=0; i<6; i++)
|
||||||
{
|
{
|
||||||
/* patch is enabled ? */
|
/* patch is enabled ? */
|
||||||
if (ggenie.regs[0] & (1 << i))
|
if (ggenie.regs[0] & (1 << i))
|
||||||
{
|
{
|
||||||
/* first look if address has not already been patched */
|
|
||||||
for (j=0;j<i;j++)
|
|
||||||
{
|
|
||||||
if (ggenie.addr[i] == ggenie.addr[j])
|
|
||||||
{
|
|
||||||
/* disable code for later initialization */
|
|
||||||
ggenie.regs[0] &= ~(1 << i);
|
|
||||||
j = i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* save old value and patch ROM if enabled */
|
/* save old value and patch ROM if enabled */
|
||||||
if (ggenie.regs[0] & (1 << i))
|
|
||||||
{
|
|
||||||
ggenie.old[i] = *(uint16 *)(cart.rom + ggenie.addr[i]);
|
ggenie.old[i] = *(uint16 *)(cart.rom + ggenie.addr[i]);
|
||||||
*(uint16 *)(cart.rom + ggenie.addr[i]) = ggenie.data[i];
|
*(uint16 *)(cart.rom + ggenie.addr[i]) = ggenie.data[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* restore old values */
|
/* disable cheats in reversed order in case the same address is used by multiple patches */
|
||||||
for (i=0; i<6; i++)
|
for (i=5; i>=0; i--)
|
||||||
{
|
{
|
||||||
/* patch is enabled ? */
|
/* patch is enabled ? */
|
||||||
if (ggenie.regs[0] & (1 << i))
|
if (ggenie.regs[0] & (1 << i))
|
||||||
{
|
{
|
||||||
|
/* restore original ROM value */
|
||||||
*(uint16 *)(cart.rom + ggenie.addr[i]) = ggenie.old[i];
|
*(uint16 *)(cart.rom + ggenie.addr[i]) = ggenie.old[i];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -339,14 +339,18 @@ static void apply_cheats(void)
|
|||||||
|
|
||||||
static void clear_cheats(void)
|
static void clear_cheats(void)
|
||||||
{
|
{
|
||||||
int i;
|
int i = maxcheats;
|
||||||
for (i = 0; i < maxcheats; i++)
|
|
||||||
|
/* disable cheats in reversed order in case the same address is used by multiple patches */
|
||||||
|
while (i > 0)
|
||||||
{
|
{
|
||||||
/* restore original ROM data */
|
/* restore original ROM data */
|
||||||
if (cheatlist[i].enable && (cheatlist[i].address < cart.romsize))
|
if (cheatlist[i-1].enable && (cheatlist[i-1].address < cart.romsize))
|
||||||
{
|
{
|
||||||
*(u16 *)(cart.rom + (cheatlist[i].address & 0xFFFFFE)) = cheatlist[i].old;
|
*(u16 *)(cart.rom + (cheatlist[i-1].address & 0xFFFFFE)) = cheatlist[i-1].old;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
i--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user