[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20160215205438.GF9223@dhcp22.suse.cz>
Date: Mon, 15 Feb 2016 21:54:38 +0100
From: Michal Hocko <mhocko@...nel.org>
To: Tejun Heo <tj@...nel.org>
Cc: Mike Galbraith <umgwanakikbuti@...il.com>,
LKML <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH wq/for-4.5-fixes] workqueue: handle NUMA_NO_NODE for
unbound pool_workqueue lookup
On Mon 15-02-16 13:21:25, Tejun Heo wrote:
> Hello, Michal.
>
> On Mon, Feb 15, 2016 at 06:33:46PM +0100, Michal Hocko wrote:
> > On Wed 10-02-16 10:55:03, Tejun Heo wrote:
> > [...]
> > > --- a/kernel/workqueue.c
> > > +++ b/kernel/workqueue.c
> > > @@ -570,6 +570,16 @@ static struct pool_workqueue *unbound_pwq_by_node(struct workqueue_struct *wq,
> > > int node)
> > > {
> > > assert_rcu_or_wq_mutex_or_pool_mutex(wq);
> > > +
> > > + /*
> > > + * XXX: @node can be NUMA_NO_NODE if CPU goes offline while a
> > > + * delayed item is pending. The plan is to keep CPU -> NODE
> > > + * mapping valid and stable across CPU on/offlines. Once that
> > > + * happens, this workaround can be removed.
> >
> > I am not sure this is completely true with the code as is currently.
> > Don't wee also need to use cpu_to_mem to handle memoryless CPUs?
>
> I'm not sure. I think we still wan to distinguish workers for a
> memoryless node from its neighboring node with memory. We don't want
> work items for the latter to be randomly distributed to the former
> after all.
I am not sure I understand. Does that mean that a node with no memory
would have its WQ specific pool? I might be missing something but I
thought that cpu_to_node will return NUMA_NO_NODE if the CPU is memory
less. Or do you expect that cpu_to_node will always return a valid node
id even when it doesn't contain any memory?
--
Michal Hocko
SUSE Labs
Powered by blists - more mailing lists