diff options
author | Ingo Molnar <mingo@elte.hu> | 2010-10-13 15:44:24 +0200 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-10-13 15:44:24 +0200 |
commit | 3d8a1a6a8af910cc2da566080d111e062a124ba6 (patch) | |
tree | 0c78b30a5c7aa083e215222989f982313c5141c0 /net/ipv4/tcp_input.c | |
parent | 1b13fe6a6e9986dbc079cbb05090be75edbffa5d (diff) | |
parent | 5d0d71569e671239ae0d905ced9b65cd843f99ee (diff) |
Merge branch 'amd-iommu/2.6.37' of git://git.kernel.org/pub/scm/linux/kernel/git/joro/linux-2.6-iommu into core/iommu
Diffstat (limited to 'net/ipv4/tcp_input.c')
-rw-r--r-- | net/ipv4/tcp_input.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/net/ipv4/tcp_input.c b/net/ipv4/tcp_input.c index e663b78a2ef..b55f60f6fcb 100644 --- a/net/ipv4/tcp_input.c +++ b/net/ipv4/tcp_input.c @@ -2545,7 +2545,8 @@ static void tcp_mark_head_lost(struct sock *sk, int packets) cnt += tcp_skb_pcount(skb); if (cnt > packets) { - if (tcp_is_sack(tp) || (oldcnt >= packets)) + if ((tcp_is_sack(tp) && !tcp_is_fack(tp)) || + (oldcnt >= packets)) break; mss = skb_shinfo(skb)->gso_size; @@ -4048,6 +4049,8 @@ static void tcp_reset(struct sock *sk) default: sk->sk_err = ECONNRESET; } + /* This barrier is coupled with smp_rmb() in tcp_poll() */ + smp_wmb(); if (!sock_flag(sk, SOCK_DEAD)) sk->sk_error_report(sk); |