[PATCH v2 3/6] lmb: check for a region's coalescing with all existing regions
Heinrich Schuchardt
heinrich.schuchardt at canonical.com
Thu Feb 20 11:34:25 CET 2025
On 20.02.25 10:56, Sughosh Ganu wrote:
> The lmb_add_region_flags() first checks if the new region to be added
> can be coalesced with existing regions. The check stops if the two
> regions are adjecent but their flags do not match. However, it is
> possible that the newly added region might be adjacent with the next
> existing region and with matching flags. Check for this possibility by
> not breaking out of the loop.
>
> Signed-off-by: Sughosh Ganu <sughosh.ganu at linaro.org>
> ---
> Changes since V1:
> * Continue the loop only in the case where the newly added region is
> after the existing region.
>
> lib/lmb.c | 2 +-
> 1 file changed, 1 insertion(+), 1 deletion(-)
>
> diff --git a/lib/lmb.c b/lib/lmb.c
> index 207f059ceb9..45888989457 100644
> --- a/lib/lmb.c
> +++ b/lib/lmb.c
> @@ -194,7 +194,7 @@ static long lmb_add_region_flags(struct alist *lmb_rgn_lst, phys_addr_t base,
> break;
> } else if (ret < 0) {
> if (flags != rgnflags)
> - break;
> + continue;
> rgn[i].size += size;
> coalesced++;
> break;
Reviewed-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
More information about the U-Boot
mailing list