diff options
-rw-r--r-- | include/linux/workqueue.h | 13 | ||||
-rw-r--r-- | kernel/workqueue.c | 6 |
2 files changed, 13 insertions, 6 deletions
diff --git a/include/linux/workqueue.h b/include/linux/workqueue.h index ce0719a2cfeb..5c89ac6e7f55 100644 --- a/include/linux/workqueue.h +++ b/include/linux/workqueue.h | |||
@@ -166,14 +166,21 @@ static inline int cancel_delayed_work(struct delayed_work *work) | |||
166 | return ret; | 166 | return ret; |
167 | } | 167 | } |
168 | 168 | ||
169 | extern void cancel_rearming_delayed_work(struct delayed_work *work); | 169 | extern void cancel_delayed_work_sync(struct delayed_work *work); |
170 | 170 | ||
171 | /* Obsolete. use cancel_rearming_delayed_work() */ | 171 | /* Obsolete. use cancel_delayed_work_sync() */ |
172 | static inline | 172 | static inline |
173 | void cancel_rearming_delayed_workqueue(struct workqueue_struct *wq, | 173 | void cancel_rearming_delayed_workqueue(struct workqueue_struct *wq, |
174 | struct delayed_work *work) | 174 | struct delayed_work *work) |
175 | { | 175 | { |
176 | cancel_rearming_delayed_work(work); | 176 | cancel_delayed_work_sync(work); |
177 | } | ||
178 | |||
179 | /* Obsolete. use cancel_delayed_work_sync() */ | ||
180 | static inline | ||
181 | void cancel_rearming_delayed_work(struct delayed_work *work) | ||
182 | { | ||
183 | cancel_delayed_work_sync(work); | ||
177 | } | 184 | } |
178 | 185 | ||
179 | #endif | 186 | #endif |
diff --git a/kernel/workqueue.c b/kernel/workqueue.c index 3bebf73be976..ad9656886daa 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c | |||
@@ -486,13 +486,13 @@ void cancel_work_sync(struct work_struct *work) | |||
486 | EXPORT_SYMBOL_GPL(cancel_work_sync); | 486 | EXPORT_SYMBOL_GPL(cancel_work_sync); |
487 | 487 | ||
488 | /** | 488 | /** |
489 | * cancel_rearming_delayed_work - reliably kill off a delayed work. | 489 | * cancel_delayed_work_sync - reliably kill off a delayed work. |
490 | * @dwork: the delayed work struct | 490 | * @dwork: the delayed work struct |
491 | * | 491 | * |
492 | * It is possible to use this function if @dwork rearms itself via queue_work() | 492 | * It is possible to use this function if @dwork rearms itself via queue_work() |
493 | * or queue_delayed_work(). See also the comment for cancel_work_sync(). | 493 | * or queue_delayed_work(). See also the comment for cancel_work_sync(). |
494 | */ | 494 | */ |
495 | void cancel_rearming_delayed_work(struct delayed_work *dwork) | 495 | void cancel_delayed_work_sync(struct delayed_work *dwork) |
496 | { | 496 | { |
497 | while (!del_timer(&dwork->timer) && | 497 | while (!del_timer(&dwork->timer) && |
498 | !try_to_grab_pending(&dwork->work)) | 498 | !try_to_grab_pending(&dwork->work)) |
@@ -500,7 +500,7 @@ void cancel_rearming_delayed_work(struct delayed_work *dwork) | |||
500 | wait_on_work(&dwork->work); | 500 | wait_on_work(&dwork->work); |
501 | work_clear_pending(&dwork->work); | 501 | work_clear_pending(&dwork->work); |
502 | } | 502 | } |
503 | EXPORT_SYMBOL(cancel_rearming_delayed_work); | 503 | EXPORT_SYMBOL(cancel_delayed_work_sync); |
504 | 504 | ||
505 | static struct workqueue_struct *keventd_wq __read_mostly; | 505 | static struct workqueue_struct *keventd_wq __read_mostly; |
506 | 506 | ||