diff options
| author | Ingo Molnar <mingo@kernel.org> | 2017-11-29 01:11:24 -0500 |
|---|---|---|
| committer | Ingo Molnar <mingo@kernel.org> | 2017-11-29 01:11:24 -0500 |
| commit | 4fc31ba13d052c2933bf91095c063cf9a39effd0 (patch) | |
| tree | beabb73c2fe245e6541126732895da62e55bc8ee /kernel/task_work.c | |
| parent | 0e18dd12064e07519f7cbff4149ca7fff620cbed (diff) | |
| parent | b29c6ef7bb1257853c1e31616d84f55e561cf631 (diff) | |
Merge branch 'linus' into perf/urgent, to pick up dependent commits
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'kernel/task_work.c')
| -rw-r--r-- | kernel/task_work.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/task_work.c b/kernel/task_work.c index 5718b3ea202a..0fef395662a6 100644 --- a/kernel/task_work.c +++ b/kernel/task_work.c | |||
| @@ -68,7 +68,7 @@ task_work_cancel(struct task_struct *task, task_work_func_t func) | |||
| 68 | * we raced with task_work_run(), *pprev == NULL/exited. | 68 | * we raced with task_work_run(), *pprev == NULL/exited. |
| 69 | */ | 69 | */ |
| 70 | raw_spin_lock_irqsave(&task->pi_lock, flags); | 70 | raw_spin_lock_irqsave(&task->pi_lock, flags); |
| 71 | while ((work = lockless_dereference(*pprev))) { | 71 | while ((work = READ_ONCE(*pprev))) { |
| 72 | if (work->func != func) | 72 | if (work->func != func) |
| 73 | pprev = &work->next; | 73 | pprev = &work->next; |
| 74 | else if (cmpxchg(pprev, work, work->next) == work) | 74 | else if (cmpxchg(pprev, work, work->next) == work) |
