[PATCH v2 2/6] lmb: handle scenario of encompassing overlap
Heinrich Schuchardt
heinrich.schuchardt at canonical.com
Thu Feb 20 11:32:47 CET 2025
On 20.02.25 10:56, Sughosh Ganu wrote:
> The lmb_fix_over_lap_regions() function is called if the added region
> overlaps with an existing region. The function then fixes the overlap
> and removes the redundant region. However, it makes certain
> assumptions. One assumption is that the overlap would not encompass
> the existing region. Another assumption is that the overlap only
> occurs between two regions -- the scenario of the added region
> overlapping multiple existing regions is not being handled. Handle
> these cases by instead calling lmb_resize_regions(). Also remove the
> now superfluous lmb_fix_over_lap_regions().
>
> Signed-off-by: Sughosh Ganu <sughosh.ganu at linaro.org>
> ---
> Changes since V1:
> * Use lmb_resize_regions() to fix the overlap instead of
> lmb_fix_over_lap_regions().
> * Remove the now superfluous lmb_fix_over_lap_regions().
>
>
> Note: To be applied after an A-b/R-b/T-b from the original author of
> lmb_fix_over_lap_regions().
>
>
> lib/lmb.c | 30 +++++++++---------------------
> 1 file changed, 9 insertions(+), 21 deletions(-)
>
> diff --git a/lib/lmb.c b/lib/lmb.c
> index d7d2c8c6dfd..207f059ceb9 100644
> --- a/lib/lmb.c
> +++ b/lib/lmb.c
> @@ -100,25 +100,6 @@ static void lmb_coalesce_regions(struct alist *lmb_rgn_lst, unsigned long r1,
> lmb_remove_region(lmb_rgn_lst, r2);
> }
>
> -/*Assumption : base addr of region 1 < base addr of region 2*/
> -static void lmb_fix_over_lap_regions(struct alist *lmb_rgn_lst,
> - unsigned long r1, unsigned long r2)
> -{
> - struct lmb_region *rgn = lmb_rgn_lst->data;
> -
> - phys_addr_t base1 = rgn[r1].base;
> - phys_size_t size1 = rgn[r1].size;
> - phys_addr_t base2 = rgn[r2].base;
> - phys_size_t size2 = rgn[r2].size;
> -
> - if (base1 + size1 > base2 + size2) {
> - printf("This will not be a case any time\n");
> - return;
> - }
> - rgn[r1].size = base2 + size2 - base1;
> - lmb_remove_region(lmb_rgn_lst, r2);
> -}
> -
> static long lmb_resize_regions(struct alist *lmb_rgn_lst,
> unsigned long idx_start,
> phys_addr_t base, phys_size_t size)
> @@ -239,8 +220,15 @@ static long lmb_add_region_flags(struct alist *lmb_rgn_lst, phys_addr_t base,
> lmb_coalesce_regions(lmb_rgn_lst, i, i + 1);
> coalesced++;
> } else if (lmb_regions_overlap(lmb_rgn_lst, i, i + 1)) {
> - /* fix overlapping area */
> - lmb_fix_over_lap_regions(lmb_rgn_lst, i, i + 1);
> + /* fix overlapping areas */
> + phys_addr_t rgnbase = rgn[i].base;
> + phys_size_t rgnsize = rgn[i].size;
> +
> + ret = lmb_resize_regions(lmb_rgn_lst, i,
> + rgnbase, rgnsize);
> + if (ret < 0)
> + return -1;
> +
> coalesced++;
> }
> }
It would be great if in a future patch you could document all LMB
functions like lmb_resize_regions() which lack a function description.
Reviewed-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
More information about the U-Boot
mailing list