]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
lmb: add a max parameter in the struct lmb_region
authorPatrick Delaunay <patrick.delaunay@foss.st.com>
Wed, 10 Mar 2021 09:16:27 +0000 (10:16 +0100)
committerTom Rini <trini@konsulko.com>
Thu, 22 Apr 2021 18:09:45 +0000 (14:09 -0400)
Add a max parameter in lmb_region struct to handle test
in lmb_add_region without using the MAX_LMB_REGIONS
define.

This patch allows to modify these size independently for
memory of reserved regions in the next patches.

Signed-off-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
include/lmb.h
lib/lmb.c

index a3247544c1ee4b03171d8e67c24228147215b132..f3397c7f730713f3bc0676d10c94b0d968eee5f9 100644 (file)
@@ -21,6 +21,7 @@ struct lmb_property {
 
 struct lmb_region {
        unsigned long cnt;
+       unsigned long max;
        struct lmb_property region[MAX_LMB_REGIONS+1];
 };
 
index 5cf419f439ad41f09b2075e2de9b704ffd280127..a926198d4879f1155826197ef7eba6255132dea7 100644 (file)
--- a/lib/lmb.c
+++ b/lib/lmb.c
@@ -95,6 +95,9 @@ static void lmb_coalesce_regions(struct lmb_region *rgn, unsigned long r1,
 
 void lmb_init(struct lmb *lmb)
 {
+       lmb->memory.max = MAX_LMB_REGIONS;
+       lmb->reserved.max = MAX_LMB_REGIONS;
+
        lmb->memory.cnt = 0;
        lmb->reserved.cnt = 0;
 }
@@ -179,7 +182,7 @@ static long lmb_add_region(struct lmb_region *rgn, phys_addr_t base, phys_size_t
 
        if (coalesced)
                return coalesced;
-       if (rgn->cnt >= MAX_LMB_REGIONS)
+       if (rgn->cnt >= rgn->max)
                return -1;
 
        /* Couldn't coalesce the LMB, so add it to the sorted table. */