From: Sughosh Ganu Date: Mon, 21 Oct 2024 17:24:33 +0000 (+0530) Subject: fdt: lmb: add reserved regions as no-overwrite X-Git-Tag: v2025.01-rc5-pxa1908~183 X-Git-Url: http://git.dujemihanovic.xyz/img/html/%7B%7B%20%28.OutputFormats.Get?a=commitdiff_plain;h=827dee587b75f5dfe109672f2de91bc7ac8bdc0d;p=u-boot.git fdt: lmb: add reserved regions as no-overwrite The boot_fdt_add_mem_rsv_regions() function reserves the memreserve and reserved-memory regions. These regions are being set with the LMB_NONE flag which allows overwriting and re-using the regions. This was fine earlier when the LMB memory map was local and not enforced globally. But that is no longer the case. Mark these regions as LMB_NOOVERWRITE so that they cannot be used. Signed-off-by: Sughosh Ganu Reported-by: Vaishnav Achath --- diff --git a/boot/image-fdt.c b/boot/image-fdt.c index 8eda521693..9a1fa8840d 100644 --- a/boot/image-fdt.c +++ b/boot/image-fdt.c @@ -110,7 +110,7 @@ void boot_fdt_add_mem_rsv_regions(void *fdt_blob) for (i = 0; i < total; i++) { if (fdt_get_mem_rsv(fdt_blob, i, &addr, &size) != 0) continue; - boot_fdt_reserve_region(addr, size, LMB_NONE); + boot_fdt_reserve_region(addr, size, LMB_NOOVERWRITE); } /* process reserved-memory */ @@ -122,7 +122,7 @@ void boot_fdt_add_mem_rsv_regions(void *fdt_blob) ret = fdt_get_resource(fdt_blob, subnode, "reg", 0, &res); if (!ret && fdtdec_get_is_enabled(fdt_blob, subnode)) { - flags = LMB_NONE; + flags = LMB_NOOVERWRITE; if (fdtdec_get_bool(fdt_blob, subnode, "no-map")) flags = LMB_NOMAP;