summaryrefslogtreecommitdiffstats
path: root/sys/netinet/udp_usrreq.c
diff options
context:
space:
mode:
authorblambert <blambert@openbsd.org>2011-04-03 16:09:09 +0000
committerblambert <blambert@openbsd.org>2011-04-03 16:09:09 +0000
commit2f7bc713767d689946e30da615ba6680403d14fd (patch)
tree4e7db8e55eb402e7bd417712db717f22ff2086a6 /sys/netinet/udp_usrreq.c
parentdon't rely on implict net/route.h inclusion via pf, claudio ok (diff)
downloadwireguard-openbsd-2f7bc713767d689946e30da615ba6680403d14fd.tar.xz
wireguard-openbsd-2f7bc713767d689946e30da615ba6680403d14fd.zip
Don't attempt to enqueue mbufs on sockets marked as SS_CANTRCVMORE, as
was done earlier for routing sockets. ok claudio@
Diffstat (limited to 'sys/netinet/udp_usrreq.c')
-rw-r--r--sys/netinet/udp_usrreq.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/netinet/udp_usrreq.c b/sys/netinet/udp_usrreq.c
index 1fa7d064d26..6db0e712d09 100644
--- a/sys/netinet/udp_usrreq.c
+++ b/sys/netinet/udp_usrreq.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: udp_usrreq.c,v 1.138 2010/09/24 14:50:30 hsuenaga Exp $ */
+/* $OpenBSD: udp_usrreq.c,v 1.139 2011/04/03 16:09:09 blambert Exp $ */
/* $NetBSD: udp_usrreq.c,v 1.28 1996/03/16 23:54:03 christos Exp $ */
/*
@@ -442,6 +442,8 @@ udp_input(struct mbuf *m, ...)
*/
last = NULL;
CIRCLEQ_FOREACH(inp, &udbtable.inpt_queue, inp_queue) {
+ if (inp->inp_socket->so_state & SS_CANTRCVMORE)
+ continue;
#ifdef INET6
/* don't accept it if AF does not match */
if (ip6 && !(inp->inp_flags & INP_IPV6))