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

Corrects transmission logic — exactly hitting write_data_time_remaining now works properly.

This commit is contained in:
Thomas Harte 2019-10-13 21:40:46 -04:00
parent 3b165a78f2
commit 530e831064

View File

@ -97,7 +97,7 @@ void ACIA::run_for(HalfCycles length) {
const auto write_data_time_remaining = transmit.write_data_time_remaining(); const auto write_data_time_remaining = transmit.write_data_time_remaining();
if(write_data_time_remaining) { if(write_data_time_remaining) {
if(transmit_advance > write_data_time_remaining) { if(transmit_advance >= write_data_time_remaining) {
if(next_transmission_ != NoTransmission) { if(next_transmission_ != NoTransmission) {
transmit.flush_writing(); transmit.flush_writing();
consider_transmission(); consider_transmission();
@ -142,7 +142,7 @@ void ACIA::consider_transmission() {
// Output all that. // Output all that.
const int total_bits = 1 + data_bits_ + stop_bits_ + (parity_ != Parity::None); const int total_bits = 1 + data_bits_ + stop_bits_ + (parity_ != Parity::None);
transmit.write(divider_, total_bits, transmission); transmit.write(divider_ * 2, total_bits, transmission);
// Mark the transmit register as empty again. // Mark the transmit register as empty again.
next_transmission_ = NoTransmission; next_transmission_ = NoTransmission;