|
@@ -2407,6 +2407,8 @@ int tcp_retransmit_skb(struct sock *sk, struct sk_buff *skb)
|
|
|
* see tcp_input.c tcp_sacktag_write_queue().
|
|
|
*/
|
|
|
TCP_SKB_CB(skb)->ack_seq = tp->snd_nxt;
|
|
|
+ } else {
|
|
|
+ NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPRETRANSFAIL);
|
|
|
}
|
|
|
return err;
|
|
|
}
|
|
@@ -2528,10 +2530,9 @@ begin_fwd:
|
|
|
if (sacked & (TCPCB_SACKED_ACKED|TCPCB_SACKED_RETRANS))
|
|
|
continue;
|
|
|
|
|
|
- if (tcp_retransmit_skb(sk, skb)) {
|
|
|
- NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_TCPRETRANSFAIL);
|
|
|
+ if (tcp_retransmit_skb(sk, skb))
|
|
|
return;
|
|
|
- }
|
|
|
+
|
|
|
NET_INC_STATS_BH(sock_net(sk), mib_idx);
|
|
|
|
|
|
if (tcp_in_cwnd_reduction(sk))
|