mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-14 20:29:32 +01:00
[Z80] fixed state of CPU registers on reset: fixes missing sound in Defender/Defender 2 (Williams Arcade Classics)
This commit is contained in:
parent
efc7c3000a
commit
cd14774e03
@ -41,6 +41,7 @@ of samples per frame and keeping PSG & FM chips in sync.
|
|||||||
---------------
|
---------------
|
||||||
* updated Z80 core to last version (fixes interrupt Mode 0 timing and some BIT instructions).
|
* updated Z80 core to last version (fixes interrupt Mode 0 timing and some BIT instructions).
|
||||||
* fixed some Z80 instructions timing.
|
* fixed some Z80 instructions timing.
|
||||||
|
* fixed state of Z80 registers on reset (sound issues with Defender & Defender 2 in Williams Arcade Classics)
|
||||||
* improved Z80 interrupt accuracy
|
* improved Z80 interrupt accuracy
|
||||||
* improved 68k accuracy (initial Reset timing + auto-vectored interrupts handling).
|
* improved 68k accuracy (initial Reset timing + auto-vectored interrupts handling).
|
||||||
* improved 68k timing accuracy for DIVU/DVIS (thanks to Jorge Cwik) & MULU/MULS instructions.
|
* improved 68k timing accuracy for DIVU/DVIS (thanks to Jorge Cwik) & MULU/MULS instructions.
|
||||||
|
@ -3353,6 +3353,9 @@ void z80_init(const void *config, int (*irqcallback)(int))
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Reset registers to their initial values */
|
/* Reset registers to their initial values */
|
||||||
|
memset(&Z80, 0, sizeof(Z80));
|
||||||
|
IX = IY = 0xffff; /* IX and IY are FFFF after a reset! */
|
||||||
|
F = ZF; /* Zero flag is set */
|
||||||
Z80.daisy = config;
|
Z80.daisy = config;
|
||||||
Z80.irq_callback = irqcallback;
|
Z80.irq_callback = irqcallback;
|
||||||
|
|
||||||
@ -3370,25 +3373,19 @@ void z80_init(const void *config, int (*irqcallback)(int))
|
|||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
void z80_reset(void)
|
void z80_reset(void)
|
||||||
{
|
{
|
||||||
/* save previous values */
|
|
||||||
void *config = (void *) Z80.daisy;
|
|
||||||
int (*irqcallback)(int) = Z80.irq_callback;
|
|
||||||
|
|
||||||
/* Reset registers to their initial values */
|
|
||||||
memset(&Z80, 0, sizeof(Z80));
|
|
||||||
Z80.daisy = config;
|
|
||||||
Z80.irq_callback = irqcallback;
|
|
||||||
IX = IY = 0xffff; /* IX and IY are FFFF after a reset! */
|
|
||||||
F = ZF; /* Zero flag is set */
|
|
||||||
|
|
||||||
PC = 0x0000;
|
PC = 0x0000;
|
||||||
I = 0;
|
I = 0;
|
||||||
R = 0;
|
R = 0;
|
||||||
R2 = 0;
|
R2 = 0;
|
||||||
|
IM = 0;
|
||||||
|
IFF1 = IFF2 = 0;
|
||||||
|
HALT = 0;
|
||||||
|
|
||||||
Z80.nmi_state = CLEAR_LINE;
|
Z80.nmi_state = CLEAR_LINE;
|
||||||
Z80.nmi_pending = FALSE;
|
Z80.nmi_pending = FALSE;
|
||||||
Z80.irq_state = CLEAR_LINE;
|
Z80.irq_state = CLEAR_LINE;
|
||||||
Z80.after_ei = FALSE;
|
Z80.after_ei = FALSE;
|
||||||
|
|
||||||
WZ=PCD;
|
WZ=PCD;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user