diff options
author | Kumar Gala <galak@kernel.crashing.org> | 2008-02-19 21:28:18 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-02-19 21:28:18 -0800 |
commit | 74b20dad1c4cc0fd13ceca62fbab808919e1a7ea (patch) | |
tree | 50c6d5e350030bbea5d6be159fbc3e6af92188e5 /lib/lmb.c | |
parent | e5f270954364a4add74e8445b1db925ac534fcfb (diff) | |
download | lwn-74b20dad1c4cc0fd13ceca62fbab808919e1a7ea.tar.gz lwn-74b20dad1c4cc0fd13ceca62fbab808919e1a7ea.zip |
[LMB]: Fix lmb_add_region if region should be added at the head
We introduced a bug in fixing lmb_add_region to handle an initial
region being non-zero. Before that fix it was impossible to insert a
region at the head of the list since the first region always started
at zero.
Now that its possible for the first region to be non-zero we need to
check to see if the new region should be added at the head and if so
actually add it.
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'lib/lmb.c')
-rw-r--r-- | lib/lmb.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/lib/lmb.c b/lib/lmb.c index e3c8dcb04b46..3c43b95fef4a 100644 --- a/lib/lmb.c +++ b/lib/lmb.c @@ -184,6 +184,11 @@ static long __init lmb_add_region(struct lmb_region *rgn, u64 base, u64 size) break; } } + + if (base < rgn->region[0].base) { + rgn->region[0].base = base; + rgn->region[0].size = size; + } rgn->cnt++; return 0; |