[PATCH] mach-k3: common_fdt: create a reserved memory node
Andrew Davis
afd at ti.com
Thu Feb 27 22:10:59 CET 2025
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,
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