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@0. > + */ > + if (depth != 1 || strcmp(uname, "memory@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@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. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html