aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux
diff options
context:
space:
mode:
Diffstat (limited to 'include/linux')
-rw-r--r--include/linux/workqueue.h11
1 files changed, 10 insertions, 1 deletions
diff --git a/include/linux/workqueue.h b/include/linux/workqueue.h
index 48b7422f25ae..0a7f79729380 100644
--- a/include/linux/workqueue.h
+++ b/include/linux/workqueue.h
@@ -61,6 +61,10 @@ enum {
61 WORK_STRUCT_FLAG_MASK = (1UL << WORK_STRUCT_FLAG_BITS) - 1, 61 WORK_STRUCT_FLAG_MASK = (1UL << WORK_STRUCT_FLAG_BITS) - 1,
62 WORK_STRUCT_WQ_DATA_MASK = ~WORK_STRUCT_FLAG_MASK, 62 WORK_STRUCT_WQ_DATA_MASK = ~WORK_STRUCT_FLAG_MASK,
63 WORK_STRUCT_NO_CPU = NR_CPUS << WORK_STRUCT_FLAG_BITS, 63 WORK_STRUCT_NO_CPU = NR_CPUS << WORK_STRUCT_FLAG_BITS,
64
65 /* bit mask for work_busy() return values */
66 WORK_BUSY_PENDING = 1 << 0,
67 WORK_BUSY_RUNNING = 1 << 1,
64}; 68};
65 69
66struct work_struct { 70struct work_struct {
@@ -307,9 +311,14 @@ extern void init_workqueues(void);
307int execute_in_process_context(work_func_t fn, struct execute_work *); 311int execute_in_process_context(work_func_t fn, struct execute_work *);
308 312
309extern int flush_work(struct work_struct *work); 313extern int flush_work(struct work_struct *work);
310
311extern int cancel_work_sync(struct work_struct *work); 314extern int cancel_work_sync(struct work_struct *work);
312 315
316extern void workqueue_set_max_active(struct workqueue_struct *wq,
317 int max_active);
318extern bool workqueue_congested(unsigned int cpu, struct workqueue_struct *wq);
319extern unsigned int work_cpu(struct work_struct *work);
320extern unsigned int work_busy(struct work_struct *work);
321
313/* 322/*
314 * Kill off a pending schedule_delayed_work(). Note that the work callback 323 * Kill off a pending schedule_delayed_work(). Note that the work callback
315 * function may still be running on return from cancel_delayed_work(), unless 324 * function may still be running on return from cancel_delayed_work(), unless