diff options
| author | Jeff Garzik <jgarzik@pobox.com> | 2005-09-24 00:25:02 -0400 |
|---|---|---|
| committer | Jeff Garzik <jgarzik@pobox.com> | 2005-09-24 00:25:02 -0400 |
| commit | c1d9728ecc5b560465df3c0c0d3b3825c2710b40 (patch) | |
| tree | d0abb5c923a7a3eca2d4b2c3e1964bf484870909 /net/ipv4/tcp_output.c | |
| parent | 165415f700b0c77fa1f8db6198f48582639adf78 (diff) | |
| parent | 87e807b6c461bbd449496a4c3ab78ab164a4ba97 (diff) | |
Merge /spare/repo/linux-2.6/
Diffstat (limited to 'net/ipv4/tcp_output.c')
| -rw-r--r-- | net/ipv4/tcp_output.c | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/net/ipv4/tcp_output.c b/net/ipv4/tcp_output.c index c10e4435e3b1..d6e3d269e906 100644 --- a/net/ipv4/tcp_output.c +++ b/net/ipv4/tcp_output.c | |||
| @@ -435,6 +435,8 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss | |||
| 435 | int nsize, old_factor; | 435 | int nsize, old_factor; |
| 436 | u16 flags; | 436 | u16 flags; |
| 437 | 437 | ||
| 438 | BUG_ON(len >= skb->len); | ||
| 439 | |||
| 438 | nsize = skb_headlen(skb) - len; | 440 | nsize = skb_headlen(skb) - len; |
| 439 | if (nsize < 0) | 441 | if (nsize < 0) |
| 440 | nsize = 0; | 442 | nsize = 0; |
| @@ -459,9 +461,7 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss | |||
| 459 | flags = TCP_SKB_CB(skb)->flags; | 461 | flags = TCP_SKB_CB(skb)->flags; |
| 460 | TCP_SKB_CB(skb)->flags = flags & ~(TCPCB_FLAG_FIN|TCPCB_FLAG_PSH); | 462 | TCP_SKB_CB(skb)->flags = flags & ~(TCPCB_FLAG_FIN|TCPCB_FLAG_PSH); |
| 461 | TCP_SKB_CB(buff)->flags = flags; | 463 | TCP_SKB_CB(buff)->flags = flags; |
| 462 | TCP_SKB_CB(buff)->sacked = | 464 | TCP_SKB_CB(buff)->sacked = TCP_SKB_CB(skb)->sacked; |
| 463 | (TCP_SKB_CB(skb)->sacked & | ||
| 464 | (TCPCB_LOST | TCPCB_EVER_RETRANS | TCPCB_AT_TAIL)); | ||
| 465 | TCP_SKB_CB(skb)->sacked &= ~TCPCB_AT_TAIL; | 465 | TCP_SKB_CB(skb)->sacked &= ~TCPCB_AT_TAIL; |
| 466 | 466 | ||
| 467 | if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_HW) { | 467 | if (!skb_shinfo(skb)->nr_frags && skb->ip_summed != CHECKSUM_HW) { |
| @@ -499,11 +499,26 @@ int tcp_fragment(struct sock *sk, struct sk_buff *skb, u32 len, unsigned int mss | |||
| 499 | tcp_skb_pcount(buff); | 499 | tcp_skb_pcount(buff); |
| 500 | 500 | ||
| 501 | tp->packets_out -= diff; | 501 | tp->packets_out -= diff; |
| 502 | |||
| 503 | if (TCP_SKB_CB(skb)->sacked & TCPCB_SACKED_ACKED) | ||
| 504 | tp->sacked_out -= diff; | ||
| 505 | if (TCP_SKB_CB(skb)->sacked & TCPCB_SACKED_RETRANS) | ||
| 506 | tp->retrans_out -= diff; | ||
| 507 | |||
| 502 | if (TCP_SKB_CB(skb)->sacked & TCPCB_LOST) { | 508 | if (TCP_SKB_CB(skb)->sacked & TCPCB_LOST) { |
| 503 | tp->lost_out -= diff; | 509 | tp->lost_out -= diff; |
| 504 | tp->left_out -= diff; | 510 | tp->left_out -= diff; |
| 505 | } | 511 | } |
| 512 | |||
| 506 | if (diff > 0) { | 513 | if (diff > 0) { |
| 514 | /* Adjust Reno SACK estimate. */ | ||
| 515 | if (!tp->rx_opt.sack_ok) { | ||
| 516 | tp->sacked_out -= diff; | ||
| 517 | if ((int)tp->sacked_out < 0) | ||
| 518 | tp->sacked_out = 0; | ||
| 519 | tcp_sync_left_out(tp); | ||
| 520 | } | ||
| 521 | |||
| 507 | tp->fackets_out -= diff; | 522 | tp->fackets_out -= diff; |
| 508 | if ((int)tp->fackets_out < 0) | 523 | if ((int)tp->fackets_out < 0) |
| 509 | tp->fackets_out = 0; | 524 | tp->fackets_out = 0; |
