From: Li Zefan Date: Fri, 11 Jan 2008 09:11:48 +0000 (-0800) Subject: CONNECTOR: Don't touch queue dev after decrement of ref count. X-Git-Tag: v2.6.23.15~54 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=57a0a0d2c27d63176040b0a0f5c8a73f4f62ec99;p=thirdparty%2Fkernel%2Fstable.git CONNECTOR: Don't touch queue dev after decrement of ref count. [CONNECTOR]: Don't touch queue dev after decrement of ref count. [ Upstream commit: cf585ae8ae9ac7287a6d078425ea32f22bf7f1f7 ] cn_queue_free_callback() will touch 'dev'(i.e. cbq->pdev), so it should be called before atomic_dec(&dev->refcnt). Signed-off-by: Li Zefan Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/connector/cn_queue.c b/drivers/connector/cn_queue.c index 296f51002b555..12ceed54ab180 100644 --- a/drivers/connector/cn_queue.c +++ b/drivers/connector/cn_queue.c @@ -99,8 +99,8 @@ int cn_queue_add_callback(struct cn_queue_dev *dev, char *name, struct cb_id *id spin_unlock_bh(&dev->queue_lock); if (found) { - atomic_dec(&dev->refcnt); cn_queue_free_callback(cbq); + atomic_dec(&dev->refcnt); return -EINVAL; }