mirror of https://gitee.com/openkylin/linux.git
x86, UV: Fix information in __uv_hub_info structure
A few parts of the uv_hub_info structure are initialized incorrectly. - n_val is being loaded with m_val. - gpa_mask is initialized with a bytes instead of an unsigned long. - Handle the case where none of the alias registers are used. Lastly I converted the bau over to using the uv_hub_info->m_val which is the correct value. Without this patch, booting a large configuration hits a problem where the upper bits of the gnode affect the pnode and the bau will not operate. Signed-off-by: Robin Holt <holt@sgi.com> Acked-by: Jack Steiner <steiner@sgi.com> Cc: Cliff Whickman <cpw@sgi.com> Cc: stable@kernel.org LKML-Reference: <20091015224946.396355000@alcatraz.americas.sgi.com> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
a5912f6b3e
commit
036ed8ba61
|
@ -352,14 +352,14 @@ static __init void get_lowmem_redirect(unsigned long *base, unsigned long *size)
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(redir_addrs); i++) {
|
for (i = 0; i < ARRAY_SIZE(redir_addrs); i++) {
|
||||||
alias.v = uv_read_local_mmr(redir_addrs[i].alias);
|
alias.v = uv_read_local_mmr(redir_addrs[i].alias);
|
||||||
if (alias.s.base == 0) {
|
if (alias.s.enable && alias.s.base == 0) {
|
||||||
*size = (1UL << alias.s.m_alias);
|
*size = (1UL << alias.s.m_alias);
|
||||||
redirect.v = uv_read_local_mmr(redir_addrs[i].redirect);
|
redirect.v = uv_read_local_mmr(redir_addrs[i].redirect);
|
||||||
*base = (unsigned long)redirect.s.dest_base << DEST_SHIFT;
|
*base = (unsigned long)redirect.s.dest_base << DEST_SHIFT;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
BUG();
|
*base = *size = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum map_type {map_wb, map_uc};
|
enum map_type {map_wb, map_uc};
|
||||||
|
@ -619,12 +619,12 @@ void __init uv_system_init(void)
|
||||||
uv_cpu_hub_info(cpu)->lowmem_remap_base = lowmem_redir_base;
|
uv_cpu_hub_info(cpu)->lowmem_remap_base = lowmem_redir_base;
|
||||||
uv_cpu_hub_info(cpu)->lowmem_remap_top = lowmem_redir_size;
|
uv_cpu_hub_info(cpu)->lowmem_remap_top = lowmem_redir_size;
|
||||||
uv_cpu_hub_info(cpu)->m_val = m_val;
|
uv_cpu_hub_info(cpu)->m_val = m_val;
|
||||||
uv_cpu_hub_info(cpu)->n_val = m_val;
|
uv_cpu_hub_info(cpu)->n_val = n_val;
|
||||||
uv_cpu_hub_info(cpu)->numa_blade_id = blade;
|
uv_cpu_hub_info(cpu)->numa_blade_id = blade;
|
||||||
uv_cpu_hub_info(cpu)->blade_processor_id = lcpu;
|
uv_cpu_hub_info(cpu)->blade_processor_id = lcpu;
|
||||||
uv_cpu_hub_info(cpu)->pnode = pnode;
|
uv_cpu_hub_info(cpu)->pnode = pnode;
|
||||||
uv_cpu_hub_info(cpu)->pnode_mask = pnode_mask;
|
uv_cpu_hub_info(cpu)->pnode_mask = pnode_mask;
|
||||||
uv_cpu_hub_info(cpu)->gpa_mask = (1 << (m_val + n_val)) - 1;
|
uv_cpu_hub_info(cpu)->gpa_mask = (1UL << (m_val + n_val)) - 1;
|
||||||
uv_cpu_hub_info(cpu)->gnode_upper = gnode_upper;
|
uv_cpu_hub_info(cpu)->gnode_upper = gnode_upper;
|
||||||
uv_cpu_hub_info(cpu)->gnode_extra = gnode_extra;
|
uv_cpu_hub_info(cpu)->gnode_extra = gnode_extra;
|
||||||
uv_cpu_hub_info(cpu)->global_mmr_base = mmr_base;
|
uv_cpu_hub_info(cpu)->global_mmr_base = mmr_base;
|
||||||
|
|
|
@ -843,8 +843,8 @@ static int __init uv_bau_init(void)
|
||||||
GFP_KERNEL, cpu_to_node(cur_cpu));
|
GFP_KERNEL, cpu_to_node(cur_cpu));
|
||||||
|
|
||||||
uv_bau_retry_limit = 1;
|
uv_bau_retry_limit = 1;
|
||||||
uv_nshift = uv_hub_info->n_val;
|
uv_nshift = uv_hub_info->m_val;
|
||||||
uv_mmask = (1UL << uv_hub_info->n_val) - 1;
|
uv_mmask = (1UL << uv_hub_info->m_val) - 1;
|
||||||
nblades = uv_num_possible_blades();
|
nblades = uv_num_possible_blades();
|
||||||
|
|
||||||
uv_bau_table_bases = (struct bau_control **)
|
uv_bau_table_bases = (struct bau_control **)
|
||||||
|
|
Loading…
Reference in New Issue