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
This commit is contained in:
parent
827396ba31
commit
3fabe28bdc
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user