x86, UV: Fix macros for multiple coherency domains
authorJack Steiner <steiner@sgi.com>
Mon, 8 Jun 2009 15:44:05 +0000 (10:44 -0500)
committerIngo Molnar <mingo@elte.hu>
Mon, 8 Jun 2009 16:57:47 +0000 (18:57 +0200)
Fix bug in the SGI UV macros that support systems with multiple
coherency domains.  The macros used for referencing global MMR
(chipset registers) are failing to correctly "or" the NASID
(node identifier) bits that reside above M+N. These high bits
are supplied automatically by the chipset for memory accesses
coming from the processor socket.

However, the bits must be present for references to the special
global MMR space used to map chipset registers. (See uv_hub.h
for more details ...)

The bug results in references to invalid/incorrect nodes.

Signed-off-by: Jack Steiner <steiner@sgi.com>
Cc: <stable@kernel.org>
LKML-Reference: <20090608154405.GA16395@sgi.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>

No differences found