Skip to content

Commit

Permalink
Merge branch 'next-cleanup' into for-v3.7
Browse files Browse the repository at this point in the history
  • Loading branch information
mszyprow committed Oct 2, 2012
2 parents abebfb1 + 75c5971 commit 461b6f0
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 16 deletions.
11 changes: 6 additions & 5 deletions arch/arm/mm/dma-mapping.c
Original file line number Diff line number Diff line change
Expand Up @@ -1059,11 +1059,12 @@ static struct page **__iommu_alloc_buffer(struct device *dev, size_t size, gfp_t
if (!pages[i])
goto error;

if (order)
if (order) {
split_page(pages[i], order);
j = 1 << order;
while (--j)
pages[i + j] = pages[i] + j;
j = 1 << order;
while (--j)
pages[i + j] = pages[i] + j;
}

__dma_clear_buffer(pages[i], PAGE_SIZE << order);
i += 1 << order;
Expand Down Expand Up @@ -1814,7 +1815,7 @@ int arm_iommu_attach_device(struct device *dev,
dev->archdata.mapping = mapping;
set_dma_ops(dev, &iommu_ops);

pr_info("Attached IOMMU controller to %s device.\n", dev_name(dev));
pr_debug("Attached IOMMU controller to %s device.\n", dev_name(dev));
return 0;
}

Expand Down
18 changes: 7 additions & 11 deletions drivers/base/dma-contiguous.c
Original file line number Diff line number Diff line change
Expand Up @@ -315,6 +315,7 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
{
unsigned long mask, pfn, pageno, start = 0;
struct cma *cma = dev_get_cma_area(dev);
struct page *page = NULL;
int ret;

if (!cma || !cma->count)
Expand All @@ -336,18 +337,17 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
for (;;) {
pageno = bitmap_find_next_zero_area(cma->bitmap, cma->count,
start, count, mask);
if (pageno >= cma->count) {
ret = -ENOMEM;
goto error;
}
if (pageno >= cma->count)
break;

pfn = cma->base_pfn + pageno;
ret = alloc_contig_range(pfn, pfn + count, MIGRATE_CMA);
if (ret == 0) {
bitmap_set(cma->bitmap, pageno, count);
page = pfn_to_page(pfn);
break;
} else if (ret != -EBUSY) {
goto error;
break;
}
pr_debug("%s(): memory range at %p is busy, retrying\n",
__func__, pfn_to_page(pfn));
Expand All @@ -356,12 +356,8 @@ struct page *dma_alloc_from_contiguous(struct device *dev, int count,
}

mutex_unlock(&cma_mutex);

pr_debug("%s(): returned %p\n", __func__, pfn_to_page(pfn));
return pfn_to_page(pfn);
error:
mutex_unlock(&cma_mutex);
return NULL;
pr_debug("%s(): returned %p\n", __func__, page);
return page;
}

/**
Expand Down

0 comments on commit 461b6f0

Please sign in to comment.