aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZhen Lei <thunder.leizhen@huawei.com>2016-09-01 02:54:53 -0400
committerWill Deacon <will.deacon@arm.com>2016-09-09 09:59:08 -0400
commit84b14256c18c967afd3cf4ee2df09535587154e0 (patch)
tree901440b13550ffccc512aae2b50d517d6a67a48d
parent16a82f06c40301045e4c05297ea93b85595dbbc4 (diff)
of/numa: fix a memory@ node can only contains one memory block
For a normal memory@ devicetree node, its reg property can contains more memory blocks. Because we don't known how many memory blocks maybe contained, so we try from index=0, increase 1 until error returned(the end). Signed-off-by: Zhen Lei <thunder.leizhen@huawei.com> Acked-by: Rob Herring <robh@kernel.org> Signed-off-by: Will Deacon <will.deacon@arm.com>
-rw-r--r--drivers/of/of_numa.c29
1 files changed, 10 insertions, 19 deletions
diff --git a/drivers/of/of_numa.c b/drivers/of/of_numa.c
index fb71b4ef1eeb..7b3fbdc0b278 100644
--- a/drivers/of/of_numa.c
+++ b/drivers/of/of_numa.c
@@ -63,13 +63,9 @@ static int __init of_numa_parse_memory_nodes(void)
63 struct device_node *np = NULL; 63 struct device_node *np = NULL;
64 struct resource rsrc; 64 struct resource rsrc;
65 u32 nid; 65 u32 nid;
66 int r = 0; 66 int i, r;
67
68 for (;;) {
69 np = of_find_node_by_type(np, "memory");
70 if (!np)
71 break;
72 67
68 for_each_node_by_type(np, "memory") {
73 r = of_property_read_u32(np, "numa-node-id", &nid); 69 r = of_property_read_u32(np, "numa-node-id", &nid);
74 if (r == -EINVAL) 70 if (r == -EINVAL)
75 /* 71 /*
@@ -78,23 +74,18 @@ static int __init of_numa_parse_memory_nodes(void)
78 * "numa-node-id" property 74 * "numa-node-id" property
79 */ 75 */
80 continue; 76 continue;
81 else if (r)
82 /* some other error */
83 break;
84 77
85 r = of_address_to_resource(np, 0, &rsrc); 78 for (i = 0; !r && !of_address_to_resource(np, i, &rsrc); i++)
86 if (r) { 79 r = numa_add_memblk(nid, rsrc.start, rsrc.end + 1);
87 pr_err("NUMA: bad reg property in memory node\n");
88 break;
89 }
90 80
91 r = numa_add_memblk(nid, rsrc.start, rsrc.end + 1); 81 if (!i || r) {
92 if (r) 82 of_node_put(np);
93 break; 83 pr_err("NUMA: bad property in memory node\n");
84 return r ? : -EINVAL;
85 }
94 } 86 }
95 of_node_put(np);
96 87
97 return r; 88 return 0;
98} 89}
99 90
100static int __init of_numa_parse_distance_map_v1(struct device_node *map) 91static int __init of_numa_parse_distance_map_v1(struct device_node *map)