aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
Diffstat (limited to 'net')
-rw-r--r--net/ipv4/tcp_input.c35
1 files changed, 17 insertions, 18 deletions
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c
index 84bcdc94dfa9..20c9440ab85e 100644
--- a/net/ipv4/tcp_input.c
+++ b/net/ipv4/tcp_input.c
@@ -1444,12 +1444,17 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1444 tp->retransmit_skb_hint = NULL; 1444 tp->retransmit_skb_hint = NULL;
1445 } 1445 }
1446 } else { 1446 } else {
1447 /* New sack for not retransmitted frame, 1447 if (!(sacked & TCPCB_RETRANS)) {
1448 * which was in hole. It is reordering. 1448 /* New sack for not retransmitted frame,
1449 */ 1449 * which was in hole. It is reordering.
1450 if (!(sacked & TCPCB_RETRANS) && 1450 */
1451 fack_count < prior_fackets) 1451 if (fack_count < prior_fackets)
1452 reord = min(fack_count, reord); 1452 reord = min(fack_count, reord);
1453
1454 /* SACK enhanced F-RTO (RFC4138; Appendix B) */
1455 if (!after(TCP_SKB_CB(skb)->end_seq, tp->frto_highmark))
1456 flag |= FLAG_ONLY_ORIG_SACKED;
1457 }
1453 1458
1454 if (sacked & TCPCB_LOST) { 1459 if (sacked & TCPCB_LOST) {
1455 TCP_SKB_CB(skb)->sacked &= ~TCPCB_LOST; 1460 TCP_SKB_CB(skb)->sacked &= ~TCPCB_LOST;
@@ -1458,18 +1463,6 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1458 /* clear lost hint */ 1463 /* clear lost hint */
1459 tp->retransmit_skb_hint = NULL; 1464 tp->retransmit_skb_hint = NULL;
1460 } 1465 }
1461 /* SACK enhanced F-RTO detection.
1462 * Set flag if and only if non-rexmitted
1463 * segments below frto_highmark are
1464 * SACKed (RFC4138; Appendix B).
1465 * Clearing correct due to in-order walk
1466 */
1467 if (after(end_seq, tp->frto_highmark)) {
1468 flag &= ~FLAG_ONLY_ORIG_SACKED;
1469 } else {
1470 if (!(sacked & TCPCB_RETRANS))
1471 flag |= FLAG_ONLY_ORIG_SACKED;
1472 }
1473 } 1466 }
1474 1467
1475 TCP_SKB_CB(skb)->sacked |= TCPCB_SACKED_ACKED; 1468 TCP_SKB_CB(skb)->sacked |= TCPCB_SACKED_ACKED;
@@ -1503,6 +1496,12 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1503 tp->retransmit_skb_hint = NULL; 1496 tp->retransmit_skb_hint = NULL;
1504 } 1497 }
1505 } 1498 }
1499
1500 /* SACK enhanced FRTO (RFC4138, Appendix B): Clearing correct
1501 * due to in-order walk
1502 */
1503 if (after(end_seq, tp->frto_highmark))
1504 flag &= ~FLAG_ONLY_ORIG_SACKED;
1506 } 1505 }
1507 1506
1508 if (tp->retrans_out && 1507 if (tp->retrans_out &&