aboutsummaryrefslogtreecommitdiffstats
path: root/net/ipv4/tcp_input.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/ipv4/tcp_input.c')
-rw-r--r--net/ipv4/tcp_input.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c
index c0e8f2b1fa7e..31294b52ad42 100644
--- a/net/ipv4/tcp_input.c
+++ b/net/ipv4/tcp_input.c
@@ -1245,7 +1245,7 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1245 int num_sacks = (ptr[1] - TCPOLEN_SACK_BASE)>>3; 1245 int num_sacks = (ptr[1] - TCPOLEN_SACK_BASE)>>3;
1246 int reord = tp->packets_out; 1246 int reord = tp->packets_out;
1247 int prior_fackets; 1247 int prior_fackets;
1248 u32 highest_sack_end_seq = tp->lost_retrans_low; 1248 u32 highest_sack_end_seq;
1249 int flag = 0; 1249 int flag = 0;
1250 int found_dup_sack = 0; 1250 int found_dup_sack = 0;
1251 int cached_fack_count; 1251 int cached_fack_count;
@@ -1256,7 +1256,7 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1256 if (!tp->sacked_out) { 1256 if (!tp->sacked_out) {
1257 if (WARN_ON(tp->fackets_out)) 1257 if (WARN_ON(tp->fackets_out))
1258 tp->fackets_out = 0; 1258 tp->fackets_out = 0;
1259 tp->highest_sack = tp->snd_una; 1259 tp->highest_sack = tcp_write_queue_head(sk);
1260 } 1260 }
1261 prior_fackets = tp->fackets_out; 1261 prior_fackets = tp->fackets_out;
1262 1262
@@ -1483,10 +1483,9 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1483 if (fack_count > tp->fackets_out) 1483 if (fack_count > tp->fackets_out)
1484 tp->fackets_out = fack_count; 1484 tp->fackets_out = fack_count;
1485 1485
1486 if (after(TCP_SKB_CB(skb)->seq, tp->highest_sack)) { 1486 if (after(TCP_SKB_CB(skb)->seq, tcp_highest_sack_seq(tp)))
1487 tp->highest_sack = TCP_SKB_CB(skb)->seq; 1487 tp->highest_sack = skb;
1488 highest_sack_end_seq = TCP_SKB_CB(skb)->end_seq; 1488
1489 }
1490 } else { 1489 } else {
1491 if (dup_sack && (sacked&TCPCB_RETRANS)) 1490 if (dup_sack && (sacked&TCPCB_RETRANS))
1492 reord = min(fack_count, reord); 1491 reord = min(fack_count, reord);
@@ -1514,6 +1513,7 @@ tcp_sacktag_write_queue(struct sock *sk, struct sk_buff *ack_skb, u32 prior_snd_
1514 flag &= ~FLAG_ONLY_ORIG_SACKED; 1513 flag &= ~FLAG_ONLY_ORIG_SACKED;
1515 } 1514 }
1516 1515
1516 highest_sack_end_seq = TCP_SKB_CB(tp->highest_sack)->end_seq;
1517 if (tcp_is_fack(tp) && tp->retrans_out && 1517 if (tcp_is_fack(tp) && tp->retrans_out &&
1518 after(highest_sack_end_seq, tp->lost_retrans_low) && 1518 after(highest_sack_end_seq, tp->lost_retrans_low) &&
1519 icsk->icsk_ca_state == TCP_CA_Recovery) 1519 icsk->icsk_ca_state == TCP_CA_Recovery)