[PATCH 1/6] drm: Add helper to check exporting driver of a DMA-buf
Daniel Vetter
daniel at ffwll.ch
Fri Jul 7 13:29:06 UTC 2017
On Thu, Jul 06, 2017 at 10:25:23PM +0200, Christian König wrote:
> Am 06.07.2017 um 22:16 schrieb Felix Kuehling:
> > This allows drivers to check if a DMA-buf contains a GEM object and
> > whether it comes from the same driver. It may be from the same or a
> > different device.
> >
> > Signed-off-by: Felix Kuehling <Felix.Kuehling at amd.com>
>
> I think Daniel/Dave hadmore a function which returns the casted GEM object
> or NULL in mind, but that should o it as well.
>
> Patch is Reviewed-by: Christian König <christian.koenig at amd.com>
Yeah I think the try_to_cast is the much cleaner interface. Also, can we
pls cc the entire patch series to dri-devel, makes it much easier to see
th entire context? I can't really say whether this or try_to_cast is a
good idea without that ...
-Daniel
>
> Regards,
> Christian.
>
> > ---
> > drivers/gpu/drm/drm_prime.c | 24 ++++++++++++++++++++++++
> > include/drm/drmP.h | 2 ++
> > 2 files changed, 26 insertions(+)
> >
> > diff --git a/drivers/gpu/drm/drm_prime.c b/drivers/gpu/drm/drm_prime.c
> > index 25aa455..a50baec 100644
> > --- a/drivers/gpu/drm/drm_prime.c
> > +++ b/drivers/gpu/drm/drm_prime.c
> > @@ -594,6 +594,30 @@ int drm_gem_prime_handle_to_fd(struct drm_device *dev,
> > EXPORT_SYMBOL(drm_gem_prime_handle_to_fd);
> > /**
> > + * drm_gem_prime_dmabuf_is_from_driver - check exporting driver of a dma-buf
> > + * @dma_buf: dma-buf object to check
> > + * @driver: driver that is the expected exporter of the dma-buf
> > + *
> > + * Returns true if @driver exported @dma_buf. Returns false if
> > + * @dma_buf was exported by a different driver.
> > + */
> > +bool drm_gem_prime_dmabuf_is_from_driver(const struct dma_buf *dma_buf,
> > + const struct drm_driver *driver)
> > +{
> > + struct drm_gem_object *obj;
> > +
> > + if (dma_buf->ops != &drm_gem_prime_dmabuf_ops)
> > + return false;
> > +
> > + obj = dma_buf->priv;
> > + if (obj->dev->driver != driver)
> > + return false;
> > +
> > + return true;
> > +}
> > +EXPORT_SYMBOL(drm_gem_prime_dmabuf_is_from_driver);
> > +
> > +/**
> > * drm_gem_prime_import - helper library implementation of the import callback
> > * @dev: drm_device to import into
> > * @dma_buf: dma-buf object to import
> > diff --git a/include/drm/drmP.h b/include/drm/drmP.h
> > index 6105c05..052f747 100644
> > --- a/include/drm/drmP.h
> > +++ b/include/drm/drmP.h
> > @@ -767,6 +767,8 @@ extern struct dma_buf *drm_gem_prime_export(struct drm_device *dev,
> > extern int drm_gem_prime_handle_to_fd(struct drm_device *dev,
> > struct drm_file *file_priv, uint32_t handle, uint32_t flags,
> > int *prime_fd);
> > +extern bool drm_gem_prime_dmabuf_is_from_driver(const struct dma_buf *dma_buf,
> > + const struct drm_driver *driver);
> > extern struct drm_gem_object *drm_gem_prime_import(struct drm_device *dev,
> > struct dma_buf *dma_buf);
> > extern int drm_gem_prime_fd_to_handle(struct drm_device *dev,
>
>
> _______________________________________________
> dri-devel mailing list
> dri-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/dri-devel
--
Daniel Vetter
Software Engineer, Intel Corporation
http://blog.ffwll.ch
More information about the dri-devel
mailing list