[PATCH 08/20] dtoc: Output the device in a separate function
Simon Glass
sjg at chromium.org
Thu Dec 17 21:57:22 CET 2020
Reduce the length of output_node() by moving the device-output
functionality into a separate function.
Signed-off-by: Simon Glass <sjg at chromium.org>
---
tools/dtoc/dtb_platdata.py | 33 ++++++++++++++++++++++-----------
1 file changed, 22 insertions(+), 11 deletions(-)
diff --git a/tools/dtoc/dtb_platdata.py b/tools/dtoc/dtb_platdata.py
index be38f5876b4..b429c13ef1b 100644
--- a/tools/dtoc/dtb_platdata.py
+++ b/tools/dtoc/dtb_platdata.py
@@ -630,6 +630,27 @@ class DtbPlatdata(object):
self.buf(', '.join(vals[i:i + 8]))
self.buf('}')
+ def _declare_device(self, var_name, struct_name, node_parent):
+ """Add a device declaration to the output
+
+ This declares a U_BOOT_DEVICE() for the device being processed
+
+ Args:
+ var_name: C name for the node
+ struct_name: Name for the dt struct associated with the node
+ node_parent: Parent of the node (or None if none)
+ """
+ self.buf('U_BOOT_DEVICE(%s) = {\n' % var_name)
+ self.buf('\t.name\t\t= "%s",\n' % struct_name)
+ self.buf('\t.plat\t= &%s%s,\n' % (VAL_PREFIX, var_name))
+ self.buf('\t.plat_size\t= sizeof(%s%s),\n' % (VAL_PREFIX, var_name))
+ idx = -1
+ if node_parent and node_parent in self._valid_nodes:
+ idx = node_parent.idx
+ self.buf('\t.parent_idx\t= %d,\n' % idx)
+ self.buf('};\n')
+ self.buf('\n')
+
def output_node(self, node):
"""Output the C code for a node
@@ -656,17 +677,7 @@ class DtbPlatdata(object):
self.buf(',\n')
self.buf('};\n')
- # Add a device declaration
- self.buf('U_BOOT_DEVICE(%s) = {\n' % var_name)
- self.buf('\t.name\t\t= "%s",\n' % struct_name)
- self.buf('\t.plat\t= &%s%s,\n' % (VAL_PREFIX, var_name))
- self.buf('\t.plat_size\t= sizeof(%s%s),\n' % (VAL_PREFIX, var_name))
- idx = -1
- if node.parent and node.parent in self._valid_nodes:
- idx = node.parent.idx
- self.buf('\t.parent_idx\t= %d,\n' % idx)
- self.buf('};\n')
- self.buf('\n')
+ self._declare_device(var_name, struct_name, node.parent)
self.out(''.join(self.get_buf()))
--
2.29.2.684.gfbc64c5ab5-goog
More information about the U-Boot
mailing list