Commit 8f1bc6b5 authored by Nitin Gupta's avatar Nitin Gupta Committed by Kamal Mostafa

sparc64: Fix numa node distance initialization

BugLink: http://bugs.launchpad.net/bugs/1596575

[ Upstream commit 36beca65 ]

Orabug: 22495713

Currently, NUMA node distance matrix is initialized only
when a machine descriptor (MD) exists. However, sun4u
machines (e.g. Sun Blade 2500) do not have an MD and thus
distance values were left uninitialized. The initialization
is now moved such that it happens on both sun4u and sun4v.
Signed-off-by: default avatarNitin Gupta <nitin.m.gupta@oracle.com>
Tested-by: default avatarMikael Pettersson <mikpelinux@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarTim Gardner <tim.gardner@canonical.com>
Signed-off-by: default avatarKamal Mostafa <kamal@canonical.com>
parent e272fc9f
...@@ -1267,13 +1267,6 @@ static int __init numa_parse_mdesc(void) ...@@ -1267,13 +1267,6 @@ static int __init numa_parse_mdesc(void)
int i, j, err, count; int i, j, err, count;
u64 node; u64 node;
/* Some sane defaults for numa latency values */
for (i = 0; i < MAX_NUMNODES; i++) {
for (j = 0; j < MAX_NUMNODES; j++)
numa_latency[i][j] = (i == j) ?
LOCAL_DISTANCE : REMOTE_DISTANCE;
}
node = mdesc_node_by_name(md, MDESC_NODE_NULL, "latency-groups"); node = mdesc_node_by_name(md, MDESC_NODE_NULL, "latency-groups");
if (node == MDESC_NODE_NULL) { if (node == MDESC_NODE_NULL) {
mdesc_release(md); mdesc_release(md);
...@@ -1369,10 +1362,18 @@ static int __init numa_parse_sun4u(void) ...@@ -1369,10 +1362,18 @@ static int __init numa_parse_sun4u(void)
static int __init bootmem_init_numa(void) static int __init bootmem_init_numa(void)
{ {
int i, j;
int err = -1; int err = -1;
numadbg("bootmem_init_numa()\n"); numadbg("bootmem_init_numa()\n");
/* Some sane defaults for numa latency values */
for (i = 0; i < MAX_NUMNODES; i++) {
for (j = 0; j < MAX_NUMNODES; j++)
numa_latency[i][j] = (i == j) ?
LOCAL_DISTANCE : REMOTE_DISTANCE;
}
if (numa_enabled) { if (numa_enabled) {
if (tlb_type == hypervisor) if (tlb_type == hypervisor)
err = numa_parse_mdesc(); err = numa_parse_mdesc();
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment