Skip to content

Commit 9f41659

Browse files
committedSep 8, 2017
Send a challenge ACK in response to an unacceptable TCP ACK.
1 parent ef6f658 commit 9f41659

File tree

1 file changed

+18
-3
lines changed

1 file changed

+18
-3
lines changed
 

‎src/socket/tcp.rs

+18-3
Original file line numberDiff line numberDiff line change
@@ -734,19 +734,20 @@ impl<'a> TcpSocket<'a> {
734734
// Every acknowledgement must be for transmitted but unacknowledged data.
735735
(_, &TcpRepr { ack_number: Some(ack_number), .. }) => {
736736
let unacknowledged = self.tx_buffer.len() + control_len;
737+
737738
if ack_number < self.local_seq_no {
738739
net_debug!("[{}]{}:{}: duplicate ACK ({} not in {}...{})",
739740
self.debug_id, self.local_endpoint, self.remote_endpoint,
740741
ack_number, self.local_seq_no, self.local_seq_no + unacknowledged);
741-
// FIXME: instead of waiting for the retransmit timer to kick in,
742-
// reset it here.
742+
// FIXME: implement fast retransmit
743743
return Err(Error::Dropped)
744744
}
745+
745746
if ack_number > self.local_seq_no + unacknowledged {
746747
net_debug!("[{}]{}:{}: unacceptable ACK ({} not in {}...{})",
747748
self.debug_id, self.local_endpoint, self.remote_endpoint,
748749
ack_number, self.local_seq_no, self.local_seq_no + unacknowledged);
749-
return Err(Error::Dropped)
750+
return Ok(Some(self.ack_reply(ip_repr, &repr)))
750751
}
751752
}
752753
}
@@ -2903,6 +2904,20 @@ mod test {
29032904
}));
29042905
}
29052906

2907+
#[test]
2908+
fn test_unacceptable_ack_challenge_ack() {
2909+
let mut s = socket_established();
2910+
send!(s, TcpRepr {
2911+
seq_number: REMOTE_SEQ + 1,
2912+
ack_number: Some(LOCAL_SEQ + 1 + 1),
2913+
..SEND_TEMPL
2914+
}, Ok(Some(TcpRepr {
2915+
seq_number: LOCAL_SEQ + 1,
2916+
ack_number: Some(REMOTE_SEQ + 1),
2917+
..RECV_TEMPL
2918+
})));
2919+
}
2920+
29062921
#[test]
29072922
fn test_fill_peer_window() {
29082923
let mut s = socket_established();

0 commit comments

Comments
 (0)
Please sign in to comment.