diff options
author | Evgeniy Polyakov <johnpol@2ka.mipt.ru> | 2006-12-18 01:53:58 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2006-12-18 01:53:58 -0800 |
commit | a240d9f1d8e6421cb970632b93e71b2f66c2cd70 (patch) | |
tree | e3d103d3c3637c074d0a2bf48fbcb07dce04b70a /drivers/connector/connector.c | |
parent | 14fb8a764786e37ac26a2175638115f21980e5a3 (diff) | |
download | kernel_samsung_aries-a240d9f1d8e6421cb970632b93e71b2f66c2cd70.zip kernel_samsung_aries-a240d9f1d8e6421cb970632b93e71b2f66c2cd70.tar.gz kernel_samsung_aries-a240d9f1d8e6421cb970632b93e71b2f66c2cd70.tar.bz2 |
[CONNECTOR]: Replace delayed work with usual work queue.
Signed-off-by: Evgeniy Polyakov <johnpol@2ka.mipt.ru>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/connector/connector.c')
-rw-r--r-- | drivers/connector/connector.c | 16 |
1 files changed, 7 insertions, 9 deletions
diff --git a/drivers/connector/connector.c b/drivers/connector/connector.c index 4cec1a8..a44db75 100644 --- a/drivers/connector/connector.c +++ b/drivers/connector/connector.c @@ -135,16 +135,15 @@ static int cn_call_callback(struct cn_msg *msg, void (*destruct_data)(void *), v spin_lock_bh(&dev->cbdev->queue_lock); list_for_each_entry(__cbq, &dev->cbdev->queue_list, callback_entry) { if (cn_cb_equal(&__cbq->id.id, &msg->id)) { - if (likely(!work_pending(&__cbq->work.work) && + if (likely(!work_pending(&__cbq->work) && __cbq->data.ddata == NULL)) { __cbq->data.callback_priv = msg; __cbq->data.ddata = data; __cbq->data.destruct_data = destruct_data; - if (queue_delayed_work( - dev->cbdev->cn_queue, - &__cbq->work, 0)) + if (queue_work(dev->cbdev->cn_queue, + &__cbq->work)) err = 0; } else { struct cn_callback_data *d; @@ -158,12 +157,11 @@ static int cn_call_callback(struct cn_msg *msg, void (*destruct_data)(void *), v d->destruct_data = destruct_data; d->free = __cbq; - INIT_DELAYED_WORK(&__cbq->work, - &cn_queue_wrapper); + INIT_WORK(&__cbq->work, + &cn_queue_wrapper); - if (queue_delayed_work( - dev->cbdev->cn_queue, - &__cbq->work, 0)) + if (queue_work(dev->cbdev->cn_queue, + &__cbq->work)) err = 0; else { kfree(__cbq); |