[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20260112142009.1006236-38-herve.codina@bootlin.com>
Date: Mon, 12 Jan 2026 15:19:27 +0100
From: Herve Codina <herve.codina@...tlin.com>
To: David Gibson <david@...son.dropbear.id.au>,
Rob Herring <robh@...nel.org>,
Krzysztof Kozlowski <krzk@...nel.org>,
Conor Dooley <conor+dt@...nel.org>
Cc: Ayush Singh <ayush@...gleboard.org>,
Geert Uytterhoeven <geert@...ux-m68k.org>,
devicetree-compiler@...r.kernel.org,
devicetree@...r.kernel.org,
linux-kernel@...r.kernel.org,
devicetree-spec@...r.kernel.org,
Hui Pu <hui.pu@...ealthcare.com>,
Ian Ray <ian.ray@...ealthcare.com>,
Luca Ceresoli <luca.ceresoli@...tlin.com>,
Thomas Petazzoni <thomas.petazzoni@...tlin.com>,
Herve Codina <herve.codina@...tlin.com>
Subject: [RFC PATCH 37/77] dtc: Add support for import symbols sorting
dtc can sort items when the command line --sort option is set.
Add support for import symbols sorting when this option is used.
Signed-off-by: Herve Codina <herve.codina@...tlin.com>
---
livetree.c | 27 +++++++++++++++++++++++++++
1 file changed, 27 insertions(+)
diff --git a/livetree.c b/livetree.c
index dac5359..285f6e1 100644
--- a/livetree.c
+++ b/livetree.c
@@ -1014,9 +1014,36 @@ static void sort_node(struct node *node)
sort_node(c);
}
+static void sort_importsyms(struct dt_info *dti)
+{
+ int n = 0, i = 0;
+ struct symbol *symbol, **tbl;
+
+ for_each_symbol(dti->importsymlist, symbol)
+ n++;
+
+ if (n == 0)
+ return;
+
+ tbl = xmalloc(n * sizeof(*tbl));
+
+ for_each_symbol(dti->importsymlist, symbol)
+ tbl[i++] = symbol;
+
+ qsort(tbl, n, sizeof(*tbl), cmp_symbol);
+
+ dti->importsymlist = tbl[0];
+ for (i = 0; i < (n-1); i++)
+ tbl[i]->next = tbl[i+1];
+ tbl[n-1]->next = NULL;
+
+ free(tbl);
+}
+
void sort_tree(struct dt_info *dti)
{
sort_reserve_entries(dti);
+ sort_importsyms(dti);
sort_node(dti->dt);
}
--
2.52.0
Powered by blists - more mailing lists