- Merge all the ng_send_fn2* functions into one - ng_send_fn2(),
removing some copy&pasted code. - Reduce copy and paste in ng_apply_item(). - Resurrect ng_send_fn() as a valid symbol, not a define. Reviewed by: mav, julian
This commit is contained in:
parent
a65c7c8bdb
commit
6cd20c281d
@ -1110,22 +1110,12 @@ int ng_rmhook_self(hook_p hook); /* if a node wants to kill a hook */
|
|||||||
int ng_rmnode_self(node_p here); /* if a node wants to suicide */
|
int ng_rmnode_self(node_p here); /* if a node wants to suicide */
|
||||||
int ng_rmtype(struct ng_type *tp);
|
int ng_rmtype(struct ng_type *tp);
|
||||||
int ng_snd_item(item_p item, int queue);
|
int ng_snd_item(item_p item, int queue);
|
||||||
int ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn,
|
int ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void *arg1,
|
||||||
|
int arg2);
|
||||||
|
int ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn, void *arg1,
|
||||||
|
int arg2, int flags);
|
||||||
|
int ng_send_fn2(node_p node, hook_p hook, item_p pitem, ng_item_fn2 *fn,
|
||||||
void *arg1, int arg2, int flags);
|
void *arg1, int arg2, int flags);
|
||||||
#define ng_send_fn(node, hook, fn, arg1, arg2) \
|
|
||||||
ng_send_fn1(node, hook, fn, arg1, arg2, NG_NOFLAGS)
|
|
||||||
int ng_send_fn21(node_p node, hook_p hook, ng_item_fn2 *fn,
|
|
||||||
void *arg1, int arg2, int flags);
|
|
||||||
#define ng_send_fn2(node, hook, fn, arg1, arg2) \
|
|
||||||
ng_send_fn21(node, hook, fn, arg1, arg2, NG_NOFLAGS)
|
|
||||||
int ng_send_fn21_cont(item_p item, node_p node, hook_p hook, ng_item_fn2 *fn,
|
|
||||||
void *arg1, int arg2, int flags);
|
|
||||||
#define ng_send_fn2_cont(item, node, hook, fn, arg1, arg2) \
|
|
||||||
ng_send_fn21_cont(item, node, hook, fn, arg1, arg2, NG_NOFLAGS)
|
|
||||||
int ng_send_fn21_fwd(item_p item, node_p node, hook_p hook, ng_item_fn2 *fn,
|
|
||||||
void *arg1, int arg2, int flags);
|
|
||||||
#define ng_send_fn2_fwd(item, node, hook, fn, arg1, arg2) \
|
|
||||||
ng_send_fn21_fwd(item, node, hook, fn, arg1, arg2, NG_NOFLAGS)
|
|
||||||
int ng_uncallout(struct callout *c, node_p node);
|
int ng_uncallout(struct callout *c, node_p node);
|
||||||
int ng_callout(struct callout *c, node_p node, hook_p hook, int ticks,
|
int ng_callout(struct callout *c, node_p node, hook_p hook, int ticks,
|
||||||
ng_item_fn *fn, void * arg1, int arg2);
|
ng_item_fn *fn, void * arg1, int arg2);
|
||||||
@ -1135,7 +1125,9 @@ int ng_callout(struct callout *c, node_p node, hook_p hook, int ticks,
|
|||||||
#define NG_NOFLAGS 0x00000000 /* no special options */
|
#define NG_NOFLAGS 0x00000000 /* no special options */
|
||||||
#define NG_QUEUE 0x00000001 /* enqueue item, don't dispatch */
|
#define NG_QUEUE 0x00000001 /* enqueue item, don't dispatch */
|
||||||
#define NG_WAITOK 0x00000002 /* use M_WAITOK, etc. */
|
#define NG_WAITOK 0x00000002 /* use M_WAITOK, etc. */
|
||||||
|
/* XXXGL: NG_PROGRESS unused since ng_base.c rev. 1.136. Should be deleted? */
|
||||||
#define NG_PROGRESS 0x00000004 /* return EINPROGRESS if queued */
|
#define NG_PROGRESS 0x00000004 /* return EINPROGRESS if queued */
|
||||||
|
#define NG_REUSE_ITEM 0x00000008 /* supplied item should be reused */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* prototypes the user should DEFINITELY not use directly
|
* prototypes the user should DEFINITELY not use directly
|
||||||
|
@ -1351,8 +1351,8 @@ ng_con_part2(node_p node, item_p item, hook_p hook)
|
|||||||
}
|
}
|
||||||
mtx_unlock(&ng_topo_mtx);
|
mtx_unlock(&ng_topo_mtx);
|
||||||
|
|
||||||
if ((error = ng_send_fn2_fwd(item, peer->hk_node, peer,
|
if ((error = ng_send_fn2(peer->hk_node, peer, item, &ng_con_part3,
|
||||||
&ng_con_part3, NULL, 0))) {
|
NULL, 0, NG_REUSE_ITEM))) {
|
||||||
printf("failed in ng_con_part2(C)\n");
|
printf("failed in ng_con_part2(C)\n");
|
||||||
ng_destroy_hook(hook); /* also zaps peer */
|
ng_destroy_hook(hook); /* also zaps peer */
|
||||||
return (error); /* item was consumed. */
|
return (error); /* item was consumed. */
|
||||||
@ -1403,8 +1403,8 @@ ng_con_nodes(item_p item, node_p node, const char *name,
|
|||||||
* Procesing continues in that function in the lock context of
|
* Procesing continues in that function in the lock context of
|
||||||
* the other node.
|
* the other node.
|
||||||
*/
|
*/
|
||||||
if ((error = ng_send_fn2_cont(item, node2, hook2,
|
if ((error = ng_send_fn2(node2, hook2, item, &ng_con_part2, NULL, 0,
|
||||||
&ng_con_part2, NULL, 0))) {
|
NG_NOFLAGS))) {
|
||||||
printf("failed in ng_con_nodes(): %d\n", error);
|
printf("failed in ng_con_nodes(): %d\n", error);
|
||||||
ng_destroy_hook(hook); /* also zaps peer */
|
ng_destroy_hook(hook); /* also zaps peer */
|
||||||
}
|
}
|
||||||
@ -2540,23 +2540,6 @@ ng_apply_item(node_p node, item_p item, int rw)
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case NGQF_FN:
|
case NGQF_FN:
|
||||||
/*
|
|
||||||
* We have to implicitly trust the hook,
|
|
||||||
* as some of these are used for system purposes
|
|
||||||
* where the hook is invalid. In the case of
|
|
||||||
* the shutdown message we allow it to hit
|
|
||||||
* even if the node is invalid.
|
|
||||||
*/
|
|
||||||
if ((NG_NODE_NOT_VALID(node))
|
|
||||||
&& (NGI_FN(item) != &ng_rmnode)) {
|
|
||||||
TRAP_ERROR();
|
|
||||||
error = EINVAL;
|
|
||||||
NG_FREE_ITEM(item);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
(*NGI_FN(item))(node, hook, NGI_ARG1(item), NGI_ARG2(item));
|
|
||||||
NG_FREE_ITEM(item);
|
|
||||||
break;
|
|
||||||
case NGQF_FN2:
|
case NGQF_FN2:
|
||||||
/*
|
/*
|
||||||
* We have to implicitly trust the hook,
|
* We have to implicitly trust the hook,
|
||||||
@ -2572,7 +2555,12 @@ ng_apply_item(node_p node, item_p item, int rw)
|
|||||||
NG_FREE_ITEM(item);
|
NG_FREE_ITEM(item);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
error = (*NGI_FN2(item))(node, item, hook);
|
if ((item->el_flags & NGQF_TYPE) == NGQF_FN) {
|
||||||
|
(*NGI_FN(item))(node, hook, NGI_ARG1(item),
|
||||||
|
NGI_ARG2(item));
|
||||||
|
NG_FREE_ITEM(item);
|
||||||
|
} else /* it is NGQF_FN2 */
|
||||||
|
error = (*NGI_FN2(item))(node, item, hook);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
@ -3692,6 +3680,13 @@ ng_package_msg_self(node_p here, hook_p hook, struct ng_mesg *msg)
|
|||||||
* Send ng_item_fn function call to the specified node.
|
* Send ng_item_fn function call to the specified node.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
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, NG_NOFLAGS);
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2,
|
ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2,
|
||||||
int flags)
|
int flags)
|
||||||
@ -3715,70 +3710,32 @@ ng_send_fn1(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Send ng_item_fn2 function call to the specified.
|
* Send ng_item_fn2 function call to the specified node.
|
||||||
|
*
|
||||||
|
* If an optional pitem parameter is supplied, its apply
|
||||||
|
* callback will be copied to the new item. If also NG_REUSE_ITEM
|
||||||
|
* flag is set, no new item will be allocated, but pitem will
|
||||||
|
* be used.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
int
|
int
|
||||||
ng_send_fn21(node_p node, hook_p hook, ng_item_fn2 *fn, void * arg1, int arg2,
|
ng_send_fn2(node_p node, hook_p hook, item_p pitem, ng_item_fn2 *fn, void *arg1,
|
||||||
int flags)
|
int arg2, int flags)
|
||||||
{
|
{
|
||||||
item_p item;
|
item_p item;
|
||||||
|
|
||||||
if ((item = ng_getqblk(flags)) == NULL) {
|
KASSERT((pitem != NULL || (flags & NG_REUSE_ITEM) == 0),
|
||||||
return (ENOMEM);
|
("%s: NG_REUSE_ITEM but no pitem", __func__));
|
||||||
}
|
|
||||||
item->el_flags = NGQF_FN2 | NGQF_WRITER;
|
/*
|
||||||
NG_NODE_REF(node); /* and one for the item */
|
* Allocate a new item if no supplied or
|
||||||
NGI_SET_NODE(item, node);
|
* if we can't use supplied one.
|
||||||
if (hook) {
|
*/
|
||||||
NG_HOOK_REF(hook);
|
if (pitem == NULL || (flags & NG_REUSE_ITEM) == 0) {
|
||||||
NGI_SET_HOOK(item, hook);
|
if ((item = ng_getqblk(flags)) == NULL)
|
||||||
}
|
return (ENOMEM);
|
||||||
NGI_FN2(item) = fn;
|
} else
|
||||||
NGI_ARG1(item) = arg1;
|
item = pitem;
|
||||||
NGI_ARG2(item) = arg2;
|
|
||||||
return(ng_snd_item(item, flags));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Send ng_item_fn2 function call to the specified node
|
|
||||||
* with copying apply pointer from specified item.
|
|
||||||
* Passed item left untouched.
|
|
||||||
*/
|
|
||||||
|
|
||||||
int
|
|
||||||
ng_send_fn21_cont(item_p pitem, node_p node, hook_p hook,
|
|
||||||
ng_item_fn2 *fn, void * arg1, int arg2, int flags)
|
|
||||||
{
|
|
||||||
item_p item;
|
|
||||||
|
|
||||||
if ((item = ng_getqblk(flags)) == NULL) {
|
|
||||||
return (ENOMEM);
|
|
||||||
}
|
|
||||||
item->el_flags = NGQF_FN2 | NGQF_WRITER;
|
|
||||||
NG_NODE_REF(node); /* and one for the item */
|
|
||||||
NGI_SET_NODE(item, node);
|
|
||||||
if (hook) {
|
|
||||||
NG_HOOK_REF(hook);
|
|
||||||
NGI_SET_HOOK(item, hook);
|
|
||||||
}
|
|
||||||
NGI_FN2(item) = fn;
|
|
||||||
NGI_ARG1(item) = arg1;
|
|
||||||
NGI_ARG2(item) = arg2;
|
|
||||||
item->apply = pitem->apply;
|
|
||||||
return(ng_snd_item(item, flags));
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Send ng_item_fn2 function call to the specified node
|
|
||||||
* reusing item including apply pointer.
|
|
||||||
* Passed item is consumed.
|
|
||||||
*/
|
|
||||||
|
|
||||||
int
|
|
||||||
ng_send_fn21_fwd(item_p item, node_p node, hook_p hook,
|
|
||||||
ng_item_fn2 *fn, void * arg1, int arg2, int flags)
|
|
||||||
{
|
|
||||||
item->el_flags = NGQF_FN2 | NGQF_WRITER;
|
item->el_flags = NGQF_FN2 | NGQF_WRITER;
|
||||||
NG_NODE_REF(node); /* and one for the item */
|
NG_NODE_REF(node); /* and one for the item */
|
||||||
NGI_SET_NODE(item, node);
|
NGI_SET_NODE(item, node);
|
||||||
@ -3789,6 +3746,8 @@ ng_send_fn21_fwd(item_p item, node_p node, hook_p hook,
|
|||||||
NGI_FN2(item) = fn;
|
NGI_FN2(item) = fn;
|
||||||
NGI_ARG1(item) = arg1;
|
NGI_ARG1(item) = arg1;
|
||||||
NGI_ARG2(item) = arg2;
|
NGI_ARG2(item) = arg2;
|
||||||
|
if (pitem != NULL && (flags & NG_REUSE_ITEM) == 0)
|
||||||
|
item->apply = pitem->apply;
|
||||||
return(ng_snd_item(item, flags));
|
return(ng_snd_item(item, flags));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user