diff options
| author | Rebecca Schultz Zavin <rebecca@android.com> | 2012-11-15 10:31:02 -0800 | 
|---|---|---|
| committer | Arve Hjønnevåg <arve@android.com> | 2013-07-01 14:16:15 -0700 | 
| commit | 467ec9d01ca5877901625b1c4bb6a396b85ba362 (patch) | |
| tree | 046cc5c23d1a982d8c4021d7d70d00c6dd12c85d /drivers/gpu/ion/ion.c | |
| parent | 404bca0758936d274a911248fcf892f1d345065c (diff) | |
| download | olio-linux-3.10-467ec9d01ca5877901625b1c4bb6a396b85ba362.tar.xz olio-linux-3.10-467ec9d01ca5877901625b1c4bb6a396b85ba362.zip | |
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.
Change-Id: I9c79b30e3105e796060fc74b058f04093ee5e96e
Signed-off-by: Rebecca Schultz Zavin <rebecca@android.com>
Diffstat (limited to 'drivers/gpu/ion/ion.c')
| -rw-r--r-- | drivers/gpu/ion/ion.c | 33 | 
1 files changed, 26 insertions, 7 deletions
| diff --git a/drivers/gpu/ion/ion.c b/drivers/gpu/ion/ion.c index c30b8fb41a7..2465085c876 100644 --- a/drivers/gpu/ion/ion.c +++ b/drivers/gpu/ion/ion.c @@ -1343,16 +1343,35 @@ void ion_device_destroy(struct ion_device *dev)  void __init ion_reserve(struct ion_platform_data *data)  { -	int i, ret; +	int i;  	for (i = 0; i < data->nr; i++) {  		if (data->heaps[i].size == 0)  			continue; -		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); + +		if (data->heaps[i].base == 0) { +			phys_addr_t paddr; +			paddr = memblock_alloc_base(data->heaps[i].size, +						    data->heaps[i].align, +						    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);  	}  } |