diff options
Diffstat (limited to 'net/ipv4/tcp_output.c')
-rw-r--r-- | net/ipv4/tcp_output.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index 821fae271428..cd21528665f3 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
@@ -711,7 +711,6 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss | |||
711 | TCP_SKB_CB(skb)->flags = flags & ~(TCPCB_FLAG_FIN|TCPCB_FLAG_PSH); | 711 | TCP_SKB_CB(skb)->flags = flags & ~(TCPCB_FLAG_FIN|TCPCB_FLAG_PSH); |
712 | TCP_SKB_CB(buff)->flags = flags; | 712 | TCP_SKB_CB(buff)->flags = flags; |
713 | TCP_SKB_CB(buff)->sacked = TCP_SKB_CB(skb)->sacked; | 713 | TCP_SKB_CB(buff)->sacked = TCP_SKB_CB(skb)->sacked; |
714 | TCP_SKB_CB(skb)->sacked &= ~TCPCB_AT_TAIL; | ||
715 | 714 | ||
716 | if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_PARTIAL) { | 715 | if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_PARTIAL) { |
717 | /* Copy and checksum data tail into the new buffer. */ | 716 | /* Copy and checksum data tail into the new buffer. */ |
@@ -1726,7 +1725,7 @@ static void tcp_retrans_try_collapse(struct sock *sk, struct sk_buff *skb, int m | |||
1726 | /* All done, get rid of second SKB and account for it so | 1725 | /* All done, get rid of second SKB and account for it so |
1727 | * packet counting does not break. | 1726 | * packet counting does not break. |
1728 | */ | 1727 | */ |
1729 | TCP_SKB_CB(skb)->sacked |= TCP_SKB_CB(next_skb)->sacked&(TCPCB_EVER_RETRANS|TCPCB_AT_TAIL); | 1728 | TCP_SKB_CB(skb)->sacked |= TCP_SKB_CB(next_skb)->sacked & TCPCB_EVER_RETRANS; |
1730 | if (TCP_SKB_CB(next_skb)->sacked&TCPCB_SACKED_RETRANS) | 1729 | if (TCP_SKB_CB(next_skb)->sacked&TCPCB_SACKED_RETRANS) |
1731 | tp->retrans_out -= tcp_skb_pcount(next_skb); | 1730 | tp->retrans_out -= tcp_skb_pcount(next_skb); |
1732 | if (TCP_SKB_CB(next_skb)->sacked&TCPCB_LOST) | 1731 | if (TCP_SKB_CB(next_skb)->sacked&TCPCB_LOST) |
@@ -2475,7 +2474,7 @@ static int tcp_xmit_probe_skb(struct sock *sk, int urgent) | |||
2475 | skb_reserve(skb, MAX_TCP_HEADER); | 2474 | skb_reserve(skb, MAX_TCP_HEADER); |
2476 | skb->csum = 0; | 2475 | skb->csum = 0; |
2477 | TCP_SKB_CB(skb)->flags = TCPCB_FLAG_ACK; | 2476 | TCP_SKB_CB(skb)->flags = TCPCB_FLAG_ACK; |
2478 | TCP_SKB_CB(skb)->sacked = urgent; | 2477 | TCP_SKB_CB(skb)->sacked = 0; |
2479 | skb_shinfo(skb)->gso_segs = 1; | 2478 | skb_shinfo(skb)->gso_segs = 1; |
2480 | skb_shinfo(skb)->gso_size = 0; | 2479 | skb_shinfo(skb)->gso_size = 0; |
2481 | skb_shinfo(skb)->gso_type = 0; | 2480 | skb_shinfo(skb)->gso_type = 0; |
@@ -2527,7 +2526,7 @@ int tcp_write_wakeup(struct sock *sk) | |||
2527 | } else { | 2526 | } else { |
2528 | if (tp->urg_mode && | 2527 | if (tp->urg_mode && |
2529 | between(tp->snd_up, tp->snd_una+1, tp->snd_una+0xFFFF)) | 2528 | between(tp->snd_up, tp->snd_una+1, tp->snd_una+0xFFFF)) |
2530 | tcp_xmit_probe_skb(sk, TCPCB_URG); | 2529 | tcp_xmit_probe_skb(sk, 1); |
2531 | return tcp_xmit_probe_skb(sk, 0); | 2530 | return tcp_xmit_probe_skb(sk, 0); |
2532 | } | 2531 | } |
2533 | } | 2532 | } |