workqueue: swap set_cpus_allowed_ptr() and PF_NO_SETAFFINITY
authorOleg Nesterov <oleg@redhat.com>
Thu, 14 Nov 2013 11:56:18 +0000 (12:56 +0100)
committerTejun Heo <tj@kernel.org>
Fri, 22 Nov 2013 23:13:20 +0000 (18:13 -0500)
Move the setting of PF_NO_SETAFFINITY up before set_cpus_allowed()
in create_worker(). Otherwise userland can change ->cpus_allowed
in between.

Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: Tejun Heo <tj@kernel.org>
kernel/workqueue.c

index 987293d03ebcf0e6bf1c6b81e8a4e68c7965e903..f8942429268bc26e8fc359fd8e41409e02a1a065 100644 (file)
@@ -1736,16 +1736,17 @@ static struct worker *create_worker(struct worker_pool *pool)
        if (IS_ERR(worker->task))
                goto fail;
 
+       set_user_nice(worker->task, pool->attrs->nice);
+
+       /* prevent userland from meddling with cpumask of workqueue workers */
+       worker->task->flags |= PF_NO_SETAFFINITY;
+
        /*
         * set_cpus_allowed_ptr() will fail if the cpumask doesn't have any
         * online CPUs.  It'll be re-applied when any of the CPUs come up.
         */
-       set_user_nice(worker->task, pool->attrs->nice);
        set_cpus_allowed_ptr(worker->task, pool->attrs->cpumask);
 
-       /* prevent userland from meddling with cpumask of workqueue workers */
-       worker->task->flags |= PF_NO_SETAFFINITY;
-
        /*
         * The caller is responsible for ensuring %POOL_DISASSOCIATED
         * remains stable across this function.  See the comments above the