diff options
-rw-r--r-- | include/net/tcp.h | 4 | ||||
-rw-r--r-- | net/ipv4/tcp.c | 1 | ||||
-rw-r--r-- | net/ipv4/tcp_input.c | 3 | ||||
-rw-r--r-- | net/ipv4/tcp_output.c | 7 |
4 files changed, 4 insertions, 11 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h index 6a732d4919fe..48081ada92a7 100644 --- a/include/net/tcp.h +++ b/include/net/tcp.h | |||
@@ -578,10 +578,6 @@ struct tcp_skb_cb { | |||
578 | #define TCPCB_EVER_RETRANS 0x80 /* Ever retransmitted frame */ | 578 | #define TCPCB_EVER_RETRANS 0x80 /* Ever retransmitted frame */ |
579 | #define TCPCB_RETRANS (TCPCB_SACKED_RETRANS|TCPCB_EVER_RETRANS) | 579 | #define TCPCB_RETRANS (TCPCB_SACKED_RETRANS|TCPCB_EVER_RETRANS) |
580 | 580 | ||
581 | #define TCPCB_URG 0x20 /* Urgent pointer advanced here */ | ||
582 | |||
583 | #define TCPCB_AT_TAIL (TCPCB_URG) | ||
584 | |||
585 | __u16 urg_ptr; /* Valid w/URG flags is set. */ | 581 | __u16 urg_ptr; /* Valid w/URG flags is set. */ |
586 | __u32 ack_seq; /* Sequence number ACK'd */ | 582 | __u32 ack_seq; /* Sequence number ACK'd */ |
587 | }; | 583 | }; |
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 2cbfa6df7976..34085e3a4096 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
@@ -497,7 +497,6 @@ static inline void tcp_mark_urg(struct tcp_sock *tp, int flags, | |||
497 | if (flags & MSG_OOB) { | 497 | if (flags & MSG_OOB) { |
498 | tp->urg_mode = 1; | 498 | tp->urg_mode = 1; |
499 | tp->snd_up = tp->write_seq; | 499 | tp->snd_up = tp->write_seq; |
500 | TCP_SKB_CB(skb)->sacked |= TCPCB_URG; | ||
501 | } | 500 | } |
502 | } | 501 | } |
503 | 502 | ||
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index 7bac1fac065f..1e7fd8113663 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c | |||
@@ -2821,8 +2821,7 @@ static int tcp_clean_rtx_queue(struct sock *sk, int prior_fackets) | |||
2821 | if (sacked & TCPCB_LOST) | 2821 | if (sacked & TCPCB_LOST) |
2822 | tp->lost_out -= acked_pcount; | 2822 | tp->lost_out -= acked_pcount; |
2823 | 2823 | ||
2824 | if (unlikely((sacked & TCPCB_URG) && tp->urg_mode && | 2824 | if (unlikely(tp->urg_mode && !before(end_seq, tp->snd_up))) |
2825 | !before(end_seq, tp->snd_up))) | ||
2826 | tp->urg_mode = 0; | 2825 | tp->urg_mode = 0; |
2827 | 2826 | ||
2828 | tp->packets_out -= acked_pcount; | 2827 | tp->packets_out -= acked_pcount; |
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 | } |