1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-14 13:33:42 +00:00

Fixes announced timing difference between pixel and border lines.

The Apple II sync fault is now fixed!
This commit is contained in:
Thomas Harte 2019-02-12 22:32:02 -05:00
parent 77bebd4a65
commit 7939897622

View File

@ -346,8 +346,9 @@ template <class BusHandler, bool is_iie> class Video: public VideoBase {
while(int_cycles) { while(int_cycles) {
const int cycles_this_line = std::min(65 - column_, int_cycles); const int cycles_this_line = std::min(65 - column_, int_cycles);
const int ending_column = column_ + cycles_this_line; const int ending_column = column_ + cycles_this_line;
const bool is_vertical_sync_line = (row_ >= first_sync_line && row_ < first_sync_line + 3);
if(row_ >= first_sync_line && row_ < first_sync_line + 3) { if(is_vertical_sync_line) {
// In effect apply an XOR to HSYNC and VSYNC flags in order to include equalising // In effect apply an XOR to HSYNC and VSYNC flags in order to include equalising
// pulses (and hencce keep hsync approximately where it should be during vsync). // pulses (and hencce keep hsync approximately where it should be during vsync).
const int blank_start = std::max(first_sync_column - sync_length, column_); const int blank_start = std::max(first_sync_column - sync_length, column_);
@ -361,7 +362,7 @@ template <class BusHandler, bool is_iie> class Video: public VideoBase {
crt_.output_sync((ending_column - blank_end) * 14); crt_.output_sync((ending_column - blank_end) * 14);
} }
} else { } else {
crt_.output_sync((cycles_this_line) * 14); crt_.output_sync(cycles_this_line * 14);
} }
} else { } else {
const GraphicsMode line_mode = graphics_mode(row_); const GraphicsMode line_mode = graphics_mode(row_);
@ -521,7 +522,7 @@ template <class BusHandler, bool is_iie> class Video: public VideoBase {
*/ */
if(column_ < first_sync_column && ending_column >= first_sync_column) { if(column_ < first_sync_column && ending_column >= first_sync_column) {
crt_.output_blank((first_sync_column - 41)*14 - 1); crt_.output_blank(first_sync_column*14 - 568);
} }
if(column_ < (first_sync_column + sync_length) && ending_column >= (first_sync_column + sync_length)) { if(column_ < (first_sync_column + sync_length) && ending_column >= (first_sync_column + sync_length)) {
@ -556,11 +557,16 @@ template <class BusHandler, bool is_iie> class Video: public VideoBase {
} }
// Add an extra half a colour cycle of blank; this isn't counted in the run_for // Add an extra half a colour cycle of blank; this isn't counted in the run_for
// count explicitly but is promised. // count explicitly but is promised. If this is a vertical sync line, output sync
// instead of blank, taking that to be the default level.
if(is_vertical_sync_line) {
crt_.output_sync(2);
} else {
crt_.output_blank(2); crt_.output_blank(2);
} }
} }
} }
}
GraphicsMode graphics_mode(int row) { GraphicsMode graphics_mode(int row) {
if( if(