|
@@ -3805,10 +3805,14 @@ invalid_ack:
|
|
|
return -1;
|
|
|
|
|
|
old_ack:
|
|
|
+ /* If data was SACKed, tag it and see if we should send more data.
|
|
|
+ * If data was DSACKed, see if we can undo a cwnd reduction.
|
|
|
+ */
|
|
|
if (TCP_SKB_CB(skb)->sacked) {
|
|
|
- tcp_sacktag_write_queue(sk, skb, prior_snd_una);
|
|
|
- if (icsk->icsk_ca_state == TCP_CA_Open)
|
|
|
- tcp_try_keep_open(sk);
|
|
|
+ flag |= tcp_sacktag_write_queue(sk, skb, prior_snd_una);
|
|
|
+ newly_acked_sacked = tp->sacked_out - prior_sacked;
|
|
|
+ tcp_fastretrans_alert(sk, pkts_acked, newly_acked_sacked,
|
|
|
+ is_dupack, flag);
|
|
|
}
|
|
|
|
|
|
SOCK_DEBUG(sk, "Ack %u before %u:%u\n", ack, tp->snd_una, tp->snd_nxt);
|