diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/is_single_threaded.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/is_single_threaded.c b/lib/is_single_threaded.c index 434010980bdf..bd2bea963364 100644 --- a/lib/is_single_threaded.c +++ b/lib/is_single_threaded.c | |||
@@ -22,8 +22,6 @@ bool current_is_single_threaded(void) | |||
22 | struct task_struct *p, *t; | 22 | struct task_struct *p, *t; |
23 | bool ret; | 23 | bool ret; |
24 | 24 | ||
25 | might_sleep(); | ||
26 | |||
27 | if (atomic_read(&task->signal->live) != 1) | 25 | if (atomic_read(&task->signal->live) != 1) |
28 | return false; | 26 | return false; |
29 | 27 | ||
@@ -31,7 +29,6 @@ bool current_is_single_threaded(void) | |||
31 | return true; | 29 | return true; |
32 | 30 | ||
33 | ret = false; | 31 | ret = false; |
34 | down_write(&mm->mmap_sem); | ||
35 | rcu_read_lock(); | 32 | rcu_read_lock(); |
36 | for_each_process(p) { | 33 | for_each_process(p) { |
37 | if (unlikely(p->flags & PF_KTHREAD)) | 34 | if (unlikely(p->flags & PF_KTHREAD)) |
@@ -45,12 +42,17 @@ bool current_is_single_threaded(void) | |||
45 | goto found; | 42 | goto found; |
46 | if (likely(t->mm)) | 43 | if (likely(t->mm)) |
47 | break; | 44 | break; |
45 | /* | ||
46 | * t->mm == NULL. Make sure next_thread/next_task | ||
47 | * will see other CLONE_VM tasks which might be | ||
48 | * forked before exiting. | ||
49 | */ | ||
50 | smp_rmb(); | ||
48 | } while_each_thread(p, t); | 51 | } while_each_thread(p, t); |
49 | } | 52 | } |
50 | ret = true; | 53 | ret = true; |
51 | found: | 54 | found: |
52 | rcu_read_unlock(); | 55 | rcu_read_unlock(); |
53 | up_write(&mm->mmap_sem); | ||
54 | 56 | ||
55 | return ret; | 57 | return ret; |
56 | } | 58 | } |