Commit fa9bba55 authored by Rebecca Schultz Zavin's avatar Rebecca Schultz Zavin Committed by Greg Kroah-Hartman

gpu: ion: Modify reserve function for carveouts with no start address

This patch allows you to specify a heap that requires carveout memory
but that doesn't specify a start address.  Memblock_alloc will be called
to find a location for these heaps.
Signed-off-by: default avatarRebecca Schultz Zavin <rebecca@android.com>
[jstultz: modified patch to apply to staging directory]
Signed-off-by: default avatarJohn Stultz <john.stultz@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 092c354b
...@@ -1343,16 +1343,35 @@ void ion_device_destroy(struct ion_device *dev) ...@@ -1343,16 +1343,35 @@ void ion_device_destroy(struct ion_device *dev)
void __init ion_reserve(struct ion_platform_data *data) void __init ion_reserve(struct ion_platform_data *data)
{ {
int i, ret; int i;
for (i = 0; i < data->nr; i++) { for (i = 0; i < data->nr; i++) {
if (data->heaps[i].size == 0) if (data->heaps[i].size == 0)
continue; continue;
ret = memblock_reserve(data->heaps[i].base,
data->heaps[i].size); if (data->heaps[i].base == 0) {
if (ret) phys_addr_t paddr;
pr_err("memblock reserve of %x@%lx failed\n", paddr = memblock_alloc_base(data->heaps[i].size,
data->heaps[i].size, data->heaps[i].align,
data->heaps[i].base); MEMBLOCK_ALLOC_ANYWHERE);
if (!paddr) {
pr_err("%s: error allocating memblock for "
"heap %d\n",
__func__, i);
continue;
}
data->heaps[i].base = paddr;
} else {
int ret = memblock_reserve(data->heaps[i].base,
data->heaps[i].size);
if (ret)
pr_err("memblock reserve of %x@%lx failed\n",
data->heaps[i].size,
data->heaps[i].base);
}
pr_info("%s: %s reserved base %lx size %d\n", __func__,
data->heaps[i].name,
data->heaps[i].base,
data->heaps[i].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