[PATCH] mach-k3: common_fdt: create a reserved memory node
Bryan Brattlof
bb at ti.com
Fri Feb 28 04:40:05 CET 2025
On February 27, 2025 thus sayeth Andrew Davis:
> On 2/27/25 11:14 AM, Bryan Brattlof wrote:
> > Some device trees may not have a reserved-memory node. Rather than
> > exiting early we should create a new reserved-memory node along with
> > the memory carveout for the firmware we (U-Boot) have placed.
> >
> > Signed-off-by: Bryan Brattlof <bb at ti.com>
> > ---
> > arch/arm/mach-k3/common_fdt.c | 7 +++----
> > 1 file changed, 3 insertions(+), 4 deletions(-)
> >
> > diff --git a/arch/arm/mach-k3/common_fdt.c b/arch/arm/mach-k3/common_fdt.c
> > index 4a01671156687..361b0c0b31b09 100644
> > --- a/arch/arm/mach-k3/common_fdt.c
> > +++ b/arch/arm/mach-k3/common_fdt.c
> > @@ -122,10 +122,8 @@ int fdt_fixup_reserved(void *blob, const char *name,
> > /* Find reserved-memory */
> > nodeoffset = fdt_subnode_offset(blob, 0, "reserved-memory");
> > - if (nodeoffset < 0) {
> > - debug("Could not find reserved-memory node\n");
> > - return 0;
> > - }
> > + if (nodeoffset < 0)
>
> We could also reverse this check and put the node deleting logic
> below inside this block. Same effect but removes the need for
> a goto for flow control here (goto considered harmful etc..)
>
> if (nodeoffset >= 0) {
> /* Find existing matching subnode and remove it */
> ...
> }
>
> Might make the intention a bit much, so either way is fine with me,
>
Ha it's funny you mentioned this. I had a previous version where I did
just that but wasn't sure how people felt about adding another tab to
such a large section. Then started looking at adding a fdt_* function
before landing on seeing what people thought about a goto label.
I guess I should take votes :)
~Bryan
> Acked-by: Andrew Davis <afd at ti.com>
>
> > + goto add_carveout;
> > /* Find existing matching subnode and remove it */
> > fdt_for_each_subnode(subnode, blob, nodeoffset) {
> > @@ -154,6 +152,7 @@ int fdt_fixup_reserved(void *blob, const char *name,
> > }
> > }
> > +add_carveout:
> > struct fdt_memory carveout = {
> > .start = new_address,
> > .end = new_address + new_size - 1,
> >
> > ---
> > base-commit: b78f8677cde8b1dde31b66f5b780f2e9b62fba7f
> > change-id: 20250227-reserved-memory-85f5d409e6a7
> >
> > Best regards,
More information about the U-Boot
mailing list