summaryrefslogtreecommitdiff
path: root/kernel/workqueue.c
diff options
context:
space:
mode:
authorDavid S. Miller <davem@nuts.davemloft.net>2005-02-22 03:23:21 -0800
committerDavid S. Miller <davem@nuts.davemloft.net>2005-02-22 03:23:21 -0800
commit6a135a53cb9ef5a17b5d52f9b49a5422257b2071 (patch)
treeadb45313862a6eb12bde8a1cd454eb66921e672e /kernel/workqueue.c
parented712dbb567d319f51dde0585a7ebbcbd9aed354 (diff)
parentaa82c4c49bee16ba193ddc1e03ca53ccf52debaf (diff)
Merge nuts.davemloft.net:/disk1/BK/network-2.6.12
into nuts.davemloft.net:/disk1/BK/net-2.6.12
Diffstat (limited to 'kernel/workqueue.c')
-rw-r--r--kernel/workqueue.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/kernel/workqueue.c b/kernel/workqueue.c
index 5301935f609b..52ef419d2747 100644
--- a/kernel/workqueue.c
+++ b/kernel/workqueue.c
@@ -423,6 +423,30 @@ void flush_scheduled_work(void)
flush_workqueue(keventd_wq);
}
+/**
+ * cancel_rearming_delayed_workqueue - reliably kill off a delayed
+ * work whose handler rearms the delayed work.
+ * @wq: the controlling workqueue structure
+ * @work: the delayed work struct
+ */
+static void cancel_rearming_delayed_workqueue(struct workqueue_struct *wq,
+ struct work_struct *work)
+{
+ while (!cancel_delayed_work(work))
+ flush_workqueue(wq);
+}
+
+/**
+ * cancel_rearming_delayed_work - reliably kill off a delayed keventd
+ * work whose handler rearms the delayed work.
+ * @work: the delayed work struct
+ */
+void cancel_rearming_delayed_work(struct work_struct *work)
+{
+ cancel_rearming_delayed_workqueue(keventd_wq, work);
+}
+EXPORT_SYMBOL(cancel_rearming_delayed_work);
+
int keventd_up(void)
{
return keventd_wq != NULL;