|
@@ -218,6 +218,9 @@ _instance_destroy2(struct nfulnl_instance *inst, int lock)
|
|
|
|
|
|
spin_lock_bh(&inst->lock);
|
|
|
if (inst->skb) {
|
|
|
+ /* timer "holds" one reference (we have one more) */
|
|
|
+ if (del_timer(&inst->timer))
|
|
|
+ instance_put(inst);
|
|
|
if (inst->qlen)
|
|
|
__nfulnl_send(inst);
|
|
|
if (inst->skb) {
|
|
@@ -362,9 +365,6 @@ __nfulnl_send(struct nfulnl_instance *inst)
|
|
|
{
|
|
|
int status;
|
|
|
|
|
|
- if (timer_pending(&inst->timer))
|
|
|
- del_timer(&inst->timer);
|
|
|
-
|
|
|
if (!inst->skb)
|
|
|
return 0;
|
|
|
|
|
@@ -689,6 +689,9 @@ nfulnl_log_packet(unsigned int pf,
|
|
|
* enough room in the skb left. flush to userspace. */
|
|
|
UDEBUG("flushing old skb\n");
|
|
|
|
|
|
+ /* timer "holds" one reference (we have another one) */
|
|
|
+ if (del_timer(&inst->timer))
|
|
|
+ instance_put(inst);
|
|
|
__nfulnl_send(inst);
|
|
|
|
|
|
if (!(inst->skb = nfulnl_alloc_skb(nlbufsiz, size))) {
|