Message ID | 1461780436-27182-14-git-send-email-ddaney.cavm@gmail.com (mailing list archive) |
---|---|
State | Changes Requested, archived |
Headers | show |
On Wed, Apr 27, 2016 at 11:07:15AM -0700, David Daney wrote: > +static int __init get_mpidr_in_madt(int acpi_id, u64 *mpidr) > +{ > + unsigned long madt_end, entry; > + struct acpi_table_madt *madt; > + acpi_size tbl_size; > + > + if (ACPI_FAILURE(acpi_get_table_with_size(ACPI_SIG_MADT, 0, > + (struct acpi_table_header **)&madt, &tbl_size))) > + return -ENODEV; > + > + entry = (unsigned long)madt; > + madt_end = entry + madt->header.length; > + > + /* Parse all entries looking for a match. */ > + entry += sizeof(struct acpi_table_madt); > + while (entry + sizeof(struct acpi_subtable_header) < madt_end) { > + struct acpi_subtable_header *header = > + (struct acpi_subtable_header *)entry; > + > + if (header->type == ACPI_MADT_TYPE_GENERIC_INTERRUPT) { > + struct acpi_madt_generic_interrupt *gicc = > + container_of(header, > + struct acpi_madt_generic_interrupt, header); > + > + if ((gicc->flags & ACPI_MADT_ENABLED) && > + (gicc->uid == acpi_id)) { > + *mpidr = gicc->arm_mpidr; > + early_acpi_os_unmap_memory(madt, tbl_size); > + return 0; > + } > + } > + entry += header->length; > + } > + > + early_acpi_os_unmap_memory(madt, tbl_size); > + return -ENODEV; > +} > + > +/* Callback for Proximity Domain -> ACPI processor UID mapping */ > +void __init acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) > +{ > + int pxm, node; > + u64 mpidr; > + > + if (srat_disabled()) > + return; > + > + if (pa->header.length < sizeof(struct acpi_srat_gicc_affinity)) { > + pr_err("SRAT: Invalid SRAT header length: %d\n", > + pa->header.length); > + bad_srat(); > + return; > + } > + > + if (!(pa->flags & ACPI_SRAT_GICC_ENABLED)) > + return; > + > + if (cpus_in_srat >= NR_CPUS) { > + pr_warn_once("SRAT: cpu_to_node_map[%d] is too small, may not be able to use all cpus\n", > + NR_CPUS); > + return; > + } > + > + pxm = pa->proximity_domain; > + node = acpi_map_pxm_to_node(pxm); > + > + if (node == NUMA_NO_NODE || node >= MAX_NUMNODES) { > + pr_err("SRAT: Too many proximity domains %d\n", pxm); > + bad_srat(); > + return; > + } > + > + if (get_mpidr_in_madt(pa->acpi_processor_uid, &mpidr)) { > + pr_err("SRAT: PXM %d with ACPI ID %d has no valid MPIDR in MADT\n", > + pxm, pa->acpi_processor_uid); > + bad_srat(); > + return; > + } I wonder whether you could replace the get_mpidr_in_madt() function with something like acpi_get_phys_id(). It looks like get_mpidr_in_madt() duplicates functionality already available elsewhere.
On 05/11/2016 03:39 AM, Catalin Marinas wrote: > On Wed, Apr 27, 2016 at 11:07:15AM -0700, David Daney wrote: >> +static int __init get_mpidr_in_madt(int acpi_id, u64 *mpidr) >> +{ >> + unsigned long madt_end, entry; >> + struct acpi_table_madt *madt; >> + acpi_size tbl_size; >> + >> + if (ACPI_FAILURE(acpi_get_table_with_size(ACPI_SIG_MADT, 0, >> + (struct acpi_table_header **)&madt, &tbl_size))) >> + return -ENODEV; >> + >> + entry = (unsigned long)madt; >> + madt_end = entry + madt->header.length; >> + >> + /* Parse all entries looking for a match. */ >> + entry += sizeof(struct acpi_table_madt); >> + while (entry + sizeof(struct acpi_subtable_header) < madt_end) { >> + struct acpi_subtable_header *header = >> + (struct acpi_subtable_header *)entry; >> + >> + if (header->type == ACPI_MADT_TYPE_GENERIC_INTERRUPT) { >> + struct acpi_madt_generic_interrupt *gicc = >> + container_of(header, >> + struct acpi_madt_generic_interrupt, header); >> + >> + if ((gicc->flags & ACPI_MADT_ENABLED) && >> + (gicc->uid == acpi_id)) { >> + *mpidr = gicc->arm_mpidr; >> + early_acpi_os_unmap_memory(madt, tbl_size); >> + return 0; >> + } >> + } >> + entry += header->length; >> + } >> + >> + early_acpi_os_unmap_memory(madt, tbl_size); >> + return -ENODEV; >> +} >> + >> +/* Callback for Proximity Domain -> ACPI processor UID mapping */ >> +void __init acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) >> +{ >> + int pxm, node; >> + u64 mpidr; >> + >> + if (srat_disabled()) >> + return; >> + >> + if (pa->header.length < sizeof(struct acpi_srat_gicc_affinity)) { >> + pr_err("SRAT: Invalid SRAT header length: %d\n", >> + pa->header.length); >> + bad_srat(); >> + return; >> + } >> + >> + if (!(pa->flags & ACPI_SRAT_GICC_ENABLED)) >> + return; >> + >> + if (cpus_in_srat >= NR_CPUS) { >> + pr_warn_once("SRAT: cpu_to_node_map[%d] is too small, may not be able to use all cpus\n", >> + NR_CPUS); >> + return; >> + } >> + >> + pxm = pa->proximity_domain; >> + node = acpi_map_pxm_to_node(pxm); >> + >> + if (node == NUMA_NO_NODE || node >= MAX_NUMNODES) { >> + pr_err("SRAT: Too many proximity domains %d\n", pxm); >> + bad_srat(); >> + return; >> + } >> + >> + if (get_mpidr_in_madt(pa->acpi_processor_uid, &mpidr)) { >> + pr_err("SRAT: PXM %d with ACPI ID %d has no valid MPIDR in MADT\n", >> + pxm, pa->acpi_processor_uid); >> + bad_srat(); >> + return; >> + } > > I wonder whether you could replace the get_mpidr_in_madt() function with > something like acpi_get_phys_id(). It looks like get_mpidr_in_madt() > duplicates functionality already available elsewhere. > I just tried that, and it doesn't work. The problem is that this code is being run very early in the boot, and kmalloc cannot be used. acpi_get_phys_id() and its ilk can only be used once we have working kmalloc. We need to extract the NUMA information early like this precisely because it is needed to initializing the slab system Notice that we are using early_acpi_os_unmap_memory() et al. in get_mpidr_in_madt() explicitly for this reason. In summary: I don't think we need another revision of this patch, it is like this for a good reason. David Daney -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On 2016/5/12 8:06, David Daney wrote: > On 05/11/2016 03:39 AM, Catalin Marinas wrote: >> On Wed, Apr 27, 2016 at 11:07:15AM -0700, David Daney wrote: >>> +static int __init get_mpidr_in_madt(int acpi_id, u64 *mpidr) >>> +{ >>> + unsigned long madt_end, entry; >>> + struct acpi_table_madt *madt; >>> + acpi_size tbl_size; >>> + >>> + if (ACPI_FAILURE(acpi_get_table_with_size(ACPI_SIG_MADT, 0, >>> + (struct acpi_table_header **)&madt, &tbl_size))) >>> + return -ENODEV; >>> + >>> + entry = (unsigned long)madt; >>> + madt_end = entry + madt->header.length; >>> + >>> + /* Parse all entries looking for a match. */ >>> + entry += sizeof(struct acpi_table_madt); >>> + while (entry + sizeof(struct acpi_subtable_header) < madt_end) { >>> + struct acpi_subtable_header *header = >>> + (struct acpi_subtable_header *)entry; >>> + >>> + if (header->type == ACPI_MADT_TYPE_GENERIC_INTERRUPT) { >>> + struct acpi_madt_generic_interrupt *gicc = >>> + container_of(header, >>> + struct acpi_madt_generic_interrupt, header); >>> + >>> + if ((gicc->flags & ACPI_MADT_ENABLED) && >>> + (gicc->uid == acpi_id)) { >>> + *mpidr = gicc->arm_mpidr; >>> + early_acpi_os_unmap_memory(madt, tbl_size); >>> + return 0; >>> + } >>> + } >>> + entry += header->length; >>> + } >>> + >>> + early_acpi_os_unmap_memory(madt, tbl_size); >>> + return -ENODEV; >>> +} >>> + >>> +/* Callback for Proximity Domain -> ACPI processor UID mapping */ >>> +void __init acpi_numa_gicc_affinity_init(struct >>> acpi_srat_gicc_affinity *pa) >>> +{ >>> + int pxm, node; >>> + u64 mpidr; >>> + >>> + if (srat_disabled()) >>> + return; >>> + >>> + if (pa->header.length < sizeof(struct acpi_srat_gicc_affinity)) { >>> + pr_err("SRAT: Invalid SRAT header length: %d\n", >>> + pa->header.length); >>> + bad_srat(); >>> + return; >>> + } >>> + >>> + if (!(pa->flags & ACPI_SRAT_GICC_ENABLED)) >>> + return; >>> + >>> + if (cpus_in_srat >= NR_CPUS) { >>> + pr_warn_once("SRAT: cpu_to_node_map[%d] is too small, may >>> not be able to use all cpus\n", >>> + NR_CPUS); >>> + return; >>> + } >>> + >>> + pxm = pa->proximity_domain; >>> + node = acpi_map_pxm_to_node(pxm); >>> + >>> + if (node == NUMA_NO_NODE || node >= MAX_NUMNODES) { >>> + pr_err("SRAT: Too many proximity domains %d\n", pxm); >>> + bad_srat(); >>> + return; >>> + } >>> + >>> + if (get_mpidr_in_madt(pa->acpi_processor_uid, &mpidr)) { >>> + pr_err("SRAT: PXM %d with ACPI ID %d has no valid MPIDR in >>> MADT\n", >>> + pxm, pa->acpi_processor_uid); >>> + bad_srat(); >>> + return; >>> + } >> >> I wonder whether you could replace the get_mpidr_in_madt() function with >> something like acpi_get_phys_id(). It looks like get_mpidr_in_madt() >> duplicates functionality already available elsewhere. >> > > I just tried that, and it doesn't work. > > The problem is that this code is being run very early in the boot, and > kmalloc cannot be used. acpi_get_phys_id() and its ilk can only be used > once we have working kmalloc. We need to extract the NUMA information > early like this precisely because it is needed to initializing the slab > system > > Notice that we are using early_acpi_os_unmap_memory() et al. in > get_mpidr_in_madt() explicitly for this reason. I got the same conclusion when I was preparing this patch set. Thanks Hanjun -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
On Wed, May 11, 2016 at 05:06:13PM -0700, David Daney wrote: > On 05/11/2016 03:39 AM, Catalin Marinas wrote: > >On Wed, Apr 27, 2016 at 11:07:15AM -0700, David Daney wrote: > >>+static int __init get_mpidr_in_madt(int acpi_id, u64 *mpidr) > >>+{ > >>+ unsigned long madt_end, entry; > >>+ struct acpi_table_madt *madt; > >>+ acpi_size tbl_size; > >>+ > >>+ if (ACPI_FAILURE(acpi_get_table_with_size(ACPI_SIG_MADT, 0, > >>+ (struct acpi_table_header **)&madt, &tbl_size))) > >>+ return -ENODEV; > >>+ > >>+ entry = (unsigned long)madt; > >>+ madt_end = entry + madt->header.length; > >>+ > >>+ /* Parse all entries looking for a match. */ > >>+ entry += sizeof(struct acpi_table_madt); > >>+ while (entry + sizeof(struct acpi_subtable_header) < madt_end) { > >>+ struct acpi_subtable_header *header = > >>+ (struct acpi_subtable_header *)entry; > >>+ > >>+ if (header->type == ACPI_MADT_TYPE_GENERIC_INTERRUPT) { > >>+ struct acpi_madt_generic_interrupt *gicc = > >>+ container_of(header, > >>+ struct acpi_madt_generic_interrupt, header); > >>+ > >>+ if ((gicc->flags & ACPI_MADT_ENABLED) && > >>+ (gicc->uid == acpi_id)) { > >>+ *mpidr = gicc->arm_mpidr; > >>+ early_acpi_os_unmap_memory(madt, tbl_size); > >>+ return 0; > >>+ } > >>+ } > >>+ entry += header->length; > >>+ } > >>+ > >>+ early_acpi_os_unmap_memory(madt, tbl_size); > >>+ return -ENODEV; > >>+} > >>+ > >>+/* Callback for Proximity Domain -> ACPI processor UID mapping */ > >>+void __init acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) > >>+{ > >>+ int pxm, node; > >>+ u64 mpidr; > >>+ > >>+ if (srat_disabled()) > >>+ return; > >>+ > >>+ if (pa->header.length < sizeof(struct acpi_srat_gicc_affinity)) { > >>+ pr_err("SRAT: Invalid SRAT header length: %d\n", > >>+ pa->header.length); > >>+ bad_srat(); > >>+ return; > >>+ } > >>+ > >>+ if (!(pa->flags & ACPI_SRAT_GICC_ENABLED)) > >>+ return; > >>+ > >>+ if (cpus_in_srat >= NR_CPUS) { > >>+ pr_warn_once("SRAT: cpu_to_node_map[%d] is too small, may not be able to use all cpus\n", > >>+ NR_CPUS); > >>+ return; > >>+ } > >>+ > >>+ pxm = pa->proximity_domain; > >>+ node = acpi_map_pxm_to_node(pxm); > >>+ > >>+ if (node == NUMA_NO_NODE || node >= MAX_NUMNODES) { > >>+ pr_err("SRAT: Too many proximity domains %d\n", pxm); > >>+ bad_srat(); > >>+ return; > >>+ } > >>+ > >>+ if (get_mpidr_in_madt(pa->acpi_processor_uid, &mpidr)) { > >>+ pr_err("SRAT: PXM %d with ACPI ID %d has no valid MPIDR in MADT\n", > >>+ pxm, pa->acpi_processor_uid); > >>+ bad_srat(); > >>+ return; > >>+ } > > > >I wonder whether you could replace the get_mpidr_in_madt() function with > >something like acpi_get_phys_id(). It looks like get_mpidr_in_madt() > >duplicates functionality already available elsewhere. > > I just tried that, and it doesn't work. > > The problem is that this code is being run very early in the boot, and > kmalloc cannot be used. acpi_get_phys_id() and its ilk can only be used > once we have working kmalloc. We need to extract the NUMA information early > like this precisely because it is needed to initializing the slab system > > Notice that we are using early_acpi_os_unmap_memory() et al. in > get_mpidr_in_madt() explicitly for this reason. > > In summary: I don't think we need another revision of this patch, it is like > this for a good reason. Slightly confusing, in another reply you said you are going to address my comment. So, is it doable?
On 05/12/2016 02:49 AM, Catalin Marinas wrote: > On Wed, May 11, 2016 at 05:06:13PM -0700, David Daney wrote: >> On 05/11/2016 03:39 AM, Catalin Marinas wrote: [...] >>> >>> I wonder whether you could replace the get_mpidr_in_madt() function with >>> something like acpi_get_phys_id(). It looks like get_mpidr_in_madt() >>> duplicates functionality already available elsewhere. >> >> I just tried that, and it doesn't work. >> >> The problem is that this code is being run very early in the boot, and >> kmalloc cannot be used. acpi_get_phys_id() and its ilk can only be used >> once we have working kmalloc. We need to extract the NUMA information early >> like this precisely because it is needed to initializing the slab system >> >> Notice that we are using early_acpi_os_unmap_memory() et al. in >> get_mpidr_in_madt() explicitly for this reason. >> >> In summary: I don't think we need another revision of this patch, it is like >> this for a good reason. > > Slightly confusing, in another reply you said you are going to address > my comment. So, is it doable? I don't think so. My previous reply, to the thread in 0/14, was prematurely made with the incorrect assumption that it was a simple change. Now, after really digging in to the code, and attempting to do as you suggested, I have changed my mind. As I indicated above, there are no remaining suggestions or requests for changes to this patch set pending action. Unless people find additional problems, I think it is ready for merging. I know that Will and Rafael were discussing the proper timing for merging this in the other thread, so I leave it in their hands at this point. Thanks, David Daney > -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html
diff --git a/arch/arm64/include/asm/acpi.h b/arch/arm64/include/asm/acpi.h index aee323b..4b13ecd 100644 --- a/arch/arm64/include/asm/acpi.h +++ b/arch/arm64/include/asm/acpi.h @@ -113,4 +113,12 @@ static inline const char *acpi_get_enable_method(int cpu) pgprot_t arch_apei_get_mem_attribute(phys_addr_t addr); #endif +#ifdef CONFIG_ACPI_NUMA +int arm64_acpi_numa_init(void); +int acpi_numa_get_nid(unsigned int cpu, u64 hwid); +#else +static inline int arm64_acpi_numa_init(void) { return -ENOSYS; } +static inline int acpi_numa_get_nid(unsigned int cpu, u64 hwid) { return NUMA_NO_NODE; } +#endif /* CONFIG_ACPI_NUMA */ + #endif /*_ASM_ACPI_H*/ diff --git a/arch/arm64/include/asm/numa.h b/arch/arm64/include/asm/numa.h index e9b4f29..600887e 100644 --- a/arch/arm64/include/asm/numa.h +++ b/arch/arm64/include/asm/numa.h @@ -5,6 +5,8 @@ #ifdef CONFIG_NUMA +#define NR_NODE_MEMBLKS (MAX_NUMNODES * 2) + /* currently, arm64 implements flat NUMA topology */ #define parent_node(node) (node) diff --git a/arch/arm64/kernel/Makefile b/arch/arm64/kernel/Makefile index 3793003..69569c6 100644 --- a/arch/arm64/kernel/Makefile +++ b/arch/arm64/kernel/Makefile @@ -42,6 +42,7 @@ arm64-obj-$(CONFIG_EFI) += efi.o efi-entry.stub.o arm64-obj-$(CONFIG_PCI) += pci.o arm64-obj-$(CONFIG_ARMV8_DEPRECATED) += armv8_deprecated.o arm64-obj-$(CONFIG_ACPI) += acpi.o +arm64-obj-$(CONFIG_ACPI_NUMA) += acpi_numa.o arm64-obj-$(CONFIG_ARM64_ACPI_PARKING_PROTOCOL) += acpi_parking_protocol.o arm64-obj-$(CONFIG_PARAVIRT) += paravirt.o arm64-obj-$(CONFIG_RANDOMIZE_BASE) += kaslr.o diff --git a/arch/arm64/kernel/acpi_numa.c b/arch/arm64/kernel/acpi_numa.c new file mode 100644 index 0000000..94a6b35 --- /dev/null +++ b/arch/arm64/kernel/acpi_numa.c @@ -0,0 +1,149 @@ +/* + * ACPI 5.1 based NUMA setup for ARM64 + * Lots of code was borrowed from arch/x86/mm/srat.c + * + * Copyright 2004 Andi Kleen, SuSE Labs. + * Copyright (C) 2013-2016, Linaro Ltd. + * Author: Hanjun Guo <hanjun.guo@linaro.org> + * + * Reads the ACPI SRAT table to figure out what memory belongs to which CPUs. + * + * Called from acpi_numa_init while reading the SRAT and SLIT tables. + * Assumes all memory regions belonging to a single proximity domain + * are in one chunk. Holes between them will be included in the node. + */ + +#define pr_fmt(fmt) "ACPI: NUMA: " fmt + +#include <linux/acpi.h> +#include <linux/bitmap.h> +#include <linux/bootmem.h> +#include <linux/kernel.h> +#include <linux/mm.h> +#include <linux/memblock.h> +#include <linux/mmzone.h> +#include <linux/module.h> +#include <linux/topology.h> + +#include <acpi/processor.h> +#include <asm/numa.h> + +static int cpus_in_srat; + +struct __node_cpu_hwid { + u32 node_id; /* logical node containing this CPU */ + u64 cpu_hwid; /* MPIDR for this CPU */ +}; + +static struct __node_cpu_hwid early_node_cpu_hwid[NR_CPUS] = { +[0 ... NR_CPUS - 1] = {NUMA_NO_NODE, PHYS_CPUID_INVALID} }; + +int acpi_numa_get_nid(unsigned int cpu, u64 hwid) +{ + int i; + + for (i = 0; i < cpus_in_srat; i++) { + if (hwid == early_node_cpu_hwid[i].cpu_hwid) + return early_node_cpu_hwid[i].node_id; + } + + return NUMA_NO_NODE; +} + +static int __init get_mpidr_in_madt(int acpi_id, u64 *mpidr) +{ + unsigned long madt_end, entry; + struct acpi_table_madt *madt; + acpi_size tbl_size; + + if (ACPI_FAILURE(acpi_get_table_with_size(ACPI_SIG_MADT, 0, + (struct acpi_table_header **)&madt, &tbl_size))) + return -ENODEV; + + entry = (unsigned long)madt; + madt_end = entry + madt->header.length; + + /* Parse all entries looking for a match. */ + entry += sizeof(struct acpi_table_madt); + while (entry + sizeof(struct acpi_subtable_header) < madt_end) { + struct acpi_subtable_header *header = + (struct acpi_subtable_header *)entry; + + if (header->type == ACPI_MADT_TYPE_GENERIC_INTERRUPT) { + struct acpi_madt_generic_interrupt *gicc = + container_of(header, + struct acpi_madt_generic_interrupt, header); + + if ((gicc->flags & ACPI_MADT_ENABLED) && + (gicc->uid == acpi_id)) { + *mpidr = gicc->arm_mpidr; + early_acpi_os_unmap_memory(madt, tbl_size); + return 0; + } + } + entry += header->length; + } + + early_acpi_os_unmap_memory(madt, tbl_size); + return -ENODEV; +} + +/* Callback for Proximity Domain -> ACPI processor UID mapping */ +void __init acpi_numa_gicc_affinity_init(struct acpi_srat_gicc_affinity *pa) +{ + int pxm, node; + u64 mpidr; + + if (srat_disabled()) + return; + + if (pa->header.length < sizeof(struct acpi_srat_gicc_affinity)) { + pr_err("SRAT: Invalid SRAT header length: %d\n", + pa->header.length); + bad_srat(); + return; + } + + if (!(pa->flags & ACPI_SRAT_GICC_ENABLED)) + return; + + if (cpus_in_srat >= NR_CPUS) { + pr_warn_once("SRAT: cpu_to_node_map[%d] is too small, may not be able to use all cpus\n", + NR_CPUS); + return; + } + + pxm = pa->proximity_domain; + node = acpi_map_pxm_to_node(pxm); + + if (node == NUMA_NO_NODE || node >= MAX_NUMNODES) { + pr_err("SRAT: Too many proximity domains %d\n", pxm); + bad_srat(); + return; + } + + if (get_mpidr_in_madt(pa->acpi_processor_uid, &mpidr)) { + pr_err("SRAT: PXM %d with ACPI ID %d has no valid MPIDR in MADT\n", + pxm, pa->acpi_processor_uid); + bad_srat(); + return; + } + + early_node_cpu_hwid[cpus_in_srat].node_id = node; + early_node_cpu_hwid[cpus_in_srat].cpu_hwid = mpidr; + node_set(node, numa_nodes_parsed); + cpus_in_srat++; + pr_info("SRAT: PXM %d -> MPIDR 0x%Lx -> Node %d\n", + pxm, mpidr, node); +} + +int __init arm64_acpi_numa_init(void) +{ + int ret; + + ret = acpi_numa_init(); + if (ret) + return ret; + + return srat_disabled() ? -EINVAL : 0; +} diff --git a/arch/arm64/kernel/smp.c b/arch/arm64/kernel/smp.c index fef2e73..fe85940 100644 --- a/arch/arm64/kernel/smp.c +++ b/arch/arm64/kernel/smp.c @@ -562,6 +562,8 @@ acpi_map_gic_cpu_interface(struct acpi_madt_generic_interrupt *processor) */ acpi_set_mailbox_entry(cpu_count, processor); + early_map_cpu_to_node(cpu_count, acpi_numa_get_nid(cpu_count, hwid)); + cpu_count++; } diff --git a/arch/arm64/mm/numa.c b/arch/arm64/mm/numa.c index 1def1de..c7fe3ec 100644 --- a/arch/arm64/mm/numa.c +++ b/arch/arm64/mm/numa.c @@ -17,6 +17,7 @@ * along with this program. If not, see <http://www.gnu.org/licenses/>. */ +#include <linux/acpi.h> #include <linux/bootmem.h> #include <linux/memblock.h> #include <linux/module.h> @@ -391,7 +392,9 @@ static int __init dummy_numa_init(void) void __init arm64_numa_init(void) { if (!numa_off) { - if (!numa_init(of_numa_init)) + if (!acpi_disabled && !numa_init(arm64_acpi_numa_init)) + return; + if (acpi_disabled && !numa_init(of_numa_init)) return; }