diff options
author | julian <julian@FreeBSD.org> | 2001-02-28 18:49:09 +0000 |
---|---|---|
committer | julian <julian@FreeBSD.org> | 2001-02-28 18:49:09 +0000 |
commit | cceb0beb355fd5a9640d74d01c537bd0067dc01c (patch) | |
tree | 8243ef9cfe76164c147d95a268bc80bbed3f9eec /sys/netgraph/ng_base.c | |
parent | 68b225051bfb5632ab79f2bd176479264331ff1a (diff) | |
download | FreeBSD-src-cceb0beb355fd5a9640d74d01c537bd0067dc01c.zip FreeBSD-src-cceb0beb355fd5a9640d74d01c537bd0067dc01c.tar.gz |
Shuffle netgraph mutexes a bit and hold a reference on a node
from the function that is calling the destructor.
Diffstat (limited to 'sys/netgraph/ng_base.c')
-rw-r--r-- | sys/netgraph/ng_base.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/sys/netgraph/ng_base.c b/sys/netgraph/ng_base.c index dbcc208..4c681ec 100644 --- a/sys/netgraph/ng_base.c +++ b/sys/netgraph/ng_base.c @@ -3269,13 +3269,13 @@ ngintr(void) item = ng_dequeue(&node->nd_input_queue); if (item == NULL) { mtx_unlock_spin(&node->nd_input_queue.q_mtx); - NG_NODE_UNREF(node); break; /* go look for another node */ } else { mtx_unlock_spin(&node->nd_input_queue.q_mtx); ng_apply_item(item); } } + NG_NODE_UNREF(node); } } @@ -3544,7 +3544,8 @@ ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) return (ENOMEM); } item->el_flags = NGQF_FN | NGQF_WRITER; - NG_NODE_REF(node); + NG_NODE_REF(node); /* One for us */ + NG_NODE_REF(node); /* and one for the item */ NGI_SET_NODE(item, node); if (hook) { NG_HOOK_REF(hook); @@ -3554,6 +3555,7 @@ ng_send_fn(node_p node, hook_p hook, ng_item_fn *fn, void * arg1, int arg2) NGI_ARG1(item) = arg1; NGI_ARG2(item) = arg2; return (ng_snd_item(item, 0)); + NG_NODE_UNREF(node); } /* |