aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/ipv4/tcp_ipv4.c6
-rw-r--r--net/ipv6/tcp_ipv6.c6
2 files changed, 8 insertions, 4 deletions
diff --git a/net/ipv4/tcp_ipv4.c b/net/ipv4/tcp_ipv4.c
index 65b8ebfd078a..febfe1586e19 100644
--- a/net/ipv4/tcp_ipv4.c
+++ b/net/ipv4/tcp_ipv4.c
@@ -1677,8 +1677,10 @@ process:
1677 if (!tcp_prequeue(sk, skb)) 1677 if (!tcp_prequeue(sk, skb))
1678 ret = tcp_v4_do_rcv(sk, skb); 1678 ret = tcp_v4_do_rcv(sk, skb);
1679 } 1679 }
1680 } else 1680 } else if (sk_add_backlog_limited(sk, skb)) {
1681 sk_add_backlog(sk, skb); 1681 bh_unlock_sock(sk);
1682 goto discard_and_relse;
1683 }
1682 bh_unlock_sock(sk); 1684 bh_unlock_sock(sk);
1683 1685
1684 sock_put(sk); 1686 sock_put(sk);
diff --git a/net/ipv6/tcp_ipv6.c b/net/ipv6/tcp_ipv6.c
index febfd595a40d..d89f405528c2 100644
--- a/net/ipv6/tcp_ipv6.c
+++ b/net/ipv6/tcp_ipv6.c
@@ -1732,8 +1732,10 @@ process:
1732 if (!tcp_prequeue(sk, skb)) 1732 if (!tcp_prequeue(sk, skb))
1733 ret = tcp_v6_do_rcv(sk, skb); 1733 ret = tcp_v6_do_rcv(sk, skb);
1734 } 1734 }
1735 } else 1735 } else if (sk_add_backlog_limited(sk, skb)) {
1736 sk_add_backlog(sk, skb); 1736 bh_unlock_sock(sk);
1737 goto discard_and_relse;
1738 }
1737 bh_unlock_sock(sk); 1739 bh_unlock_sock(sk);
1738 1740
1739 sock_put(sk); 1741 sock_put(sk);