[RFC PATCH 4/4] arm64:numa: adding numa support for arm64 platforms.
Mark Rutland
mark.rutland at arm.com
Fri Oct 3 05:13:44 PDT 2014
On Thu, Sep 25, 2014 at 10:03:59AM +0100, Ganapatrao Kulkarni wrote:
> Adding numa support for arm64 based platforms.
> This version creates numa mapping by parsing the dt table.
> cpu to node id mapping is derived from cluster_id as defined in cpu-map.
> memory to node id mapping is derived from nid property of memory node.
[...]
> +/*
> + * Too small node sizes may confuse the VM badly. Usually they
> + * result from BIOS bugs. So dont recognize nodes as standalone
> + * NUMA entities that have less than this amount of RAM listed:
> + */
> +#define NODE_MIN_SIZE (4*1024*1024)
Why do these confuse the VM? what does BIOS have to do with arm64?
> +
> +#define parent_node(node) (node)
Huh?
[...]
> @@ -168,6 +191,11 @@ void __init bootmem_init(void)
> min = PFN_UP(memblock_start_of_DRAM());
> max = PFN_DOWN(memblock_end_of_DRAM());
>
> + high_memory = __va((max << PAGE_SHIFT) - 1) + 1;
> + max_pfn = max_low_pfn = max;
> +
> + if (IS_ENABLED(CONFIG_NUMA))
> + arm64_numa_init();
Is this function defined if !CONFIG_NUMA? Surely it must do nothing in
that case anyway?
[...]
> +/*
> + * Set the cpu to node and mem mapping
> + */
> +void numa_store_cpu_info(cpu)
> +{
> + cpu_to_node_map[cpu] = cpu_topology[cpu].cluster_id;
> + cpumask_set_cpu(cpu, node_to_cpumask_map[cpu_to_node_map[cpu]]);
> + set_numa_node(cpu_to_node_map[cpu]);
> + set_numa_mem(local_memory_node(cpu_to_node_map[cpu]));
> +}
I don't like this. I think we need to be more explicit in the DT w.r.t.
the relationship between memory and the CPU hierarchy.
I can imagine that we might end up with systems with multiple levels of
NUMA hierarchy (using MPIDR_EL1.Aff{3,2}), and I'd rather that we were
explcit as possible from the start w.r.t. the relationship between
memory and groups of CPUs such that we don't end up with multiple ways
of specifying said relationship, and horrible edge cases around implicit
definitions (e.g. the nid to cluster mapping).
> +/**
> + * dummy_numa_init - Fallback dummy NUMA init
> + *
> + * Used if there's no underlying NUMA architecture, NUMA initialization
> + * fails, or NUMA is disabled on the command line.
> + *
> + * Must online at least one node and add memory blocks that cover all
> + * allowed memory. This function must not fail.
> + */
> +static int __init dummy_numa_init(void)
> +{
> + pr_info("%s\n",
> + numa_off ? "NUMA turned off" : "No NUMA configuration found");
Why not print "NUMA turned off" in numa_setup?
> + pr_info("Faking a node at [mem %#018Lx-%#018Lx]\n",
> + 0LLU, PFN_PHYS(max_pfn) - 1);
> +
> + node_set(0, numa_nodes_parsed);
> + numa_add_memblk(0, 0, PFN_PHYS(max_pfn));
> +
> + return 0;
> +}
> +
> +/**
> + * early_init_dt_scan_numa_map - parse memory node and map nid to memory range.
> + */
> +int __init early_init_dt_scan_numa_map(unsigned long node, const char *uname,
> + int depth, void *data)
> +{
> + const char *type = of_get_flat_dt_prop(node, "device_type", NULL);
> + const __be32 *reg, *endp, *nid_prop;
> + int l, nid;
> +
> + /* We are scanning "memory" nodes only */
> + if (type == NULL) {
> + /*
> + * The longtrail doesn't have a device_type on the
> + * /memory node, so look for the node called /memory at 0.
> + */
> + if (depth != 1 || strcmp(uname, "memory at 0") != 0)
> + return 0;
This has no place on arm64.
We limited to longtrail workaround in the core memory parsing to PPC32
only in commit b44aa25d20e2ef6b (of: Handle memory at 0 node on PPC32
only). This code doesn't need it enabled ever.
Are you booting using UEFI? This isn't going to work when the memory map
comes from UEFI and we have no memory nodes in the DTB.
Mark.
More information about the linux-arm-kernel
mailing list