[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090511213354.GD553@sgi.com>
Date: Mon, 11 May 2009 16:33:54 -0500
From: Jack Steiner <steiner@....com>
To: David Rientjes <rientjes@...gle.com>
Cc: Yinghai Lu <yinghai@...nel.org>, Ingo Molnar <mingo@...e.hu>,
Thomas Gleixner <tglx@...utronix.de>,
"H. Peter Anvin" <hpa@...or.com>,
Andrew Morton <akpm@...ux-foundation.org>,
Andi Kleen <andi@...stfloor.org>,
"linux-kernel@...r.kernel.org" <linux-kernel@...r.kernel.org>
Subject: Re: [PATCH 3/3] x86: fix node_possible_map logic -v2
On Mon, May 11, 2009 at 12:27:49PM -0700, David Rientjes wrote:
> On Mon, 11 May 2009, Jack Steiner wrote:
>
> > Do we have a clear and unambiguous definition of what a node really is?
> > In this case, is a board (socket) with cpus, a unique PXM but no memory
> > considered a node. Even though it has no memory, it is a node (depending on the
> > definition of "node") for purposes such as scheduling. The memoryless node also
> > has local IO buses that want to direct interrupts to node-local cpus.
> >
>
> In your example of two cpus (0-1) that are remote to the system's only
> memory and two cpus (2-3) that have affinity to that memory, it appears as
> though the kernel is considering cpus 2-3 and the memory to be a node and
> cpus 0-1 to be a memoryless node.
Correct.
>
> That's a pretty useless scenario for memoryless node support, actually,
> unless there's a third node with memory that cpus 0-1 have a different
> distance to.
Yes, a large number of nodes exist. Most have memory but some do not.
> cpus 0-1 have no memory that is local, so the "remote"
> memory should be considered local to them.
The cpus without local memory will obviously have to use memory from other
nodes. But the problem seems to be more complex.
Cpus also belong to nodes. The cpu_to_node_map[] provides the mapping.
I have not tried it, but I wonder what happens if you offline all of the
memory of a node (probably not possible so this may be hypothetical for now).
Should offlining all node memory change the node that a cpu on the node
are associated with? That does not seem right.
Does offlining all node memory clear the entry in the node_data[] array?
>
> I don't know who has been pushing the memoryless node support, but it
> appears as though it hasn't been fully tested yet.
Agree. FWIW, it works ok in 2.6.27. I need to bisect to find where the regression
occurred.
> The NULL pglist_data
> here for node 0 seems appropriate since you don't need it unless you're
> describing memory, but the kernel implies that if a bit is set in
> node_online_map or node_possible_map that it has this associated data.
>
> Added Andi Kleen to the cc list.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists