On 2014-11-25 11:55, Shannon Zhao wrote: > Hi, > > On 2014/11/22 5:23, Ganapatrao Kulkarni wrote: [...] >> +============================================================================== >> +4 - Example dts >> +============================================================================== >> + >> +Example 1: 2 Node system each having 8 CPUs and a Memory. >> + >> + numa-map { >> + #address-cells = <2>; >> + #size-cells = <1>; >> + #node-count = <2>; >> + mem-map = <0x0 0x00000000 0>, >> + <0x100 0x00000000 1>; >> + >> + cpu-map = <0 7 0>, >> + <8 15 1>; > > The cpu range is continuous here. But if there is a situation like below: > > 0 2 4 6 belong to node 0 > 1 3 5 7 belong to node 1 > > This case is very common on X86. I don't know the real situation of arm as > I don't have a hardware with 2 nodes. > > How can we generate a DTS about this situation? like below? Can be parsed? > > cpu-map = <0 2 4 6 0>, > <1 3 5 7 1>; I think the binding proposed here can not cover your needs, and I think this binding is not suitable, there are some reasons. - CPU logical ID is allocated by OS, and it depends on the order of CPU node in the device tree, so it may be in a clean order like this patch proposed, or it will like the order Shannon pointed out. - Since CPU logical ID is allocated by OS, DTS file will not know these numbers. So the problem behind this is the mappings between CPUs and NUMA nodes, there is already mapping for CPU hardware ID (MPIDR) and CPU logical ID, and MPIDR will be not changed, why not using MPIDR for the mapping of NUMA node and CPU? then the mappings will be: CPU logical ID <------> CPU MPIDR <-----> NUMA node ID <-----> proximity domain (allocated by OS) (constant) (allocated by OS) Thanks Hanjun -- 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