From e6e52ffcf479cf930f39d6dd13dad900a625dbdb Mon Sep 17 00:00:00 2001 From: tomcw Date: Sat, 15 Jun 2019 18:15:00 +0100 Subject: [PATCH] Delay any video mode change by 1 cycle (#654) --- source/NTSC.cpp | 28 +++++++++++++++++++++++++--- source/NTSC.h | 2 +- source/Video.cpp | 2 +- 3 files changed, 27 insertions(+), 5 deletions(-) diff --git a/source/NTSC.cpp b/source/NTSC.cpp index fe7b7c82..a7efccae 100644 --- a/source/NTSC.cpp +++ b/source/NTSC.cpp @@ -125,6 +125,9 @@ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA static int g_nHiresPage = 1; static int g_nTextPage = 1; + static bool g_bDelayVideoMode = false; + static uint32_t g_uNewVideoModeFlags = 0; + // Understanding the Apple II, Timing Generation and the Video Scanner, Pg 3-11 // Vertical Scanning // Horizontal Scanning @@ -1852,7 +1855,7 @@ uint16_t NTSC_VideoGetScannerAddress ( const ULONG uExecutedCycles ) const uint16_t currVideoClockHorz = g_nVideoClockHorz; // Required for ANSI STORY (end credits) vert scrolling mid-scanline mixed mode: DGR80, TEXT80, DGR80 - g_nVideoClockHorz -= 2; + g_nVideoClockHorz -= 1; if ((SHORT)g_nVideoClockHorz < 0) { g_nVideoClockHorz += VIDEO_SCANNER_MAX_HORZ; @@ -1884,8 +1887,15 @@ void NTSC_SetVideoTextMode( int cols ) } //=========================================================================== -void NTSC_SetVideoMode( uint32_t uVideoModeFlags ) +void NTSC_SetVideoMode( uint32_t uVideoModeFlags, bool bDelay/*=false*/ ) { + if (bDelay) + { + g_bDelayVideoMode = true; + g_uNewVideoModeFlags = uVideoModeFlags; + return; + } + g_nVideoMixed = uVideoModeFlags & VF_MIXED; g_nVideoCharSet = VideoGetSWAltCharSet() ? 1 : 0; @@ -2227,7 +2237,19 @@ static void VideoUpdateCycles( int cyclesLeftToUpdate ) //=========================================================================== void NTSC_VideoUpdateCycles( long cycles6502 ) { - _ASSERT(cycles6502 < VIDEO_SCANNER_6502_CYCLES); // Use NTSC_VideoRedrawWholeScreen() instead + _ASSERT(cycles6502 && cycles6502 < VIDEO_SCANNER_6502_CYCLES); // Use NTSC_VideoRedrawWholeScreen() instead + + if (g_bDelayVideoMode) + { + VideoUpdateCycles(1); // Video mode change is delayed by 1 cycle + + g_bDelayVideoMode = false; + NTSC_SetVideoMode(g_uNewVideoModeFlags); + + cycles6502--; + if (!cycles6502) + return; + } VideoUpdateCycles(cycles6502); } diff --git a/source/NTSC.h b/source/NTSC.h index 23ce6dc2..44f7426f 100644 --- a/source/NTSC.h +++ b/source/NTSC.h @@ -4,7 +4,7 @@ extern uint32_t g_nChromaSize; // Prototypes (Public) ________________________________________________ - extern void NTSC_SetVideoMode( uint32_t uVideoModeFlags ); + extern void NTSC_SetVideoMode( uint32_t uVideoModeFlags, bool bDelay=false ); extern void NTSC_SetVideoStyle(); extern void NTSC_SetVideoTextMode( int cols ); extern uint32_t*NTSC_VideoGetChromaTable( bool bHueTypeMonochrome, bool bMonitorTypeColorTV ); diff --git a/source/Video.cpp b/source/Video.cpp index d3f77195..c5d37e19 100644 --- a/source/Video.cpp +++ b/source/Video.cpp @@ -675,7 +675,7 @@ BYTE VideoSetMode(WORD, WORD address, BYTE write, BYTE, ULONG uExecutedCycles) if (!IS_APPLE2) RGB_SetVideoMode(address); - NTSC_SetVideoMode( g_uVideoMode ); + NTSC_SetVideoMode( g_uVideoMode, true ); return MemReadFloatingBus(uExecutedCycles); }