diff options
author | Zhen Lei <thunder.leizhen@huawei.com> | 2016-09-01 02:54:53 -0400 |
---|---|---|
committer | Will Deacon <will.deacon@arm.com> | 2016-09-09 09:59:08 -0400 |
commit | 84b14256c18c967afd3cf4ee2df09535587154e0 (patch) | |
tree | 901440b13550ffccc512aae2b50d517d6a67a48d | |
parent | 16a82f06c40301045e4c05297ea93b85595dbbc4 (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.c | 29 |
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 | ||
100 | static int __init of_numa_parse_distance_map_v1(struct device_node *map) | 91 | static int __init of_numa_parse_distance_map_v1(struct device_node *map) |