Commit 940fed2e authored by Tejun Heo's avatar Tejun Heo

x86-64, NUMA: Unify {acpi|amd}_{numa_init|scan_nodes}() arguments and return values

The functions used during NUMA initialization - *_numa_init() and
*_scan_nodes() - have different arguments and return values.  Unify
them such that they all take no argument and return 0 on success and
-errno on failure.  This is in preparation for further NUMA init
cleanups.
Signed-off-by: default avatarTejun Heo <tj@kernel.org>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: Brian Gerst <brgerst@gmail.com>
Cc: Cyrill Gorcunov <gorcunov@gmail.com>
Cc: Shaohui Zheng <shaohui.zheng@intel.com>
Cc: David Rientjes <rientjes@google.com>
Cc: Ingo Molnar <mingo@elte.hu>
Cc: H. Peter Anvin <hpa@linux.intel.com>
parent 86ef4dbf
...@@ -187,7 +187,7 @@ struct bootnode; ...@@ -187,7 +187,7 @@ struct bootnode;
extern int acpi_numa; extern int acpi_numa;
extern void acpi_get_nodes(struct bootnode *physnodes, unsigned long start, extern void acpi_get_nodes(struct bootnode *physnodes, unsigned long start,
unsigned long end); unsigned long end);
extern int acpi_scan_nodes(unsigned long start, unsigned long end); extern int acpi_scan_nodes(void);
#define NR_NODE_MEMBLKS (MAX_NUMNODES*2) #define NR_NODE_MEMBLKS (MAX_NUMNODES*2)
#ifdef CONFIG_NUMA_EMU #ifdef CONFIG_NUMA_EMU
......
...@@ -16,7 +16,7 @@ struct bootnode; ...@@ -16,7 +16,7 @@ struct bootnode;
extern int early_is_amd_nb(u32 value); extern int early_is_amd_nb(u32 value);
extern int amd_cache_northbridges(void); extern int amd_cache_northbridges(void);
extern void amd_flush_garts(void); extern void amd_flush_garts(void);
extern int amd_numa_init(unsigned long start_pfn, unsigned long end_pfn); extern int amd_numa_init(void);
extern int amd_scan_nodes(void); extern int amd_scan_nodes(void);
extern int amd_get_subcaches(int); extern int amd_get_subcaches(int);
extern int amd_set_subcaches(int, int); extern int amd_set_subcaches(int, int);
......
...@@ -995,12 +995,12 @@ void __init setup_arch(char **cmdline_p) ...@@ -995,12 +995,12 @@ void __init setup_arch(char **cmdline_p)
/* /*
* Parse SRAT to discover nodes. * Parse SRAT to discover nodes.
*/ */
acpi = acpi_numa_init(); acpi = !acpi_numa_init();
#endif #endif
#ifdef CONFIG_AMD_NUMA #ifdef CONFIG_AMD_NUMA
if (!acpi) if (!acpi)
amd = !amd_numa_init(0, max_pfn); amd = !amd_numa_init();
#endif #endif
initmem_init(acpi, amd); initmem_init(acpi, amd);
......
...@@ -51,7 +51,7 @@ static __init int find_northbridge(void) ...@@ -51,7 +51,7 @@ static __init int find_northbridge(void)
return num; return num;
} }
return -1; return -ENOENT;
} }
static __init void early_get_boot_cpu_id(void) static __init void early_get_boot_cpu_id(void)
...@@ -69,17 +69,17 @@ static __init void early_get_boot_cpu_id(void) ...@@ -69,17 +69,17 @@ static __init void early_get_boot_cpu_id(void)
#endif #endif
} }
int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn) int __init amd_numa_init(void)
{ {
unsigned long start = PFN_PHYS(start_pfn); unsigned long start = PFN_PHYS(0);
unsigned long end = PFN_PHYS(end_pfn); unsigned long end = PFN_PHYS(max_pfn);
unsigned numnodes; unsigned numnodes;
unsigned long prevbase; unsigned long prevbase;
int i, nb, found = 0; int i, nb, found = 0;
u32 nodeid, reg; u32 nodeid, reg;
if (!early_pci_allowed()) if (!early_pci_allowed())
return -1; return -EINVAL;
nb = find_northbridge(); nb = find_northbridge();
if (nb < 0) if (nb < 0)
...@@ -90,7 +90,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn) ...@@ -90,7 +90,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn)
reg = read_pci_config(0, nb, 0, 0x60); reg = read_pci_config(0, nb, 0, 0x60);
numnodes = ((reg >> 4) & 0xF) + 1; numnodes = ((reg >> 4) & 0xF) + 1;
if (numnodes <= 1) if (numnodes <= 1)
return -1; return -ENOENT;
pr_info("Number of physical nodes %d\n", numnodes); pr_info("Number of physical nodes %d\n", numnodes);
...@@ -121,7 +121,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn) ...@@ -121,7 +121,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn)
if ((base >> 8) & 3 || (limit >> 8) & 3) { if ((base >> 8) & 3 || (limit >> 8) & 3) {
pr_err("Node %d using interleaving mode %lx/%lx\n", pr_err("Node %d using interleaving mode %lx/%lx\n",
nodeid, (base >> 8) & 3, (limit >> 8) & 3); nodeid, (base >> 8) & 3, (limit >> 8) & 3);
return -1; return -EINVAL;
} }
if (node_isset(nodeid, nodes_parsed)) { if (node_isset(nodeid, nodes_parsed)) {
pr_info("Node %d already present, skipping\n", pr_info("Node %d already present, skipping\n",
...@@ -160,7 +160,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn) ...@@ -160,7 +160,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn)
if (prevbase > base) { if (prevbase > base) {
pr_err("Node map not sorted %lx,%lx\n", pr_err("Node map not sorted %lx,%lx\n",
prevbase, base); prevbase, base);
return -1; return -EINVAL;
} }
pr_info("Node %d MemBase %016lx Limit %016lx\n", pr_info("Node %d MemBase %016lx Limit %016lx\n",
...@@ -177,7 +177,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn) ...@@ -177,7 +177,7 @@ int __init amd_numa_init(unsigned long start_pfn, unsigned long end_pfn)
} }
if (!found) if (!found)
return -1; return -ENOENT;
return 0; return 0;
} }
......
...@@ -596,7 +596,7 @@ void __init initmem_init(int acpi, int amd) ...@@ -596,7 +596,7 @@ void __init initmem_init(int acpi, int amd)
#endif #endif
#ifdef CONFIG_ACPI_NUMA #ifdef CONFIG_ACPI_NUMA
if (!numa_off && acpi && !acpi_scan_nodes(0, max_pfn << PAGE_SHIFT)) if (!numa_off && acpi && !acpi_scan_nodes())
return; return;
nodes_clear(node_possible_map); nodes_clear(node_possible_map);
nodes_clear(node_online_map); nodes_clear(node_online_map);
......
...@@ -359,7 +359,7 @@ void __init acpi_get_nodes(struct bootnode *physnodes, unsigned long start, ...@@ -359,7 +359,7 @@ void __init acpi_get_nodes(struct bootnode *physnodes, unsigned long start,
#endif /* CONFIG_NUMA_EMU */ #endif /* CONFIG_NUMA_EMU */
/* Use the information discovered above to actually set up the nodes. */ /* Use the information discovered above to actually set up the nodes. */
int __init acpi_scan_nodes(unsigned long start, unsigned long end) int __init acpi_scan_nodes(void)
{ {
int i; int i;
...@@ -368,7 +368,7 @@ int __init acpi_scan_nodes(unsigned long start, unsigned long end) ...@@ -368,7 +368,7 @@ int __init acpi_scan_nodes(unsigned long start, unsigned long end)
/* First clean up the node list */ /* First clean up the node list */
for (i = 0; i < MAX_NUMNODES; i++) for (i = 0; i < MAX_NUMNODES; i++)
cutoff_node(i, start, end); cutoff_node(i, 0, max_pfn << PAGE_SHIFT);
/* /*
* Join together blocks on the same node, holes between * Join together blocks on the same node, holes between
......
...@@ -274,7 +274,7 @@ acpi_table_parse_srat(enum acpi_srat_type id, ...@@ -274,7 +274,7 @@ acpi_table_parse_srat(enum acpi_srat_type id,
int __init acpi_numa_init(void) int __init acpi_numa_init(void)
{ {
int ret = 0; int cnt = 0;
/* /*
* Should not limit number with cpu num that is from NR_CPUS or nr_cpus= * Should not limit number with cpu num that is from NR_CPUS or nr_cpus=
...@@ -288,7 +288,7 @@ int __init acpi_numa_init(void) ...@@ -288,7 +288,7 @@ int __init acpi_numa_init(void)
acpi_parse_x2apic_affinity, 0); acpi_parse_x2apic_affinity, 0);
acpi_table_parse_srat(ACPI_SRAT_TYPE_CPU_AFFINITY, acpi_table_parse_srat(ACPI_SRAT_TYPE_CPU_AFFINITY,
acpi_parse_processor_affinity, 0); acpi_parse_processor_affinity, 0);
ret = acpi_table_parse_srat(ACPI_SRAT_TYPE_MEMORY_AFFINITY, cnt = acpi_table_parse_srat(ACPI_SRAT_TYPE_MEMORY_AFFINITY,
acpi_parse_memory_affinity, acpi_parse_memory_affinity,
NR_NODE_MEMBLKS); NR_NODE_MEMBLKS);
} }
...@@ -297,7 +297,10 @@ int __init acpi_numa_init(void) ...@@ -297,7 +297,10 @@ int __init acpi_numa_init(void)
acpi_table_parse(ACPI_SIG_SLIT, acpi_parse_slit); acpi_table_parse(ACPI_SIG_SLIT, acpi_parse_slit);
acpi_numa_arch_fixup(); acpi_numa_arch_fixup();
return ret;
if (cnt <= 0)
return cnt ?: -ENOENT;
return 0;
} }
int acpi_get_pxm(acpi_handle h) int acpi_get_pxm(acpi_handle h)
......
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