Preventing ng_callout() timeouts to trigger packet queuing

Karim Fodil-Lemelin fodillemlinkarim at gmail.com
Wed Apr 9 19:16:43 UTC 2014


Hi List,

I'm calling out to the general wisdom ... I have seen an issue in 
netgraph where, if called, a callout routine registered by ng_callout() 
will trigger packet queuing inside the worklist of netgraph since 
ng_callout() makes my node suddenly a WRITER node (therefore non 
reentrant) for the duration of the call.

So as soon as the callout function returns, all following packets will 
get directly passed to the node again and when the ngintr thread gets 
executed then only then will I get the queued packets. This introduces 
out of order packets in the flow. I am using the current patch below to 
solve the issue and I am wondering if there is anything wrong with it 
(and maybe contribute back :):


@@ -3632,7 +3632,7 @@ ng_callout(struct callout *c, node_p node, hook_p 
hook, int ticks,
         if ((item = ng_alloc_item(NGQF_FN, NG_NOFLAGS)) == NULL)
                 return (ENOMEM);

-       item->el_flags |= NGQF_WRITER;
+       item->el_flags = NGQF_READER;
         NG_NODE_REF(node);              /* and one for the item */
         NGI_SET_NODE(item, node);
         if (hook) {


Best regards,

Karim.


More information about the freebsd-net mailing list