diff options
| author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-01-08 23:38:23 -0800 | 
|---|---|---|
| committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-01-08 23:38:23 -0800 | 
| commit | da733563be5a9da26fe81d9f007262d00b846e22 (patch) | |
| tree | db28291df94a2043af2123911984c5c173da4e6f /kernel/workqueue.c | |
| parent | 6ccbcf2cb41131f8d56ef0723bf3f7c1f8486076 (diff) | |
| parent | dab78d7924598ea4031663dd10db814e2e324928 (diff) | |
Merge branch 'next' into for-linus
Diffstat (limited to 'kernel/workqueue.c')
| -rw-r--r-- | kernel/workqueue.c | 9 | 
1 files changed, 7 insertions, 2 deletions
| diff --git a/kernel/workqueue.c b/kernel/workqueue.c index 25fb1b0e53fa..42fa9ad0a810 100644 --- a/kernel/workqueue.c +++ b/kernel/workqueue.c @@ -23,7 +23,7 @@   * Please read Documentation/workqueue.txt for details.   */ -#include <linux/module.h> +#include <linux/export.h>  #include <linux/kernel.h>  #include <linux/sched.h>  #include <linux/init.h> @@ -2412,8 +2412,13 @@ reflush:  	for_each_cwq_cpu(cpu, wq) {  		struct cpu_workqueue_struct *cwq = get_cwq(cpu, wq); +		bool drained; -		if (!cwq->nr_active && list_empty(&cwq->delayed_works)) +		spin_lock_irq(&cwq->gcwq->lock); +		drained = !cwq->nr_active && list_empty(&cwq->delayed_works); +		spin_unlock_irq(&cwq->gcwq->lock); + +		if (drained)  			continue;  		if (++flush_cnt == 10 || | 
