[PATCH 1/1] drm: exynos: fix for mapping contigous dma buffers
Inki Dae
daeinki at gmail.com
Mon Nov 5 06:20:29 PST 2012
2012. 11. 3. 오후 9:21 Rahul Sharma <rahul.sharma at samsung.com> 작성:
> This patch fixes the problem of mapping contigous dma buffers. Currently page
> struct is calculated from the buf->dma_addr which is not the physical address.
> It is replaced by buf->pages which points to the page struct of the first page
> of contigous memory chunk. This gives the correct page frame number for
> mapping.
>
> Signed-off-by: Rahul Sharma <rahul.sharma at samsung.com>
> ---
> drivers/gpu/drm/exynos/exynos_drm_gem.c | 8 ++++++--
> 1 files changed, 6 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/gpu/drm/exynos/exynos_drm_gem.c b/drivers/gpu/drm/exynos/exynos_drm_gem.c
> index c557ac7..50d73f1 100644
> --- a/drivers/gpu/drm/exynos/exynos_drm_gem.c
> +++ b/drivers/gpu/drm/exynos/exynos_drm_gem.c
> @@ -120,8 +120,12 @@ static int exynos_drm_gem_map_buf(struct drm_gem_object *obj,
> }
>
> pfn = __phys_to_pfn(sg_phys(sgl)) + page_offset;
> - } else
> - pfn = (buf->dma_addr >> PAGE_SHIFT) + page_offset;
> + } else {
> + if (!buf->pages)
> + return -EINTR;
> +
> + pfn = page_to_pfn(buf->pages[0]) + page_offset;
> + }
Is there any reason you are sending patches respectively? It's better to combine them.
Thanks,
Inki Dae
>
> return vm_insert_mixed(vma, f_vaddr, pfn);
> }
> --
> 1.7.0.4
>
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/dri-devel
More information about the dri-devel
mailing list