> From: Xunlei Pang <pang.xun...@linaro.org>
> 
> Currently, get_unbound_pool() uses kzalloc() to allocate the
> worker pool. Actually, we can use the right node to do the
> allocation, achieving local memory access.
> 
> This patch selects target node first, and uses kzalloc_node()
> instead.
> 
> Signed-off-by: Xunlei Pang <pang.xun...@linaro.org>
> ---
>  kernel/workqueue.c | 26 ++++++++++++++------------
>  1 file changed, 14 insertions(+), 12 deletions(-)
> 
> diff --git a/kernel/workqueue.c b/kernel/workqueue.c
> index ca71582..96d3747 100644
> --- a/kernel/workqueue.c
> +++ b/kernel/workqueue.c
> @@ -3199,6 +3199,7 @@ static struct worker_pool *get_unbound_pool(const 
> struct workqueue_attrs *attrs)
>       u32 hash = wqattrs_hash(attrs);
>       struct worker_pool *pool;
>       int node;
> +     int target_node = NUMA_NO_NODE;
> 
>       lockdep_assert_held(&wq_pool_mutex);
> 
> @@ -3210,13 +3211,25 @@ static struct worker_pool *get_unbound_pool(const 
> struct workqueue_attrs *attrs)
>               }
>       }
> 
> +     /* if cpumask is contained inside a NUMA node, we belong to that node */
> +     if (wq_numa_enabled) {
> +             for_each_node(node) {
> +                     if (cpumask_subset(attrs->cpumask,
> +                                        wq_numa_possible_cpumask[node])) {
> +                             target_node = node;
> +                             break;
> +                     }
> +             }
> +     }
> +
>       /* nope, create a new one */
> -     pool = kzalloc(sizeof(*pool), GFP_KERNEL);
> +     pool = kzalloc_node(sizeof(*pool), GFP_KERNEL, target_node);

What if target_node is short of pages at the moment?

>       if (!pool || init_worker_pool(pool) < 0)
>               goto fail;
> 
>       lockdep_set_subclass(&pool->lock, 1);   /* see put_pwq() */
>       copy_workqueue_attrs(pool->attrs, attrs);
> +     pool->node = target_node;
> 
>       /*
>        * no_numa isn't a worker_pool attribute, always clear it.  See
> @@ -3224,17 +3237,6 @@ static struct worker_pool *get_unbound_pool(const 
> struct workqueue_attrs *attrs)
>        */
>       pool->attrs->no_numa = false;
> 
> -     /* if cpumask is contained inside a NUMA node, we belong to that node */
> -     if (wq_numa_enabled) {
> -             for_each_node(node) {
> -                     if (cpumask_subset(pool->attrs->cpumask,
> -                                        wq_numa_possible_cpumask[node])) {
> -                             pool->node = node;
> -                             break;
> -                     }
> -             }
> -     }
> -
>       if (worker_pool_assign_id(pool) < 0)
>               goto fail;
> 
> --
> 1.9.1

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to