Commit 2be2626d authored by David S. Miller's avatar David S. Miller

[TCP]: Fix packet counting in tcp_fragment().

Do not reference the tso_factor of SKB buff until
it is initialized.
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 44eb8ff7
...@@ -473,10 +473,6 @@ static int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len) ...@@ -473,10 +473,6 @@ static int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len)
TCP_SKB_CB(buff)->sacked = TCP_SKB_CB(buff)->sacked =
(TCP_SKB_CB(skb)->sacked & (TCP_SKB_CB(skb)->sacked &
(TCPCB_LOST | TCPCB_EVER_RETRANS | TCPCB_AT_TAIL)); (TCPCB_LOST | TCPCB_EVER_RETRANS | TCPCB_AT_TAIL));
if (TCP_SKB_CB(buff)->sacked&TCPCB_LOST) {
tcp_inc_pcount(&tp->lost_out, buff);
tcp_inc_pcount(&tp->left_out, buff);
}
TCP_SKB_CB(skb)->sacked &= ~TCPCB_AT_TAIL; TCP_SKB_CB(skb)->sacked &= ~TCPCB_AT_TAIL;
if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_HW) { if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_HW) {
...@@ -503,6 +499,11 @@ static int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len) ...@@ -503,6 +499,11 @@ static int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len)
tcp_set_skb_tso_factor(skb, tp->mss_cache_std); tcp_set_skb_tso_factor(skb, tp->mss_cache_std);
tcp_set_skb_tso_factor(buff, tp->mss_cache_std); tcp_set_skb_tso_factor(buff, tp->mss_cache_std);
if (TCP_SKB_CB(buff)->sacked&TCPCB_LOST) {
tcp_inc_pcount(&tp->lost_out, buff);
tcp_inc_pcount(&tp->left_out, buff);
}
/* Link BUFF into the send queue. */ /* Link BUFF into the send queue. */
__skb_append(skb, buff); __skb_append(skb, buff);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment