aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/net/tcp.h4
-rw-r--r--net/ipv4/tcp.c1
-rw-r--r--net/ipv4/tcp_input.c3
-rw-r--r--net/ipv4/tcp_output.c7
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 }