mirror of
https://github.com/torvalds/linux.git
synced 2024-11-17 09:31:50 +00:00
udp: use limited socket backlog
Make udp adapt to the limited socket backlog change. Cc: "David S. Miller" <davem@davemloft.net> Cc: Alexey Kuznetsov <kuznet@ms2.inr.ac.ru> Cc: "Pekka Savola (ipv6)" <pekkas@netcore.fi> Cc: Patrick McHardy <kaber@trash.net> Signed-off-by: Zhu Yi <yi.zhu@intel.com> Acked-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6b03a53a5a
commit
55349790d7
@ -1371,8 +1371,10 @@ int udp_queue_rcv_skb(struct sock *sk, struct sk_buff *skb)
|
|||||||
bh_lock_sock(sk);
|
bh_lock_sock(sk);
|
||||||
if (!sock_owned_by_user(sk))
|
if (!sock_owned_by_user(sk))
|
||||||
rc = __udp_queue_rcv_skb(sk, skb);
|
rc = __udp_queue_rcv_skb(sk, skb);
|
||||||
else
|
else if (sk_add_backlog_limited(sk, skb)) {
|
||||||
sk_add_backlog(sk, skb);
|
bh_unlock_sock(sk);
|
||||||
|
goto drop;
|
||||||
|
}
|
||||||
bh_unlock_sock(sk);
|
bh_unlock_sock(sk);
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
|
@ -583,16 +583,20 @@ static void flush_stack(struct sock **stack, unsigned int count,
|
|||||||
bh_lock_sock(sk);
|
bh_lock_sock(sk);
|
||||||
if (!sock_owned_by_user(sk))
|
if (!sock_owned_by_user(sk))
|
||||||
udpv6_queue_rcv_skb(sk, skb1);
|
udpv6_queue_rcv_skb(sk, skb1);
|
||||||
else
|
else if (sk_add_backlog_limited(sk, skb1)) {
|
||||||
sk_add_backlog(sk, skb1);
|
kfree_skb(skb1);
|
||||||
|
bh_unlock_sock(sk);
|
||||||
|
goto drop;
|
||||||
|
}
|
||||||
bh_unlock_sock(sk);
|
bh_unlock_sock(sk);
|
||||||
} else {
|
continue;
|
||||||
atomic_inc(&sk->sk_drops);
|
|
||||||
UDP6_INC_STATS_BH(sock_net(sk),
|
|
||||||
UDP_MIB_RCVBUFERRORS, IS_UDPLITE(sk));
|
|
||||||
UDP6_INC_STATS_BH(sock_net(sk),
|
|
||||||
UDP_MIB_INERRORS, IS_UDPLITE(sk));
|
|
||||||
}
|
}
|
||||||
|
drop:
|
||||||
|
atomic_inc(&sk->sk_drops);
|
||||||
|
UDP6_INC_STATS_BH(sock_net(sk),
|
||||||
|
UDP_MIB_RCVBUFERRORS, IS_UDPLITE(sk));
|
||||||
|
UDP6_INC_STATS_BH(sock_net(sk),
|
||||||
|
UDP_MIB_INERRORS, IS_UDPLITE(sk));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
@ -754,8 +758,12 @@ int __udp6_lib_rcv(struct sk_buff *skb, struct udp_table *udptable,
|
|||||||
bh_lock_sock(sk);
|
bh_lock_sock(sk);
|
||||||
if (!sock_owned_by_user(sk))
|
if (!sock_owned_by_user(sk))
|
||||||
udpv6_queue_rcv_skb(sk, skb);
|
udpv6_queue_rcv_skb(sk, skb);
|
||||||
else
|
else if (sk_add_backlog_limited(sk, skb)) {
|
||||||
sk_add_backlog(sk, skb);
|
atomic_inc(&sk->sk_drops);
|
||||||
|
bh_unlock_sock(sk);
|
||||||
|
sock_put(sk);
|
||||||
|
goto discard;
|
||||||
|
}
|
||||||
bh_unlock_sock(sk);
|
bh_unlock_sock(sk);
|
||||||
sock_put(sk);
|
sock_put(sk);
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user