Commit abb65272 authored by Tomi Valkeinen's avatar Tomi Valkeinen Committed by Linus Torvalds

memblock: fix memblock_is_region_memory()

memblock_is_region_memory() uses reserved memblocks to search for the
given region, while it should use the memory memblocks.

I encountered the problem with OMAP's framebuffer ram allocation.
Normally the ram is allocated dynamically, and this function is not
called.  However, if we want to pass the framebuffer from the bootloader
to the kernel (to retain the boot image), this function is used to check
the validity of the kernel parameters for the framebuffer ram area.
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@nokia.com>
Acked-by: default avatarYinghai Lu <yinghai@kernel.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Ingo Molnar <mingo@elte.hu>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent 453c7192
...@@ -683,13 +683,13 @@ int __init_memblock memblock_is_memory(phys_addr_t addr) ...@@ -683,13 +683,13 @@ int __init_memblock memblock_is_memory(phys_addr_t addr)
int __init_memblock memblock_is_region_memory(phys_addr_t base, phys_addr_t size) int __init_memblock memblock_is_region_memory(phys_addr_t base, phys_addr_t size)
{ {
int idx = memblock_search(&memblock.reserved, base); int idx = memblock_search(&memblock.memory, base);
if (idx == -1) if (idx == -1)
return 0; return 0;
return memblock.reserved.regions[idx].base <= base && return memblock.memory.regions[idx].base <= base &&
(memblock.reserved.regions[idx].base + (memblock.memory.regions[idx].base +
memblock.reserved.regions[idx].size) >= (base + size); memblock.memory.regions[idx].size) >= (base + size);
} }
int __init_memblock memblock_is_region_reserved(phys_addr_t base, phys_addr_t size) int __init_memblock memblock_is_region_reserved(phys_addr_t base, phys_addr_t size)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment