aboutsummaryrefslogtreecommitdiffstats
path: root/arch/sparc/kernel
diff options
context:
space:
mode:
Diffstat (limited to 'arch/sparc/kernel')
-rw-r--r--arch/sparc/kernel/of_device.c26
1 files changed, 22 insertions, 4 deletions
diff --git a/arch/sparc/kernel/of_device.c b/arch/sparc/kernel/of_device.c
index c59014886afe..4ef160755881 100644
--- a/arch/sparc/kernel/of_device.c
+++ b/arch/sparc/kernel/of_device.c
@@ -344,6 +344,27 @@ static int __init build_one_resource(struct device_node *parent,
344 return 1; 344 return 1;
345} 345}
346 346
347static int __init use_1to1_mapping(struct device_node *pp)
348{
349 /* If we have a ranges property in the parent, use it. */
350 if (of_find_property(pp, "ranges", NULL) != NULL)
351 return 0;
352
353 /* Some SBUS devices use intermediate nodes to express
354 * hierarchy within the device itself. These aren't
355 * real bus nodes, and don't have a 'ranges' property.
356 * But, we should still pass the translation work up
357 * to the SBUS itself.
358 */
359 if (!strcmp(pp->name, "dma") ||
360 !strcmp(pp->name, "espdma") ||
361 !strcmp(pp->name, "ledma") ||
362 !strcmp(pp->name, "lebuffer"))
363 return 0;
364
365 return 1;
366}
367
347static int of_resource_verbose; 368static int of_resource_verbose;
348 369
349static void __init build_device_resources(struct of_device *op, 370static void __init build_device_resources(struct of_device *op,
@@ -389,10 +410,7 @@ static void __init build_device_resources(struct of_device *op,
389 410
390 memcpy(addr, reg, na * 4); 411 memcpy(addr, reg, na * 4);
391 412
392 /* If the immediate parent has no ranges property to apply, 413 if (use_1to1_mapping(pp)) {
393 * just use a 1<->1 mapping.
394 */
395 if (of_find_property(pp, "ranges", NULL) == NULL) {
396 result = of_read_addr(addr, na); 414 result = of_read_addr(addr, na);
397 goto build_res; 415 goto build_res;
398 } 416 }