drm/tegra: gem: Use dma_mmap_writecombine()
authorThierry Reding <treding@nvidia.com>
Wed, 24 Sep 2014 14:14:04 +0000 (16:14 +0200)
committerThierry Reding <treding@nvidia.com>
Thu, 13 Nov 2014 15:14:48 +0000 (16:14 +0100)
Use the existing API rather than open-coding equivalent functionality
in the driver.

Signed-off-by: Thierry Reding <treding@nvidia.com>
drivers/gpu/drm/tegra/gem.c

index a42d4c9a4d7dc8e7a1f122d2a89978858d160949..9905598ebfc44ddf893546705062efb7e1630d14 100644 (file)
@@ -306,6 +306,7 @@ const struct vm_operations_struct tegra_bo_vm_ops = {
 
 int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma)
 {
+       unsigned long vm_pgoff = vma->vm_pgoff;
        struct drm_gem_object *gem;
        struct tegra_bo *bo;
        int ret;
@@ -317,12 +318,19 @@ int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma)
        gem = vma->vm_private_data;
        bo = to_tegra_bo(gem);
 
-       ret = remap_pfn_range(vma, vma->vm_start, bo->paddr >> PAGE_SHIFT,
-                             vma->vm_end - vma->vm_start, vma->vm_page_prot);
-       if (ret)
+       vma->vm_flags &= ~VM_PFNMAP;
+       vma->vm_pgoff = 0;
+
+       ret = dma_mmap_writecombine(gem->dev->dev, vma, bo->vaddr, bo->paddr,
+                                   gem->size);
+       if (ret) {
                drm_gem_vm_close(vma);
+               return ret;
+       }
+
+       vma->vm_pgoff = vm_pgoff;
 
-       return ret;
+       return 0;
 }
 
 static struct sg_table *