mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-14 20:29:32 +01:00
[Genesis/VDP] Fixed FIFO access timings when using invalid write code value (fixes Clue menu)
This commit is contained in:
parent
5328ea847c
commit
6b1751448b
@ -381,7 +381,7 @@ void vdp_reset(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Mega Drive specific */
|
/* Mega Drive specific */
|
||||||
else if ((system_hw == SYSTEM_MD) && (config.bios & 1) && !(system_bios & SYSTEM_MD))
|
else if (((system_hw == SYSTEM_MD) || (system_hw == SYSTEM_MCD)) && (config.bios & 1) && !(system_bios & SYSTEM_MD))
|
||||||
{
|
{
|
||||||
/* force registers initialization (only if TMSS model is emulated and BOOT ROM is not loaded) */
|
/* force registers initialization (only if TMSS model is emulated and BOOT ROM is not loaded) */
|
||||||
vdp_reg_w(0 , 0x04, 0);
|
vdp_reg_w(0 , 0x04, 0);
|
||||||
@ -479,8 +479,8 @@ int vdp_context_load(uint8 *state)
|
|||||||
load_param(&cached_write, sizeof(cached_write));
|
load_param(&cached_write, sizeof(cached_write));
|
||||||
|
|
||||||
/* restore FIFO timings */
|
/* restore FIFO timings */
|
||||||
fifo_latency = 214 - (reg[12] & 1) * 24;
|
fifo_latency = (reg[12] & 1) ? 190 : 214;
|
||||||
fifo_latency <<= ((code & 0x0F) == 0x01);
|
fifo_latency <<= ((code & 0x0F) < 0x03);
|
||||||
|
|
||||||
/* restore current NTSC/PAL mode */
|
/* restore current NTSC/PAL mode */
|
||||||
if (system_hw & SYSTEM_MD)
|
if (system_hw & SYSTEM_MD)
|
||||||
@ -567,8 +567,9 @@ void vdp_dma_update(unsigned int cycles)
|
|||||||
if (status & 8)
|
if (status & 8)
|
||||||
{
|
{
|
||||||
/* Process DMA until the end of VBLANK */
|
/* Process DMA until the end of VBLANK */
|
||||||
/* NOTE: This is not 100% accurate since rate should be recalculated if */
|
/* NOTE: DMA timings can not change during VBLANK because active display width cannot be modified. */
|
||||||
/* display width is changed during VBLANK but no games actually do this */
|
/* Indeed, writing VDP registers during DMA is either impossible (when doing DMA from 68k bus, CPU */
|
||||||
|
/* is locked) or will abort DMA operation (in case of DMA Fill or Copy). */
|
||||||
dma_cycles = (lines_per_frame * MCYCLES_PER_LINE) - cycles;
|
dma_cycles = (lines_per_frame * MCYCLES_PER_LINE) - cycles;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -777,9 +778,11 @@ void vdp_68k_ctrl_w(unsigned int data)
|
|||||||
|
|
||||||
Each VRAM access is byte wide, so one VRAM write (word) need twice cycles.
|
Each VRAM access is byte wide, so one VRAM write (word) need twice cycles.
|
||||||
|
|
||||||
|
Note: Invalid code 0x02 (register write) apparently behaves the same as VRAM
|
||||||
|
access, although no data is written in this case (fixes Clue menu)
|
||||||
*/
|
*/
|
||||||
fifo_latency = 214 - (reg[12] & 1) * 24;
|
fifo_latency = (reg[12] & 1) ? 190 : 214;
|
||||||
fifo_latency <<= ((code & 0x0F) == 0x01);
|
fifo_latency <<= ((code & 0x0F) < 0x03);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Mega Drive VDP control port specific (MS compatibility mode) */
|
/* Mega Drive VDP control port specific (MS compatibility mode) */
|
||||||
@ -1998,7 +2001,7 @@ static void vdp_reg_w(unsigned int r, unsigned int d, unsigned int cycles)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Adjust FIFO timings for VRAM writes */
|
/* Adjust FIFO timings for VRAM writes */
|
||||||
fifo_latency <<= ((code & 0x0F) == 0x01);
|
fifo_latency <<= ((code & 0x0F) < 0x03);
|
||||||
|
|
||||||
/* Active display width modified during HBLANK (Bugs Bunny Double Trouble) */
|
/* Active display width modified during HBLANK (Bugs Bunny Double Trouble) */
|
||||||
if ((v_counter < bitmap.viewport.h) && (cycles <= (mcycles_vdp + 860)))
|
if ((v_counter < bitmap.viewport.h) && (cycles <= (mcycles_vdp + 860)))
|
||||||
|
Loading…
x
Reference in New Issue
Block a user