aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm
diff options
context:
space:
mode:
authorRahul Sharma <rahul.sharma@samsung.com>2013-01-28 08:38:48 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2013-03-23 07:17:57 -0400
commitdca25cb80065849e71e5c95a7fd74b0d67695bf3 (patch)
tree63565404835747b88b7b7d09cb0c4d5bc1c7265e /drivers/gpu/drm
parent6e995e231a90ce7c5ce2a9eae23c8e22f4388db1 (diff)
drm: modify pages_to_sg prime helper to create optimized SG table
It fixes the issue arises due to passing 'nr_pages' in place of 'nents' to sg_alloc_table. When ARM_HAS_SG_CHAIN is disabled, it is causing failure in creating SG table for the buffers having more than 204 physical pages i.e. equal to SG_MAX_SINGLE_ALLOC. When using sg_alloc_table_from_pages interface, in place of sg_alloc_table, page list will be passes to get each contiguous section which is represented by a single entry in the table. For a Contiguous Buffer, number of entries should be equal to 1. Following check is causing the failure which is not applicable for Non-Contig buffers: if (WARN_ON_ONCE(nents > max_ents)) return -EINVAL; Above patch is well tested for EXYNOS4 and EXYNOS5 for with/wihtout IOMMU supprot. NOUVEAU and RADEON platforms also depends on drm_prime_pages_to_sg helper function. This set is base on "exynos-drm-fixes" branch at http://git.kernel.org/?p=linux/kernel/git/daeinki/drm-exynos.git Signed-off-by: Rahul Sharma <rahul.sharma@samsung.com> Acked-by: Dave Airlie <airlied@gmail.com> Reviewed-by: Aaron Plattner <aplattner@nvidia.com> Tested-by: Aaron Plattner <aplattner@nvidia.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm')
-rw-r--r--drivers/gpu/drm/drm_prime.c8
1 files changed, 2 insertions, 6 deletions
diff --git a/drivers/gpu/drm/drm_prime.c b/drivers/gpu/drm/drm_prime.c
index 366910ddcfcb..25d02187067e 100644
--- a/drivers/gpu/drm/drm_prime.c
+++ b/drivers/gpu/drm/drm_prime.c
@@ -401,21 +401,17 @@ int drm_prime_fd_to_handle_ioctl(struct drm_device *dev, void *data,
401struct sg_table *drm_prime_pages_to_sg(struct page **pages, int nr_pages) 401struct sg_table *drm_prime_pages_to_sg(struct page **pages, int nr_pages)
402{ 402{
403 struct sg_table *sg = NULL; 403 struct sg_table *sg = NULL;
404 struct scatterlist *iter;
405 int i;
406 int ret; 404 int ret;
407 405
408 sg = kmalloc(sizeof(struct sg_table), GFP_KERNEL); 406 sg = kmalloc(sizeof(struct sg_table), GFP_KERNEL);
409 if (!sg) 407 if (!sg)
410 goto out; 408 goto out;
411 409
412 ret = sg_alloc_table(sg, nr_pages, GFP_KERNEL); 410 ret = sg_alloc_table_from_pages(sg, pages, nr_pages, 0,
411 nr_pages << PAGE_SHIFT, GFP_KERNEL);
413 if (ret) 412 if (ret)
414 goto out; 413 goto out;
415 414
416 for_each_sg(sg->sgl, iter, nr_pages, i)
417 sg_set_page(iter, pages[i], PAGE_SIZE, 0);
418
419 return sg; 415 return sg;
420out: 416out:
421 kfree(sg); 417 kfree(sg);