blob: 6b4cbddcdfe15a403307c720c5c914195673d176 [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Kumar Gala38449a42009-09-10 03:02:13 -05002/*
Haiying Wang325a12f2011-01-20 22:26:31 +00003 * Copyright 2008-2011 Freescale Semiconductor, Inc.
Kumar Gala38449a42009-09-10 03:02:13 -05004 */
5
6#include <common.h>
Masahiro Yamada75f82d02018-03-05 01:20:11 +09007#include <linux/libfdt.h>
Kumar Gala38449a42009-09-10 03:02:13 -05008#include <fdt_support.h>
9
10#include <asm/processor.h>
11#include <asm/io.h>
12
13#include <asm/fsl_portals.h>
14#include <asm/fsl_liodn.h>
15
Kumar Gala38449a42009-09-10 03:02:13 -050016/* Update portal containter to match LAW setup of portal in phy map */
17void fdt_portal(void *blob, const char *compat, const char *container,
18 u64 addr, u32 size)
19{
20 int off;
21
22 off = fdt_node_offset_by_compatible(blob, -1, compat);
23 if (off < 0)
Bin Meng75a6a372022-10-26 12:40:07 +080024 return;
Kumar Gala38449a42009-09-10 03:02:13 -050025
26 off = fdt_parent_offset(blob, off);
27 /* if non-zero assume we have a container */
28 if (off > 0) {
29 char buf[60];
30 const char *p, *name;
31 u32 *range;
32 int len;
33
34 /* fixup ranges */
35 range = fdt_getprop_w(blob, off, "ranges", &len);
36 if (range == NULL) {
37 printf("ERROR: container for %s has no ranges", compat);
Bin Meng75a6a372022-10-26 12:40:07 +080038 return;
Kumar Gala38449a42009-09-10 03:02:13 -050039 }
40
41 range[0] = 0;
42 if (len == 16) {
43 range[1] = addr >> 32;
44 range[2] = addr & 0xffffffff;
45 range[3] = size;
46 } else {
47 range[1] = addr & 0xffffffff;
48 range[2] = size;
49 }
50 fdt_setprop_inplace(blob, off, "ranges", range, len);
51
52 /* fixup the name */
53 name = fdt_get_name(blob, off, &len);
54 p = memchr(name, '@', len);
55
56 if (p)
57 len = p - name;
58
59 /* if we are given a container name check it
60 * against what we found, if it doesnt match exit out */
61 if (container && (memcmp(container, name, len))) {
62 printf("WARNING: container names didn't match %s %s\n",
63 container, name);
Bin Meng75a6a372022-10-26 12:40:07 +080064 return;
Kumar Gala38449a42009-09-10 03:02:13 -050065 }
66
67 memcpy(&buf, name, len);
68 len += sprintf(&buf[len], "@%llx", addr);
69 fdt_set_name(blob, off, buf);
Bin Meng75a6a372022-10-26 12:40:07 +080070 return;
Kumar Gala38449a42009-09-10 03:02:13 -050071 }
72
73 printf("ERROR: %s isn't in a container. Not supported\n", compat);
74}