1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-12 15:31:09 +00:00

It sounds like the two sync signals are exclusive ORd.

This commit is contained in:
Thomas Harte 2015-08-19 21:36:33 -04:00
parent 3c3c4d2f7c
commit 043d2f9896

View File

@ -199,31 +199,30 @@ void Machine::output_pixels(unsigned int count)
} }
} }
// logic: if in vsync, output that; otherwise if in vblank then output that;
// otherwise output a pixel
if(_vSyncEnabled) {
state = (_horizontalTimer < start_of_sync) ? OutputState::Sync : OutputState::Blank;
} else {
// blank is decoded as 68 counts; sync and colour burst as 16 counts // blank is decoded as 68 counts; sync and colour burst as 16 counts
// 4 blank // 4 blank
// 4 sync // 4 sync
// 9 'blank'; colour burst after 4 // 9 'blank'; colour burst after 4
// 40 pixels // 40 pixels
// it'll be about 43 cycles from start of hsync to start of visible frame, so... // it'll be about 43 cycles from start of hsync to start of visible frame, so...
// guesses, until I can find information: 26 cycles blank, 16 sync, 40 blank, 160 pixels // guesses, until I can find information: 26 cycles blank, 16 sync, 40 blank, 160 pixels
if (_horizontalTimer < (_vBlankExtend ? 152 : 160)) { if (_horizontalTimer < (_vBlankExtend ? 152 : 160)) {
if(_vBlankEnabled) { if(_vBlankEnabled) {
state = OutputState::Blank; state = OutputState::Blank;
} else { } else {
state = OutputState::Pixel; state = OutputState::Pixel;
}
} }
else if (_horizontalTimer < end_of_sync) state = OutputState::Blank; }
else if (_horizontalTimer < start_of_sync) state = OutputState::Sync; else if (_horizontalTimer < end_of_sync) state = OutputState::Blank;
else state = OutputState::Blank; else if (_horizontalTimer < start_of_sync) state = OutputState::Sync;
else state = OutputState::Blank;
// logic: if vsync is enabled, output the opposite of the automatic hsync output
if(_vSyncEnabled) {
state = (state = OutputState::Sync) ? OutputState::Blank : OutputState::Sync;
} }
_lastOutputStateDuration++; _lastOutputStateDuration++;