]> git.baikalelectronics.ru Git - kernel.git/commitdiff
drm/vmwgfx: Hook up the helpers to align buffer objects
authorThomas Hellstrom (VMware) <thomas_os@shipmail.org>
Tue, 24 Mar 2020 17:50:35 +0000 (18:50 +0100)
committerThomas Hellstrom (VMware) <thomas_os@shipmail.org>
Tue, 24 Mar 2020 17:50:35 +0000 (18:50 +0100)
Start using the helpers that align buffer object user-space addresses and
buffer object vram addresses to huge page boundaries.
This is to improve the chances of allowing huge page-table entries.

Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Michal Hocko <mhocko@suse.com>
Cc: "Matthew Wilcox (Oracle)" <willy@infradead.org>
Cc: "Kirill A. Shutemov" <kirill.shutemov@linux.intel.com>
Cc: Ralph Campbell <rcampbell@nvidia.com>
Cc: "Jérôme Glisse" <jglisse@redhat.com>
Cc: "Christian König" <christian.koenig@amd.com>
Cc: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Thomas Hellstrom (VMware) <thomas_os@shipmail.org>
Reviewed-by: Roland Scheidegger <sroland@vmware.com>
Acked-by: Christian König <christian.koenig@amd.com>
drivers/gpu/drm/drm_file.c
drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
drivers/gpu/drm/vmwgfx/vmwgfx_drv.h
drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c

index d1fcb0c61622297136e857c22d42bf2d21865709..eb009d3ab48fa318ddd51dae56784d288ccef17d 100644 (file)
@@ -1011,4 +1011,5 @@ unsigned long drm_get_unmapped_area(struct file *file,
        return current->mm->get_unmapped_area(file, uaddr, len, pgoff, flags);
 }
 #endif /* CONFIG_TRANSPARENT_HUGEPAGE */
+EXPORT_SYMBOL_GPL(drm_get_unmapped_area);
 #endif /* CONFIG_MMU */
index 4f58364421ce78874c79d18db092b5ec806312bf..f0b7a891cbad48f48448bc112d37d118c0a0e7c1 100644 (file)
@@ -1230,6 +1230,18 @@ static void vmw_remove(struct pci_dev *pdev)
        pci_disable_device(pdev);
 }
 
+static unsigned long
+vmw_get_unmapped_area(struct file *file, unsigned long uaddr,
+                     unsigned long len, unsigned long pgoff,
+                     unsigned long flags)
+{
+       struct drm_file *file_priv = file->private_data;
+       struct vmw_private *dev_priv = vmw_priv(file_priv->minor->dev);
+
+       return drm_get_unmapped_area(file, uaddr, len, pgoff, flags,
+                                    &dev_priv->vma_manager);
+}
+
 static int vmwgfx_pm_notifier(struct notifier_block *nb, unsigned long val,
                              void *ptr)
 {
@@ -1401,6 +1413,7 @@ static const struct file_operations vmwgfx_driver_fops = {
        .compat_ioctl = vmw_compat_ioctl,
 #endif
        .llseek = noop_llseek,
+       .get_unmapped_area = vmw_get_unmapped_area,
 };
 
 static struct drm_driver driver = {
index d19d28c136711f1b225d102a97566487ea772931..fc98622caf87c1a25bba44f5e736173f881ae36e 100644 (file)
@@ -915,6 +915,7 @@ extern int vmw_mmap(struct file *filp, struct vm_area_struct *vma);
 
 extern void vmw_validation_mem_init_ttm(struct vmw_private *dev_priv,
                                        size_t gran);
+
 /**
  * TTM buffer object driver - vmwgfx_ttm_buffer.c
  */
index 3f3b2c7a208a9266345e9faa24980f7b6c2a6d09..bf0bc4697959e75255e46f2931a69be780a3f85a 100644 (file)
@@ -749,7 +749,7 @@ static int vmw_init_mem_type(struct ttm_bo_device *bdev, uint32_t type,
                break;
        case TTM_PL_VRAM:
                /* "On-card" video ram */
-               man->func = &ttm_bo_manager_func;
+               man->func = &vmw_thp_func;
                man->gpu_offset = 0;
                man->flags = TTM_MEMTYPE_FLAG_FIXED | TTM_MEMTYPE_FLAG_MAPPABLE;
                man->available_caching = TTM_PL_FLAG_CACHED;