From cbfa8be50b1ff837df58c0dd07675578a2fd5bc6 Mon Sep 17 00:00:00 2001 From: glebius Date: Fri, 13 May 2005 11:35:02 +0000 Subject: Since there is no way to queue a function call to node, create ng_queue_fn() - a queue version of ng_send_fn(). --- sys/netgraph/ng_base.c | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) (limited to 'sys/netgraph/ng_base.c') diff --git a/sys/netgraph/ng_base.c b/sys/netgraph/ng_base.c index 3a87a7f..6747761 100644 --- a/sys/netgraph/ng_base.c +++ b/sys/netgraph/ng_base.c @@ -3568,8 +3568,9 @@ ng_package_msg_self(node_p here, hook_p hook, struct ng_mesg *msg) return (item); } -int -ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) +static __inline int +ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2, + int queue) { item_p item; @@ -3586,7 +3587,19 @@ ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) NGI_FN(item) = fn; NGI_ARG1(item) = arg1; NGI_ARG2(item) = arg2; - return(ng_snd_item(item, 0)); + return(ng_snd_item(item, queue)); +} + +int +ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) +{ + return (ng_send_fn1(node, hook, fn, arg1, arg2, 0)); +} + +int +ng_queue_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) +{ + return (ng_send_fn1(node, hook, fn, arg1, arg2, 1)); } /* -- cgit v1.1