summaryrefslogtreecommitdiffstats
path: root/sys/netgraph
diff options
context:
space:
mode:
authorrstone <rstone@FreeBSD.org>2012-09-27 20:12:51 +0000
committerrstone <rstone@FreeBSD.org>2012-09-27 20:12:51 +0000
commit9462cb164169ec9d8c369c666eac8bd7e7476de7 (patch)
tree2c8fe38dcfd2eb69340ca18ad589a36d059c44f4 /sys/netgraph
parent2971b4a1848640e101b8f4080426f14ec481a081 (diff)
downloadFreeBSD-src-9462cb164169ec9d8c369c666eac8bd7e7476de7.zip
FreeBSD-src-9462cb164169ec9d8c369c666eac8bd7e7476de7.tar.gz
Ensure that all cases that enqueue a netgraph item for delivery by a
ngthread properly set the item's depth to 1. In particular, prior to this change if ng_snd_item failed to acquire a lock on a node, the item's depth would not be set at all. This fix ensures that the error code from rcvmsg/ rcvdata is properly passed back to the apply callback. For example, this fixes a bug where an error from rcvmsg/rcvdata would not previously propagate back to a libnetgraph consumer when the message was queued. Reviewed by: mav MFC after: 1 month Sponsored by: Sandvine Incorporated
Diffstat (limited to 'sys/netgraph')
-rw-r--r--sys/netgraph/ng_base.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sys/netgraph/ng_base.c b/sys/netgraph/ng_base.c
index 0856e80..6143464 100644
--- a/sys/netgraph/ng_base.c
+++ b/sys/netgraph/ng_base.c
@@ -2008,6 +2008,7 @@ ng_queue_rw(node_p node, item_p item, int rw)
NGI_SET_WRITER(item);
else
NGI_SET_READER(item);
+ item->depth = 1;
NG_QUEUE_LOCK(ngq);
/* Set OP_PENDING flag and enqueue the item. */
@@ -2286,7 +2287,6 @@ ng_snd_item(item_p item, int flags)
}
if (queue) {
- item->depth = 1;
/* Put it on the queue for that node*/
ng_queue_rw(node, item, rw);
return ((flags & NG_PROGRESS) ? EINPROGRESS : 0);
OpenPOWER on IntegriCloud