From: Herve Codina <herve.codina@bootlin.com>
To: David Gibson <david@gibson.dropbear.id.au>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk@kernel.org>,
Conor Dooley <conor+dt@kernel.org>
Cc: Ayush Singh <ayush@beagleboard.org>,
Geert Uytterhoeven <geert@linux-m68k.org>,
devicetree-compiler@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, devicetree-spec@vger.kernel.org,
Hui Pu <hui.pu@gehealthcare.com>,
Ian Ray <ian.ray@gehealthcare.com>,
Luca Ceresoli <luca.ceresoli@bootlin.com>,
Thomas Petazzoni <thomas.petazzoni@bootlin.com>,
Herve Codina <herve.codina@bootlin.com>
Subject: [RFC PATCH 56/77] Add support for FDT_BEGIN_NODE_REF_SYM dtb tag
Date: Mon, 12 Jan 2026 15:19:46 +0100 [thread overview]
Message-ID: <20260112142009.1006236-57-herve.codina@bootlin.com> (raw)
In-Reply-To: <20260112142009.1006236-1-herve.codina@bootlin.com>
The FDT_BEGIN_NODE_REF dtb tag is a meta-data tag defining a referenced
node.
This kind of nodes can be present in addon dtbs and identifies a node
external to the addon dtb but modified by the addon.
For instance, if an addon adds a sub-node a node existing in the
device-tree the addon is applied to, the existing node needs to be
referenced by the addon dtb. This is the purpose of FDT_BEGIN_NODE_REF.
This tag typically identifies what we call orphan nodes in dts.
The structure of FDT_BEGIN_NODE_REF is identical to the structure of
FDT_BEGIN_NODE except that the node name is not present and it is
replaced by the node symbol reference needed to reference the node in
the base device-tree when the addon device-tree blob is applied.
The FDT_BEGIN_NODE_REF block is terminated by a FDT_END_NODE tag.
The FDT_BEGIN_NODE_REF tag is followed by:
- node symbol name (string including \0)
The symbol name used to reference the node in the base device-tree
when the addon is applied.
- padding:
Padding (0x00) added to have the next value aligned on 32bit.
- Node structure (see FDT_BEGIN_NODE):
Items provided by the addon to be merged in the referenced
node when the addon is applied.
- FDT_END_NODE tag
Example:
FDT_BEGIN_NODE_REF 'foo1' 0x00 0x00 0x00 ... FDT_END_NODE
This means that the external node referenced by 'foo1' is modified by
the addon. Items to merge when the addon is applied are represented by
the '...' part.
This is what is encoded in the dtb when the related dts has the
following orphan node:
&foo1 {
...
};
If several external nodes are modified by the addon (several orphan
nodes described in the addon), several FDT_BEGIN_NODE_REF are present.
Each of them related to an external node. For instance, having 'foo1'
and 'bar1' as external nodes leads to the following sequence:
FDT_BEGIN_NODE_REF 'foo1' 0x00 0x00 0x00 ... FDT_END_NODE
FDT_BEGIN_NODE_REF 'bar1' 0x00 0x00 0x00 ... FDT_END_NODE
The FDT_BEGIN_NODE_REF can be present only for a top level node.
Subnodes are identified by a FDT_BEGIN_NODE tag.
If FDT_BEGIN_NODE_REF tags are present in the dtb, they are present
after the root node definition (i.e. after the first FDT_BEGIN_NODE
/ FDT_END_NODE block).
Add support for this new dtb tag.
Signed-off-by: Herve Codina <herve.codina@bootlin.com>
---
fdtdump.c | 11 ++++++
flattree.c | 103 ++++++++++++++++++++++++++++++++++++++++++---------
libfdt/fdt.c | 10 +++++
libfdt/fdt.h | 2 +
4 files changed, 108 insertions(+), 18 deletions(-)
diff --git a/fdtdump.c b/fdtdump.c
index 04e6e38..7d58e3d 100644
--- a/fdtdump.c
+++ b/fdtdump.c
@@ -176,6 +176,17 @@ static void dump_blob(void *blob, bool debug)
continue;
}
+ if (tag == FDT_BEGIN_NODE_REF) {
+ last_prop_name = NULL;
+ s = p;
+ p = PALIGN(p + strlen(s) + 1, 4);
+
+ printf("%*s&%s {\n", depth * shift, "", s);
+
+ depth++;
+ continue;
+ }
+
if (tag == FDT_EXPORT_SYM) {
s = p;
p = PALIGN(p + strlen(s) + 1, 4);
diff --git a/flattree.c b/flattree.c
index 412c7f8..27f7608 100644
--- a/flattree.c
+++ b/flattree.c
@@ -51,6 +51,7 @@ struct emitter {
void (*export_sym)(void *);
void (*export_sym_ref)(void *);
void (*import_sym)(void *);
+ void (*beginnode_ref)(void *, struct label *labels);
};
static void bin_emit_cell(void *e, cell_t val)
@@ -125,6 +126,11 @@ static void bin_emit_import_sym(void *e)
bin_emit_cell(e, FDT_IMPORT_SYM);
}
+static void bin_emit_beginnode_ref(void *e, struct label *labels)
+{
+ bin_emit_cell(e, FDT_BEGIN_NODE_REF);
+}
+
static struct emitter bin_emitter = {
.cell = bin_emit_cell,
.string = bin_emit_string,
@@ -138,6 +144,7 @@ static struct emitter bin_emitter = {
.export_sym = bin_emit_export_sym,
.export_sym_ref = bin_emit_export_sym_ref,
.import_sym = bin_emit_import_sym,
+ .beginnode_ref = bin_emit_beginnode_ref,
};
static void emit_label(FILE *f, const char *prefix, const char *label)
@@ -292,6 +299,18 @@ static void asm_emit_import_sym(void *e)
die("FDT_IMPORT_SYM not supported in asm output\n");
}
+static void asm_emit_beginnode_ref(void *e, struct label *labels)
+{
+ /*
+ * Orphan nodes (FDT_BEGIN_NODE_REF tags) are an feature
+ * introduced for addons.
+ * Addons device-tree blob have to reason to be in the asm format.
+ *
+ * Need to be implemented if really needed.
+ */
+ die("FDT_BEGIN_NODE_REF not supported in asm output\n");
+}
+
static struct emitter asm_emitter = {
.cell = asm_emit_cell,
.string = asm_emit_string,
@@ -305,6 +324,7 @@ static struct emitter asm_emitter = {
.export_sym = asm_emit_export_sym,
.export_sym = asm_emit_export_sym_ref,
.import_sym = asm_emit_import_sym,
+ .beginnode_ref = asm_emit_beginnode_ref,
};
static int stringtable_insert(struct data *d, const char *str)
@@ -335,13 +355,17 @@ static void flatten_tree(struct node *tree, struct emitter *emit,
if (tree->deleted)
return;
- emit->beginnode(etarget, tree->labels);
-
- if (vi->flags & FTF_FULLPATH)
- emit->string(etarget, tree->fullpath, 0);
- else
- emit->string(etarget, tree->name, 0);
+ if ((vi->flags & FTF_REF_XXX) && tree->ref) {
+ emit->beginnode_ref(etarget, tree->labels);
+ emit->string(etarget, tree->ref, 0);
+ } else {
+ emit->beginnode(etarget, tree->labels);
+ if (vi->flags & FTF_FULLPATH)
+ emit->string(etarget, tree->fullpath, 0);
+ else
+ emit->string(etarget, tree->name, 0);
+ }
emit->align(etarget, sizeof(cell_t));
for_each_property(tree, prop) {
@@ -500,6 +524,22 @@ static void flatten_imports(struct symbol *importsymlist, struct emitter *emit,
}
}
+static void flatten_orphans(struct node *orphanlist, struct emitter *emit,
+ void *etarget, struct data *strbuf,
+ struct version_info *vi, uint32_t dt_flags)
+{
+ struct node *orphan;
+
+ if (!(vi->flags & FTF_REF_XXX))
+ return;
+
+ if (!(dt_flags & FDT_FLAG_ADDON) && orphanlist)
+ die("Only addons can have orphan nodes\n");
+
+ for_each_orphan(orphanlist, orphan)
+ flatten_tree(orphan, emit, etarget, strbuf, vi);
+}
+
void dt_to_blob(FILE *f, struct dt_info *dti, int version)
{
struct version_info *vi = NULL;
@@ -523,6 +563,9 @@ void dt_to_blob(FILE *f, struct dt_info *dti, int version)
flatten_tree(dti->dt, &bin_emitter, &dtbuf, &strbuf, vi);
flatten_imports(dti->importsymlist, &bin_emitter, &dtbuf, vi, dt_flags);
+ flatten_orphans(dti->orphanlist, &bin_emitter, &dtbuf, &strbuf, vi,
+ dt_flags);
+
bin_emit_cell(&dtbuf, FDT_END);
reservebuf = flatten_reserve_list(dti->reservelist, vi);
@@ -616,6 +659,9 @@ void dt_to_asm(FILE *f, struct dt_info *dti, int version)
if (dti->importsymlist)
die("Import symbols not supported in asm format\n");
+ if (dti->orphanlist)
+ die("Orphan nodes not supported in asm format\n");
+
for (i = 0; i < ARRAY_SIZE(version_table); i++) {
if (version_table[i].version == version)
@@ -912,7 +958,8 @@ static const char *nodename_from_path(const char *ppath, const char *cpath)
static struct node *unflatten_tree(struct inbuf *dtbuf,
struct inbuf *strbuf,
- const char *parent_flatname, int flags)
+ const char *parent_flatname, int flags,
+ bool is_orphan_node)
{
struct node *node;
const char *flatname;
@@ -922,14 +969,18 @@ static struct node *unflatten_tree(struct inbuf *dtbuf,
const char *str2;
node = build_node(NULL, NULL, NULL, NULL);
-
- flatname = flat_read_string(dtbuf);
-
- if (flags & FTF_FULLPATH)
- node->name = xstrdup(nodename_from_path(parent_flatname,
- flatname));
- else
- node->name = xstrdup(flatname);
+ if (is_orphan_node) {
+ str = flat_read_string(dtbuf);
+ orphan_node(node, str);
+ flatname = "";
+ } else {
+ flatname = flat_read_string(dtbuf);
+ if (flags & FTF_FULLPATH)
+ node->name = xstrdup(nodename_from_path(parent_flatname,
+ flatname));
+ else
+ node->name = xstrdup(flatname);
+ }
do {
struct symbol *exportsym;
@@ -949,7 +1000,7 @@ static struct node *unflatten_tree(struct inbuf *dtbuf,
break;
case FDT_BEGIN_NODE:
- child = unflatten_tree(dtbuf,strbuf, flatname, flags);
+ child = unflatten_tree(dtbuf, strbuf, flatname, flags, false);
add_child(node, child);
break;
@@ -1012,6 +1063,11 @@ static struct node *unflatten_tree(struct inbuf *dtbuf,
add_symbol(&node->exportsymlist, exportsym);
break;
+ case FDT_BEGIN_NODE_REF:
+ /* FDT_BEGIN_NODE_REF can only be at the FDT top level. */
+ die("Unexpected FDT_BEGIN_NODE_REF tag\n");
+ break;
+
default:
die("Invalid opcode word %08x in device tree blob\n",
val);
@@ -1039,6 +1095,8 @@ struct dt_info *dt_from_blob(const char *fname)
struct node *tree;
struct symbol *importsymlist = NULL;
struct symbol *importsym;
+ struct node *orphanlist = NULL;
+ struct node *orphan;
uint32_t val;
int flags = 0;
unsigned int dtsflags = 0;
@@ -1150,7 +1208,7 @@ struct dt_info *dt_from_blob(const char *fname)
if (val != FDT_BEGIN_NODE)
die("Device tree blob doesn't begin with FDT_BEGIN_NODE (begins with 0x%08x)\n", val);
- tree = unflatten_tree(&dtbuf, &strbuf, "", flags);
+ tree = unflatten_tree(&dtbuf, &strbuf, "", flags, false);
val = flat_read_word(&dtbuf);
@@ -1162,6 +1220,15 @@ struct dt_info *dt_from_blob(const char *fname)
val = flat_read_word(&dtbuf);
}
}
+
+ if (flags & FTF_REF_XXX) {
+ while (val == FDT_BEGIN_NODE_REF) {
+ orphan = unflatten_tree(&dtbuf, &strbuf, "", flags,
+ true);
+ addon_add_orphan_node(&orphanlist, orphan);
+ val = flat_read_word(&dtbuf);
+ }
+ }
}
if (val != FDT_END)
@@ -1172,5 +1239,5 @@ struct dt_info *dt_from_blob(const char *fname)
fclose(f);
return build_dt_info(DTSF_V1 | dtsflags, reservelist, tree, boot_cpuid_phys,
- importsymlist, NULL);
+ importsymlist, orphanlist);
}
diff --git a/libfdt/fdt.c b/libfdt/fdt.c
index c169dd9..dc58d2d 100644
--- a/libfdt/fdt.c
+++ b/libfdt/fdt.c
@@ -232,6 +232,15 @@ uint32_t fdt_next_tag_full(const void *fdt, int startoffset, int *nextoffset)
return FDT_END; /* premature end */
break;
+ case FDT_BEGIN_NODE_REF:
+ /* Skip ref */
+ do {
+ p = fdt_offset_ptr(fdt, offset++, 1);
+ } while (p && (*p != '\0'));
+ if (!can_assume(VALID_DTB) && !p)
+ return FDT_END; /* premature end */
+ break;
+
case FDT_EXPORT_SYM:
/* Skip name */
do {
@@ -342,6 +351,7 @@ uint32_t fdt_next_tag(const void *fdt, int startoffset, int *nextoffset)
break;
case FDT_IMPORT_SYM:
+ case FDT_BEGIN_NODE_REF:
/* Those tags are available at the root level, after the
* root node -> Skip everything until FDT_END
*/
diff --git a/libfdt/fdt.h b/libfdt/fdt.h
index b6c23ef..8a39458 100644
--- a/libfdt/fdt.h
+++ b/libfdt/fdt.h
@@ -63,6 +63,8 @@ struct fdt_property {
#define FDT_REF_LOCAL 0x5 /* local phandle reference: offset */
#define FDT_REF_PHANDLE 0x6 /* external phandle reference: offset,
external label */
+#define FDT_BEGIN_NODE_REF 0x7 /* Same as FDT_BEGIN_NODE but with
+ reference instead of name */
#define FDT_END 0x9
#define FDT_EXPORT_SYM 0xa /* export symbol: name, phandle value */
#define FDT_EXPORT_SYM_REF 0xb /* export symbol: name, phandle value (maybe
--
2.52.0
next prev parent reply other threads:[~2026-01-12 14:21 UTC|newest]
Thread overview: 160+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-12 14:18 [RFC PATCH 00/77] Add support for dtb metadata and addon device-trees Herve Codina
2026-01-12 14:18 ` [RFC PATCH 01/77] checks: Use consistent type for strspn() returned value Herve Codina
2026-01-12 14:55 ` Ayush Singh
2026-01-13 3:08 ` David Gibson
2026-01-13 4:42 ` David Gibson
2026-01-13 8:02 ` Herve Codina
2026-01-12 14:18 ` [RFC PATCH 02/77] Introduce v18 dtb version Herve Codina
2026-01-15 0:12 ` David Gibson
2026-01-16 9:09 ` Herve Codina
2026-01-19 5:13 ` David Gibson
2026-01-19 9:48 ` Herve Codina
2026-01-28 1:49 ` David Gibson
2026-01-20 20:38 ` Rob Herring
2026-01-29 1:40 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 03/77] libfdt: Introduce fdt_next_tag_full() and use it in fdt_next_tag() Herve Codina
2026-01-15 0:17 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 04/77] dtc: Allow to use data_append_markers() out of data.c Herve Codina
2026-01-15 0:18 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 05/77] fdtdump: Change FDT_PROP prob handling to ease future addition Herve Codina
2026-01-12 15:41 ` Ayush Singh
2026-01-15 0:28 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 06/77] Add support for FDT_REF_LOCAL dtb tag Herve Codina
2026-01-13 19:22 ` Rob Herring
2026-01-15 0:34 ` David Gibson
2026-01-15 15:54 ` Rob Herring
2026-01-16 10:16 ` Herve Codina
2026-01-16 10:17 ` Herve Codina
2026-01-19 6:16 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 07/77] livetree: Improve get_node_by_phandle() Herve Codina
2026-01-15 0:41 ` David Gibson
2026-01-16 10:52 ` Herve Codina
2026-01-19 5:18 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 08/77] dtc: Introduce update_phandles_ref() Herve Codina
2026-01-15 0:46 ` David Gibson
2026-01-16 11:26 ` Herve Codina
2026-01-19 5:21 ` David Gibson
2026-01-12 14:18 ` [RFC PATCH 09/77] dtc: Introduce mark_local_phandles() Herve Codina
2026-01-15 0:48 ` David Gibson
2026-01-16 13:09 ` Herve Codina
2026-01-19 5:46 ` David Gibson
2026-01-19 12:14 ` Herve Codina
2026-01-12 14:19 ` [RFC PATCH 10/77] tests: Add basic metadata tests Herve Codina
2026-01-15 0:50 ` David Gibson
2026-01-16 13:36 ` Herve Codina
2026-01-19 5:32 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 11/77] Add support for FDT_REF_PHANDLE dtb tag Herve Codina
2026-01-15 1:24 ` David Gibson
2026-01-16 15:17 ` Herve Codina
2026-01-19 5:40 ` David Gibson
2026-01-19 13:19 ` Herve Codina
2026-01-12 14:19 ` [RFC PATCH 12/77] tests: metadata: Add external phandle reference tests Herve Codina
2026-01-12 14:19 ` [RFC PATCH 13/77] Introduce dt_flags field in dtb header Herve Codina
2026-01-15 1:29 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 14/77] tests: metadata: Add a first test related to the dt_flags header field Herve Codina
2026-01-12 14:19 ` [RFC PATCH 15/77] Add support for /addon/ keyword Herve Codina
2026-01-12 14:19 ` [RFC PATCH 16/77] tests: metadata: Add a test related to addon dt_flags header value Herve Codina
2026-01-12 14:19 ` [RFC PATCH 17/77] tests: metadata: Add a basic addon test Herve Codina
2026-01-12 14:19 ` [RFC PATCH 18/77] dtc-parser.y: Avoid an empty proplist Herve Codina
2026-01-15 1:34 ` David Gibson
2026-01-16 16:22 ` Herve Codina
2026-01-12 14:19 ` [RFC PATCH 19/77] dtc: Introduce export symbols Herve Codina
2026-01-15 5:52 ` David Gibson
2026-01-16 16:27 ` Herve Codina
2026-01-19 5:51 ` David Gibson
2026-01-19 13:51 ` Herve Codina
2026-01-21 2:35 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 20/77] dtc: Add support for /export/ dts keyword parsing Herve Codina
2026-01-15 5:57 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 21/77] checks: Handle export symbols in fixup_phandle_references() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 22/77] dtc: Add export symbols (/export/ keyword) in generated dts file Herve Codina
2026-01-12 14:19 ` [RFC PATCH 23/77] dtc: Introduce mark_local_exports() Herve Codina
2026-01-15 6:01 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 24/77] dtc: Introduce update_exports_ref() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 25/77] Add support for FDT_EXPORT_SYM dtb tag Herve Codina
2026-01-15 6:23 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 26/77] tests: metadata: Add export symbols with local references tests Herve Codina
2026-01-12 14:19 ` [RFC PATCH 27/77] dtc: Add support for export symbols sorting Herve Codina
2026-01-12 14:19 ` [RFC PATCH 28/77] tests: metadata: Add a test " Herve Codina
2026-01-12 14:19 ` [RFC PATCH 29/77] Add support for FDT_EXPORT_SYM_REF dtb tag Herve Codina
2026-01-15 6:25 ` David Gibson
2026-01-19 15:46 ` Herve Codina
2026-01-29 1:36 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 30/77] tests: metadata: Add export symbols with external references tests Herve Codina
2026-01-12 14:19 ` [RFC PATCH 31/77] dtc: Introduce import symbols Herve Codina
2026-01-12 14:19 ` [RFC PATCH 32/77] dtc-parser: Introduce last_header_flags Herve Codina
2026-01-15 6:31 ` David Gibson
2026-01-19 14:11 ` Herve Codina
2026-01-21 2:37 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 33/77] dtc: Add support for /import/ dts keyword parsing Herve Codina
2026-01-12 14:19 ` [RFC PATCH 34/77] dtc: Add import symbols (/import/ keyword) in generated dts file Herve Codina
2026-01-12 14:19 ` [RFC PATCH 35/77] Add support for FDT_IMPORT_SYM dtb tag Herve Codina
2026-01-15 6:41 ` David Gibson
2026-01-19 14:36 ` Herve Codina
2026-01-28 2:25 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 36/77] tests: metadata: Add import symbols tests Herve Codina
2026-01-12 14:19 ` [RFC PATCH 37/77] dtc: Add support for import symbols sorting Herve Codina
2026-01-12 14:19 ` [RFC PATCH 38/77] tests: metadata: Improve sort test to check " Herve Codina
2026-01-12 14:19 ` [RFC PATCH 39/77] check: Get 'chosen' node using get_subnode() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 40/77] dtc: Introduce dti_get_node_by_path() Herve Codina
2026-01-15 6:47 ` David Gibson
2026-01-19 15:52 ` Herve Codina
2026-01-29 1:38 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 41/77] dtc: Introduce dti_get_node_by_label() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 42/77] dtc: Introduce dti_get_node_by_phandle() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 43/77] dtc: Introduce dti_get_node_by_ref() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 44/77] dtc: Introduce dti_get_node_phandle() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 45/77] dtc: Introduce dti_get_property_by_label() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 46/77] dtc: Introduce dti_get_marker_label() Herve Codina
2026-01-15 6:51 ` David Gibson
2026-01-19 16:02 ` Herve Codina
2026-01-21 9:02 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 47/77] dtc: Introduce dti_fill_fullpaths() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 48/77] dtc: Introduce orphan nodes Herve Codina
2026-01-12 14:19 ` [RFC PATCH 49/77] dtc: Handle orphan nodes in dti_get_xxx_by_yyy() Herve Codina
2026-01-15 6:55 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 50/77] dtc: Handle orphan nodes in mark_local_xxx() and update_xxx_ref() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 51/77] dtc: Avoid NULL fullpath for nodes in orphan trees Herve Codina
2026-01-15 6:56 ` David Gibson
2026-01-19 16:11 ` Herve Codina
2026-01-12 14:19 ` [RFC PATCH 52/77] checks: Perform checks for orphan nodes Herve Codina
2026-01-12 14:19 ` [RFC PATCH 53/77] dtc: Rename add_orphan_node() to plugin_add_orphan_node() Herve Codina
2026-01-12 14:19 ` [RFC PATCH 54/77] dtc: Add basic support for addon orphan nodes dts parsing Herve Codina
2026-01-12 14:19 ` [RFC PATCH 55/77] dtc: Add orphan nodes in generated dts file Herve Codina
2026-01-12 14:19 ` Herve Codina [this message]
2026-01-12 14:19 ` [RFC PATCH 57/77] tests: metadata: Add basic test for addon orphan nodes Herve Codina
2026-01-12 14:19 ` [RFC PATCH 58/77] dtc: Add support for missing root node in addon device-tree Herve Codina
2026-01-12 14:19 ` [RFC PATCH 59/77] tests: metadata: Add a test for addon without root node Herve Codina
2026-01-12 14:19 ` [RFC PATCH 60/77] dtc: Allow parser_get_node_by_ref() to return an orphan node for merging purpose Herve Codina
2026-01-12 14:19 ` [RFC PATCH 61/77] tests: metadata: Add a test related to orphan node merging Herve Codina
2026-01-12 14:19 ` [RFC PATCH 62/77] dtc: Add support for orphan nodes sorting Herve Codina
2026-01-12 14:19 ` [RFC PATCH 63/77] tests: metadata: Improve sort test to check " Herve Codina
2026-01-12 14:19 ` [RFC PATCH 64/77] dtc: Add support for references by path involving orphan nodes Herve Codina
2026-01-15 7:01 ` David Gibson
2026-01-19 16:38 ` Herve Codina
2026-01-21 9:06 ` David Gibson
2026-01-21 16:30 ` Herve Codina
2026-01-29 2:00 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 65/77] tests: metadata: Add a test " Herve Codina
2026-01-12 14:19 ` [RFC PATCH 66/77] dtc: Add support for namespace labels references Herve Codina
2026-01-12 14:19 ` [RFC PATCH 67/77] tests: metadata: Add a test " Herve Codina
2026-01-12 14:19 ` [RFC PATCH 68/77] libfdt: Introduce fdt_getprop_by_offset_w() Herve Codina
2026-01-15 7:05 ` David Gibson
2026-01-12 14:19 ` [RFC PATCH 69/77] libfdt: Introduce fdt_getprop_offset() Herve Codina
2026-01-12 14:20 ` [RFC PATCH 70/77] libfdt: Add support for applying an addon on a base device-tree blob Herve Codina
2026-01-12 14:20 ` [RFC PATCH 71/77] Add fdtaddon tool to apply an addon Herve Codina
2026-01-12 14:20 ` [RFC PATCH 72/77] tests: Add a first basic test for fdtaddon Herve Codina
2026-01-12 14:20 ` [RFC PATCH 73/77] tests: fdtaddon: Add a basic test for addons using an orphan nodes Herve Codina
2026-01-12 14:20 ` [RFC PATCH 74/77] tests: fdtaddon: Add a basic test for addons with unresolved phandle references Herve Codina
2026-01-12 14:20 ` [RFC PATCH 75/77] tests: fdtaddon: Add a test for addons using namespace label references Herve Codina
2026-01-12 14:20 ` [RFC PATCH 76/77] tests: fdtaddon: Add a test for using 'stacked' addons Herve Codina
2026-01-12 14:20 ` [RFC PATCH 77/77] tests: fdtaddon: Add a test using more realistic dts and dtsa Herve Codina
2026-01-12 14:49 ` [RFC PATCH 00/77] Add support for dtb metadata and addon device-trees Ayush Singh
2026-01-13 18:44 ` Rob Herring
2026-01-14 16:18 ` Herve Codina
2026-01-19 6:00 ` David Gibson
2026-01-27 15:19 ` Herve Codina
2026-01-27 22:06 ` Rob Herring
2026-01-29 5:08 ` David Gibson
2026-01-15 0:08 ` David Gibson
2026-01-15 7:11 ` David Gibson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20260112142009.1006236-57-herve.codina@bootlin.com \
--to=herve.codina@bootlin.com \
--cc=ayush@beagleboard.org \
--cc=conor+dt@kernel.org \
--cc=david@gibson.dropbear.id.au \
--cc=devicetree-compiler@vger.kernel.org \
--cc=devicetree-spec@vger.kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=geert@linux-m68k.org \
--cc=hui.pu@gehealthcare.com \
--cc=ian.ray@gehealthcare.com \
--cc=krzk@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=luca.ceresoli@bootlin.com \
--cc=robh@kernel.org \
--cc=thomas.petazzoni@bootlin.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox