drivers: dma-contiguous: refactor dma_alloc_from_contiguous()
The dma_alloc_from_contiguous() function returns either a valid pointer to a page structure or NULL, the error code set when pageno >= cma->count is not used at all and can be safely removed. This commit also changes the function to avoid goto and have only one exit path and one place where mutex is unlocked. Signed-off-by: Michal Nazarewicz <mina86@mina86.com> [fixed compilation break caused by missing semicolon] Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
This commit is contained in:
parent
a0d271cbfe
commit
bdd43cb39f
@ -315,6 +315,7 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
|
|||||||
{
|
{
|
||||||
unsigned long mask, pfn, pageno, start = 0;
|
unsigned long mask, pfn, pageno, start = 0;
|
||||||
struct cma *cma = dev_get_cma_area(dev);
|
struct cma *cma = dev_get_cma_area(dev);
|
||||||
|
struct page *page = NULL;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!cma || !cma->count)
|
if (!cma || !cma->count)
|
||||||
@ -336,18 +337,17 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
|
|||||||
for (;;) {
|
for (;;) {
|
||||||
pageno = bitmap_find_next_zero_area(cma->bitmap, cma->count,
|
pageno = bitmap_find_next_zero_area(cma->bitmap, cma->count,
|
||||||
start, count, mask);
|
start, count, mask);
|
||||||
if (pageno >= cma->count) {
|
if (pageno >= cma->count)
|
||||||
ret = -ENOMEM;
|
break;
|
||||||
goto error;
|
|
||||||
}
|
|
||||||
|
|
||||||
pfn = cma->base_pfn + pageno;
|
pfn = cma->base_pfn + pageno;
|
||||||
ret = alloc_contig_range(pfn, pfn + count, MIGRATE_CMA);
|
ret = alloc_contig_range(pfn, pfn + count, MIGRATE_CMA);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
bitmap_set(cma->bitmap, pageno, count);
|
bitmap_set(cma->bitmap, pageno, count);
|
||||||
|
page = pfn_to_page(pfn);
|
||||||
break;
|
break;
|
||||||
} else if (ret != -EBUSY) {
|
} else if (ret != -EBUSY) {
|
||||||
goto error;
|
break;
|
||||||
}
|
}
|
||||||
pr_debug("%s(): memory range at %p is busy, retrying\n",
|
pr_debug("%s(): memory range at %p is busy, retrying\n",
|
||||||
__func__, pfn_to_page(pfn));
|
__func__, pfn_to_page(pfn));
|
||||||
@ -356,12 +356,8 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
|
|||||||
}
|
}
|
||||||
|
|
||||||
mutex_unlock(&cma_mutex);
|
mutex_unlock(&cma_mutex);
|
||||||
|
pr_debug("%s(): returned %p\n", __func__, page);
|
||||||
pr_debug("%s(): returned %p\n", __func__, pfn_to_page(pfn));
|
return page;
|
||||||
return pfn_to_page(pfn);
|
|
||||||
error:
|
|
||||||
mutex_unlock(&cma_mutex);
|
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user