From 91b9634198df0163f71d3f9c1c15f2f79eb42155 Mon Sep 17 00:00:00 2001 From: Kevin O'Connor Date: Thu, 7 Sep 2017 14:44:55 -0400 Subject: [PATCH] serialqueue: Fix off-by-one error in retransmit sequence number tracking Commit 4655a6bf allowed naks to be honored if receive_seq was greater than the last retransmitted sequence. However, receive_seq is the receiver's next sequence number, so a nak should only be processed if it is one greater than that. Signed-off-by: Kevin O'Connor --- klippy/serialqueue.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/klippy/serialqueue.c b/klippy/serialqueue.c index 6ad1b916..7247022a 100644 --- a/klippy/serialqueue.c +++ b/klippy/serialqueue.c @@ -609,9 +609,9 @@ retransmit_event(struct serialqueue *sq, double eventtime) sq->rto *= 2.0; if (sq->rto > MAX_RTO) sq->rto = MAX_RTO; - sq->ignore_nak_seq = sq->send_seq - 1; + sq->ignore_nak_seq = sq->send_seq; } - sq->retransmit_seq = sq->send_seq - 1; + sq->retransmit_seq = sq->send_seq; sq->rtt_sample_seq = 0; sq->idle_time = eventtime + buflen * sq->baud_adjust; double waketime = eventtime + first_buflen * sq->baud_adjust + sq->rto;