Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/external/bsd/drm2 Draft support for drm prime.



details:   https://anonhg.NetBSD.org/src/rev/cbdbdd2b28b9
branches:  trunk
changeset: 364864:cbdbdd2b28b9
user:      riastradh <riastradh%NetBSD.org@localhost>
date:      Mon Aug 27 15:22:53 2018 +0000

description:
Draft support for drm prime.

diffstat:

 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_display.c |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_drv.c     |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gem.c     |    6 +-
 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ttm.c     |   15 +-
 sys/external/bsd/drm2/dist/drm/drm_gem.c                   |    8 +-
 sys/external/bsd/drm2/dist/drm/drm_internal.h              |    4 +-
 sys/external/bsd/drm2/dist/drm/drm_ioctl.c                 |    6 +-
 sys/external/bsd/drm2/dist/drm/drm_prime.c                 |  151 ++++++-
 sys/external/bsd/drm2/dist/drm/i915/i915_drv.c             |    6 +-
 sys/external/bsd/drm2/dist/drm/i915/i915_drv.h             |    3 +-
 sys/external/bsd/drm2/dist/drm/i915/i915_gem.c             |    6 +-
 sys/external/bsd/drm2/dist/drm/i915/i915_gem_dmabuf.c      |   78 +++-
 sys/external/bsd/drm2/dist/drm/nouveau/nouveau_bo.c        |   17 +-
 sys/external/bsd/drm2/dist/drm/nouveau/nouveau_drm.c       |    6 +-
 sys/external/bsd/drm2/dist/drm/nouveau/nouveau_gem.c       |    6 +-
 sys/external/bsd/drm2/dist/drm/radeon/radeon_display.c     |    6 +-
 sys/external/bsd/drm2/dist/drm/radeon/radeon_drv.c         |    6 +-
 sys/external/bsd/drm2/dist/drm/radeon/radeon_gem.c         |    6 +-
 sys/external/bsd/drm2/dist/drm/radeon/radeon_ttm.c         |   15 +-
 sys/external/bsd/drm2/dist/include/drm/drmP.h              |   16 +-
 sys/external/bsd/drm2/dist/include/drm/drm_gem.h           |    4 +-
 sys/external/bsd/drm2/dist/uapi/drm/drm.h                  |    3 +-
 sys/external/bsd/drm2/drm/drm_fops.c                       |   10 +-
 sys/external/bsd/drm2/drm/files.drmkms                     |    4 +-
 sys/external/bsd/drm2/i915drm/files.i915drmkms             |    4 +-
 sys/external/bsd/drm2/include/linux/dma-buf.h              |  113 +++++-
 sys/external/bsd/drm2/include/linux/module.h               |    3 +-
 sys/external/bsd/drm2/linux/files.drmkms_linux             |    3 +-
 sys/external/bsd/drm2/linux/linux_dma_buf.c                |  276 +++++++++++++
 sys/external/bsd/drm2/nouveau/files.nouveau                |    4 +-
 sys/external/bsd/drm2/radeon/files.radeon                  |    4 +-
 31 files changed, 693 insertions(+), 108 deletions(-)

diffs (truncated from 1670 to 300 lines):

diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_display.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_display.c        Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_display.c        Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_display.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $     */
+/*     $NetBSD: amdgpu_display.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $     */
 
 /*
  * Copyright 2007-8 Advanced Micro Devices, Inc.
@@ -26,7 +26,7 @@
  *          Alex Deucher
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_display.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_display.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $");
 
 #include <drm/drmP.h>
 #include <drm/amdgpu_drm.h>
@@ -565,13 +565,11 @@
                return ERR_PTR(-ENOENT);
        }
 
-#ifndef __NetBSD__             /* XXX drm prime */
        /* Handle is imported dma-buf, so cannot be migrated to VRAM for scanout */
        if (obj->import_attach) {
                DRM_DEBUG_KMS("Cannot create framebuffer from imported dma_buf\n");
                return ERR_PTR(-EINVAL);
        }
-#endif
 
        amdgpu_fb = kzalloc(sizeof(*amdgpu_fb), GFP_KERNEL);
        if (amdgpu_fb == NULL) {
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_drv.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_drv.c    Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_drv.c    Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_drv.c,v 1.4 2018/08/27 14:04:50 riastradh Exp $ */
+/*     $NetBSD: amdgpu_drv.c,v 1.5 2018/08/27 15:22:54 riastradh Exp $ */
 
 /**
  * \file amdgpu_drv.c
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_drv.c,v 1.4 2018/08/27 14:04:50 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_drv.c,v 1.5 2018/08/27 15:22:54 riastradh Exp $");
 
 #include <drm/drmP.h>
 #include <drm/amdgpu_drm.h>
@@ -538,7 +538,6 @@
        .fops = &amdgpu_driver_kms_fops,
 #endif
 
-#ifndef __NetBSD__             /* XXX drm prime */
        .prime_handle_to_fd = drm_gem_prime_handle_to_fd,
        .prime_fd_to_handle = drm_gem_prime_fd_to_handle,
        .gem_prime_export = amdgpu_gem_prime_export,
@@ -550,7 +549,6 @@
        .gem_prime_import_sg_table = amdgpu_gem_prime_import_sg_table,
        .gem_prime_vmap = amdgpu_gem_prime_vmap,
        .gem_prime_vunmap = amdgpu_gem_prime_vunmap,
-#endif
 
        .name = DRIVER_NAME,
        .desc = DRIVER_DESC,
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gem.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gem.c    Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_gem.c    Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_gem.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $ */
+/*     $NetBSD: amdgpu_gem.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $ */
 
 /*
  * Copyright 2008 Advanced Micro Devices, Inc.
@@ -28,7 +28,7 @@
  *          Jerome Glisse
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_gem.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_gem.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $");
 
 #include <linux/ktime.h>
 #include <drm/drmP.h>
@@ -40,10 +40,8 @@
        struct amdgpu_bo *robj = gem_to_amdgpu_bo(gobj);
 
        if (robj) {
-#ifndef __NetBSD__             /* XXX drm prime */
                if (robj->gem_base.import_attach)
                        drm_prime_gem_destroy(&robj->gem_base, robj->tbo.sg);
-#endif
                amdgpu_mn_unregister(robj);
                amdgpu_bo_unref(&robj);
        }
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ttm.c
--- a/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ttm.c    Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/amd/amdgpu/amdgpu_ttm.c    Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: amdgpu_ttm.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $ */
+/*     $NetBSD: amdgpu_ttm.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $ */
 
 /*
  * Copyright 2009 Jerome Glisse.
@@ -32,7 +32,7 @@
  *    Dave Airlie
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: amdgpu_ttm.c,v 1.3 2018/08/27 14:04:50 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: amdgpu_ttm.c,v 1.4 2018/08/27 15:22:54 riastradh Exp $");
 
 #include <ttm/ttm_bo_api.h>
 #include <ttm/ttm_bo_driver.h>
@@ -687,8 +687,8 @@
        struct amdgpu_ttm_tt *gtt = (void *)ttm;
 #ifndef __NetBSD__
        unsigned i;
+#endif
        int r;
-#endif
        bool slave = !!(ttm->page_flags & TTM_PAGE_FLAG_SG);
 
        if (ttm->state != tt_unpopulated)
@@ -709,14 +709,17 @@
        }
 
        if (slave && ttm->sg) {
-#ifdef __NetBSD__              /* XXX drm prime */
-               return -EINVAL;
+#ifdef __NetBSD__
+               r = drm_prime_bus_dmamap_load_sgt(ttm->bdev->dmat,
+                   gtt->ttm.dma_address, ttm->sg);
+               if (r)
+                       return r;
 #else
                drm_prime_sg_to_page_addr_arrays(ttm->sg, ttm->pages,
                                                 gtt->ttm.dma_address, ttm->num_pages);
+#endif
                ttm->state = tt_unbound;
                return 0;
-#endif
        }
 
 #ifdef __NetBSD__
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/drm_gem.c
--- a/sys/external/bsd/drm2/dist/drm/drm_gem.c  Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/drm_gem.c  Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: drm_gem.c,v 1.9 2018/08/27 14:14:29 riastradh Exp $    */
+/*     $NetBSD: drm_gem.c,v 1.10 2018/08/27 15:22:53 riastradh Exp $   */
 
 /*
  * Copyright © 2008 Intel Corporation
@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: drm_gem.c,v 1.9 2018/08/27 14:14:29 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: drm_gem.c,v 1.10 2018/08/27 15:22:53 riastradh Exp $");
 
 #include <linux/types.h>
 #include <linux/slab.h>
@@ -224,7 +224,6 @@
 static void
 drm_gem_remove_prime_handles(struct drm_gem_object *obj, struct drm_file *filp)
 {
-#ifndef __NetBSD__             /* XXX drm prime */
        /*
         * Note: obj->dma_buf can't disappear as long as we still hold a
         * handle reference in obj->handle_count.
@@ -235,7 +234,6 @@
                                                   obj->dma_buf);
        }
        mutex_unlock(&filp->prime.lock);
-#endif
 }
 
 /**
@@ -822,10 +820,8 @@
        if (dev->driver->gem_close_object)
                dev->driver->gem_close_object(obj, file_priv);
 
-#ifndef __NetBSD__                     /* XXX drm prime */
        if (drm_core_check_feature(dev, DRIVER_PRIME))
                drm_gem_remove_prime_handles(obj, file_priv);
-#endif
        drm_vma_node_revoke(&obj->vma_node, file_priv->filp);
 
        drm_gem_object_handle_unreference_unlocked(obj);
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/drm_internal.h
--- a/sys/external/bsd/drm2/dist/drm/drm_internal.h     Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/drm_internal.h     Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: drm_internal.h,v 1.2 2018/08/27 04:58:19 riastradh Exp $       */
+/*     $NetBSD: drm_internal.h,v 1.3 2018/08/27 15:22:53 riastradh Exp $       */
 
 /*
  * Copyright © 2014 Intel Corporation
@@ -50,12 +50,10 @@
 int drm_prime_fd_to_handle_ioctl(struct drm_device *dev, void *data,
                                 struct drm_file *file_priv);
 
-#ifndef __NetBSD__             /* XXX drm prime */
 void drm_prime_init_file_private(struct drm_prime_file_private *prime_fpriv);
 void drm_prime_destroy_file_private(struct drm_prime_file_private *prime_fpriv);
 void drm_prime_remove_buf_handle_locked(struct drm_prime_file_private *prime_fpriv,
                                        struct dma_buf *dma_buf);
-#endif
 
 #ifndef __NetBSD__
 /* drm_info.c */
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/drm_ioctl.c
--- a/sys/external/bsd/drm2/dist/drm/drm_ioctl.c        Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/drm_ioctl.c        Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: drm_ioctl.c,v 1.8 2018/08/27 14:45:45 riastradh Exp $  */
+/*     $NetBSD: drm_ioctl.c,v 1.9 2018/08/27 15:22:53 riastradh Exp $  */
 
 /*
  * Created: Fri Jan  8 09:01:26 1999 by faith%valinux.com@localhost
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: drm_ioctl.c,v 1.8 2018/08/27 14:45:45 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: drm_ioctl.c,v 1.9 2018/08/27 15:22:53 riastradh Exp $");
 
 #include <drm/drmP.h>
 #include <drm/drm_core.h>
@@ -665,10 +665,8 @@
 
        DRM_IOCTL_DEF(DRM_IOCTL_MODE_GETRESOURCES, drm_mode_getresources, DRM_CONTROL_ALLOW|DRM_UNLOCKED),
 
-#ifndef __NetBSD__             /* XXX drm prime */
        DRM_IOCTL_DEF(DRM_IOCTL_PRIME_HANDLE_TO_FD, drm_prime_handle_to_fd_ioctl, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
        DRM_IOCTL_DEF(DRM_IOCTL_PRIME_FD_TO_HANDLE, drm_prime_fd_to_handle_ioctl, DRM_AUTH|DRM_UNLOCKED|DRM_RENDER_ALLOW),
-#endif
 
        DRM_IOCTL_DEF(DRM_IOCTL_MODE_GETPLANERESOURCES, drm_mode_getplane_res, DRM_CONTROL_ALLOW|DRM_UNLOCKED),
        DRM_IOCTL_DEF(DRM_IOCTL_MODE_GETCRTC, drm_mode_getcrtc, DRM_CONTROL_ALLOW|DRM_UNLOCKED),
diff -r 2f0ff6d19923 -r cbdbdd2b28b9 sys/external/bsd/drm2/dist/drm/drm_prime.c
--- a/sys/external/bsd/drm2/dist/drm/drm_prime.c        Mon Aug 27 15:16:49 2018 +0000
+++ b/sys/external/bsd/drm2/dist/drm/drm_prime.c        Mon Aug 27 15:22:53 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: drm_prime.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $  */
+/*     $NetBSD: drm_prime.c,v 1.3 2018/08/27 15:22:54 riastradh Exp $  */
 
 /*
  * Copyright © 2012 Red Hat
@@ -29,7 +29,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: drm_prime.c,v 1.2 2018/08/27 04:58:19 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: drm_prime.c,v 1.3 2018/08/27 15:22:54 riastradh Exp $");
 
 #include <linux/export.h>
 #include <linux/dma-buf.h>
@@ -38,6 +38,72 @@
 
 #include "drm_internal.h"
 
+struct sg_table {
+       bus_dma_segment_t       *sgt_segs;
+       int                     sgt_nsegs;
+       bus_size_t              sgt_size;
+};
+
+static int
+sg_alloc_table_from_pages(struct sg_table *sgt, struct page **pages,
+    unsigned npages, bus_size_t offset, bus_size_t size, gfp_t gfp)
+{
+       unsigned i;
+
+       KASSERT(offset == 0);
+       KASSERT(size == npages << PAGE_SHIFT);
+
+       sgt->sgt_segs = kcalloc(npages, sizeof(sgt->sgt_segs[0]), gfp);
+       if (sgt->sgt_segs == NULL)
+               return -ENOMEM;
+       sgt->sgt_nsegs = npages;
+       sgt->sgt_size = size;
+
+       for (i = 0; i < npages; i++) {
+               sgt->sgt_segs[i].ds_addr = VM_PAGE_TO_PHYS(&pages[i]->p_vmp);
+               sgt->sgt_segs[i].ds_len = PAGE_SIZE;
+       }
+
+       return 0;
+}
+
+static int
+sg_alloc_table_from_pglist(struct sg_table *sgt, struct pglist *pglist,
+    unsigned npages, bus_size_t offset, bus_size_t size, gfp_t gfp)
+{
+       struct vm_page *pg;
+       unsigned i;
+
+       KASSERT(offset == 0);
+       KASSERT(size == npages << PAGE_SHIFT);



Home | Main Index | Thread Index | Old Index