drm: Remove obsolete GEM and PRIME callbacks from struct drm_driver
Several GEM and PRIME callbacks have been deprecated in favor of per-instance GEM object functions. Remove the callbacks as they are now unused. The only exception is .gem_prime_mmap, which is still in use by several drivers. What is also gone is gem_vm_ops in struct drm_driver. All drivers now use struct drm_gem_object_funcs.vm_ops instead. While at it, the patch also improves error handling around calls to .free and .get_sg_table callbacks. v3: * restore default call to drm_gem_prime_export() in drm_gem_prime_handle_to_fd() * return -ENOSYS if get_sg_table is not set * drop all checks for obj->funcs * clean up TODO list and documentation v2: * update related TODO item (Sam) Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de> Acked-by: Daniel Vetter <daniel.vetter@ffwll.ch> Acked-by: Christian König <christian.koenig@amd.com> Link: https://patchwork.freedesktop.org/patch/msgid/20200923102159.24084-23-tzimmermann@suse.de
This commit is contained in:
parent
c85dce1b2e
commit
d693def4fd
@ -182,11 +182,11 @@ acquired and release by calling drm_gem_object_get() and drm_gem_object_put()
|
|||||||
respectively.
|
respectively.
|
||||||
|
|
||||||
When the last reference to a GEM object is released the GEM core calls
|
When the last reference to a GEM object is released the GEM core calls
|
||||||
the :c:type:`struct drm_driver <drm_driver>` gem_free_object_unlocked
|
the :c:type:`struct drm_gem_object_funcs <gem_object_funcs>` free
|
||||||
operation. That operation is mandatory for GEM-enabled drivers and must
|
operation. That operation is mandatory for GEM-enabled drivers and must
|
||||||
free the GEM object and all associated resources.
|
free the GEM object and all associated resources.
|
||||||
|
|
||||||
void (\*gem_free_object) (struct drm_gem_object \*obj); Drivers are
|
void (\*free) (struct drm_gem_object \*obj); Drivers are
|
||||||
responsible for freeing all GEM object resources. This includes the
|
responsible for freeing all GEM object resources. This includes the
|
||||||
resources created by the GEM core, which need to be released with
|
resources created by the GEM core, which need to be released with
|
||||||
drm_gem_object_release().
|
drm_gem_object_release().
|
||||||
|
@ -149,7 +149,7 @@ have to keep track of that lock and either call ``unreference`` or
|
|||||||
``unreference_locked`` depending upon context.
|
``unreference_locked`` depending upon context.
|
||||||
|
|
||||||
Core GEM doesn't have a need for ``struct_mutex`` any more since kernel 4.8,
|
Core GEM doesn't have a need for ``struct_mutex`` any more since kernel 4.8,
|
||||||
and there's a ``gem_free_object_unlocked`` callback for any drivers which are
|
and there's a GEM object ``free`` callback for any drivers which are
|
||||||
entirely ``struct_mutex`` free.
|
entirely ``struct_mutex`` free.
|
||||||
|
|
||||||
For drivers that need ``struct_mutex`` it should be replaced with a driver-
|
For drivers that need ``struct_mutex`` it should be replaced with a driver-
|
||||||
@ -289,11 +289,8 @@ struct drm_gem_object_funcs
|
|||||||
---------------------------
|
---------------------------
|
||||||
|
|
||||||
GEM objects can now have a function table instead of having the callbacks on the
|
GEM objects can now have a function table instead of having the callbacks on the
|
||||||
DRM driver struct. This is now the preferred way and drivers can be moved over.
|
DRM driver struct. This is now the preferred way. Callbacks in drivers have been
|
||||||
|
converted, except for struct drm_driver.gem_prime_mmap.
|
||||||
We also need a 2nd version of the CMA define that doesn't require the
|
|
||||||
vmapping to be present (different hook for prime importing). Plus this needs to
|
|
||||||
be rolled out to all drivers using their own implementations, too.
|
|
||||||
|
|
||||||
Level: Intermediate
|
Level: Intermediate
|
||||||
|
|
||||||
|
@ -247,12 +247,9 @@ drm_gem_object_release_handle(int id, void *ptr, void *data)
|
|||||||
{
|
{
|
||||||
struct drm_file *file_priv = data;
|
struct drm_file *file_priv = data;
|
||||||
struct drm_gem_object *obj = ptr;
|
struct drm_gem_object *obj = ptr;
|
||||||
struct drm_device *dev = obj->dev;
|
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->close)
|
if (obj->funcs->close)
|
||||||
obj->funcs->close(obj, file_priv);
|
obj->funcs->close(obj, file_priv);
|
||||||
else if (dev->driver->gem_close_object)
|
|
||||||
dev->driver->gem_close_object(obj, file_priv);
|
|
||||||
|
|
||||||
drm_gem_remove_prime_handles(obj, file_priv);
|
drm_gem_remove_prime_handles(obj, file_priv);
|
||||||
drm_vma_node_revoke(&obj->vma_node, file_priv);
|
drm_vma_node_revoke(&obj->vma_node, file_priv);
|
||||||
@ -403,14 +400,10 @@ drm_gem_handle_create_tail(struct drm_file *file_priv,
|
|||||||
if (ret)
|
if (ret)
|
||||||
goto err_remove;
|
goto err_remove;
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->open) {
|
if (obj->funcs->open) {
|
||||||
ret = obj->funcs->open(obj, file_priv);
|
ret = obj->funcs->open(obj, file_priv);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_revoke;
|
goto err_revoke;
|
||||||
} else if (dev->driver->gem_open_object) {
|
|
||||||
ret = dev->driver->gem_open_object(obj, file_priv);
|
|
||||||
if (ret)
|
|
||||||
goto err_revoke;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
*handlep = handle;
|
*handlep = handle;
|
||||||
@ -982,12 +975,11 @@ drm_gem_object_free(struct kref *kref)
|
|||||||
{
|
{
|
||||||
struct drm_gem_object *obj =
|
struct drm_gem_object *obj =
|
||||||
container_of(kref, struct drm_gem_object, refcount);
|
container_of(kref, struct drm_gem_object, refcount);
|
||||||
struct drm_device *dev = obj->dev;
|
|
||||||
|
|
||||||
if (obj->funcs)
|
if (WARN_ON(!obj->funcs->free))
|
||||||
obj->funcs->free(obj);
|
return;
|
||||||
else if (dev->driver->gem_free_object_unlocked)
|
|
||||||
dev->driver->gem_free_object_unlocked(obj);
|
obj->funcs->free(obj);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_gem_object_free);
|
EXPORT_SYMBOL(drm_gem_object_free);
|
||||||
|
|
||||||
@ -1049,9 +1041,9 @@ EXPORT_SYMBOL(drm_gem_vm_close);
|
|||||||
* @obj_size: the object size to be mapped, in bytes
|
* @obj_size: the object size to be mapped, in bytes
|
||||||
* @vma: VMA for the area to be mapped
|
* @vma: VMA for the area to be mapped
|
||||||
*
|
*
|
||||||
* Set up the VMA to prepare mapping of the GEM object using the gem_vm_ops
|
* Set up the VMA to prepare mapping of the GEM object using the GEM object's
|
||||||
* provided by the driver. Depending on their requirements, drivers can either
|
* vm_ops. Depending on their requirements, GEM objects can either
|
||||||
* provide a fault handler in their gem_vm_ops (in which case any accesses to
|
* provide a fault handler in their vm_ops (in which case any accesses to
|
||||||
* the object will be trapped, to perform migration, GTT binding, surface
|
* the object will be trapped, to perform migration, GTT binding, surface
|
||||||
* register allocation, or performance monitoring), or mmap the buffer memory
|
* register allocation, or performance monitoring), or mmap the buffer memory
|
||||||
* synchronously after calling drm_gem_mmap_obj.
|
* synchronously after calling drm_gem_mmap_obj.
|
||||||
@ -1065,12 +1057,11 @@ EXPORT_SYMBOL(drm_gem_vm_close);
|
|||||||
* callers must verify access restrictions before calling this helper.
|
* callers must verify access restrictions before calling this helper.
|
||||||
*
|
*
|
||||||
* Return 0 or success or -EINVAL if the object size is smaller than the VMA
|
* Return 0 or success or -EINVAL if the object size is smaller than the VMA
|
||||||
* size, or if no gem_vm_ops are provided.
|
* size, or if no vm_ops are provided.
|
||||||
*/
|
*/
|
||||||
int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
|
int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
|
||||||
struct vm_area_struct *vma)
|
struct vm_area_struct *vma)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = obj->dev;
|
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
/* Check for valid size. */
|
/* Check for valid size. */
|
||||||
@ -1085,7 +1076,7 @@ int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
|
|||||||
*/
|
*/
|
||||||
drm_gem_object_get(obj);
|
drm_gem_object_get(obj);
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->mmap) {
|
if (obj->funcs->mmap) {
|
||||||
ret = obj->funcs->mmap(obj, vma);
|
ret = obj->funcs->mmap(obj, vma);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
drm_gem_object_put(obj);
|
drm_gem_object_put(obj);
|
||||||
@ -1093,10 +1084,8 @@ int drm_gem_mmap_obj(struct drm_gem_object *obj, unsigned long obj_size,
|
|||||||
}
|
}
|
||||||
WARN_ON(!(vma->vm_flags & VM_DONTEXPAND));
|
WARN_ON(!(vma->vm_flags & VM_DONTEXPAND));
|
||||||
} else {
|
} else {
|
||||||
if (obj->funcs && obj->funcs->vm_ops)
|
if (obj->funcs->vm_ops)
|
||||||
vma->vm_ops = obj->funcs->vm_ops;
|
vma->vm_ops = obj->funcs->vm_ops;
|
||||||
else if (dev->driver->gem_vm_ops)
|
|
||||||
vma->vm_ops = dev->driver->gem_vm_ops;
|
|
||||||
else {
|
else {
|
||||||
drm_gem_object_put(obj);
|
drm_gem_object_put(obj);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -1198,36 +1187,30 @@ void drm_gem_print_info(struct drm_printer *p, unsigned int indent,
|
|||||||
drm_printf_indent(p, indent, "imported=%s\n",
|
drm_printf_indent(p, indent, "imported=%s\n",
|
||||||
obj->import_attach ? "yes" : "no");
|
obj->import_attach ? "yes" : "no");
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->print_info)
|
if (obj->funcs->print_info)
|
||||||
obj->funcs->print_info(p, indent, obj);
|
obj->funcs->print_info(p, indent, obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
int drm_gem_pin(struct drm_gem_object *obj)
|
int drm_gem_pin(struct drm_gem_object *obj)
|
||||||
{
|
{
|
||||||
if (obj->funcs && obj->funcs->pin)
|
if (obj->funcs->pin)
|
||||||
return obj->funcs->pin(obj);
|
return obj->funcs->pin(obj);
|
||||||
else if (obj->dev->driver->gem_prime_pin)
|
|
||||||
return obj->dev->driver->gem_prime_pin(obj);
|
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void drm_gem_unpin(struct drm_gem_object *obj)
|
void drm_gem_unpin(struct drm_gem_object *obj)
|
||||||
{
|
{
|
||||||
if (obj->funcs && obj->funcs->unpin)
|
if (obj->funcs->unpin)
|
||||||
obj->funcs->unpin(obj);
|
obj->funcs->unpin(obj);
|
||||||
else if (obj->dev->driver->gem_prime_unpin)
|
|
||||||
obj->dev->driver->gem_prime_unpin(obj);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void *drm_gem_vmap(struct drm_gem_object *obj)
|
void *drm_gem_vmap(struct drm_gem_object *obj)
|
||||||
{
|
{
|
||||||
void *vaddr;
|
void *vaddr;
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->vmap)
|
if (obj->funcs->vmap)
|
||||||
vaddr = obj->funcs->vmap(obj);
|
vaddr = obj->funcs->vmap(obj);
|
||||||
else if (obj->dev->driver->gem_prime_vmap)
|
|
||||||
vaddr = obj->dev->driver->gem_prime_vmap(obj);
|
|
||||||
else
|
else
|
||||||
vaddr = ERR_PTR(-EOPNOTSUPP);
|
vaddr = ERR_PTR(-EOPNOTSUPP);
|
||||||
|
|
||||||
@ -1242,10 +1225,8 @@ void drm_gem_vunmap(struct drm_gem_object *obj, void *vaddr)
|
|||||||
if (!vaddr)
|
if (!vaddr)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (obj->funcs && obj->funcs->vunmap)
|
if (obj->funcs->vunmap)
|
||||||
obj->funcs->vunmap(obj, vaddr);
|
obj->funcs->vunmap(obj, vaddr);
|
||||||
else if (obj->dev->driver->gem_prime_vunmap)
|
|
||||||
obj->dev->driver->gem_prime_vunmap(obj, vaddr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -171,7 +171,7 @@ drm_gem_cma_create_with_handle(struct drm_file *file_priv,
|
|||||||
* GEM object state and frees the memory used to store the object itself.
|
* GEM object state and frees the memory used to store the object itself.
|
||||||
* If the buffer is imported and the virtual address is set, it is released.
|
* If the buffer is imported and the virtual address is set, it is released.
|
||||||
* Drivers using the CMA helpers should set this as their
|
* Drivers using the CMA helpers should set this as their
|
||||||
* &drm_driver.gem_free_object_unlocked callback.
|
* &drm_gem_object_funcs.free callback.
|
||||||
*/
|
*/
|
||||||
void drm_gem_cma_free_object(struct drm_gem_object *gem_obj)
|
void drm_gem_cma_free_object(struct drm_gem_object *gem_obj)
|
||||||
{
|
{
|
||||||
@ -419,7 +419,7 @@ EXPORT_SYMBOL(drm_gem_cma_print_info);
|
|||||||
*
|
*
|
||||||
* This function exports a scatter/gather table suitable for PRIME usage by
|
* This function exports a scatter/gather table suitable for PRIME usage by
|
||||||
* calling the standard DMA mapping API. Drivers using the CMA helpers should
|
* calling the standard DMA mapping API. Drivers using the CMA helpers should
|
||||||
* set this as their &drm_driver.gem_prime_get_sg_table callback.
|
* set this as their &drm_gem_object_funcs.get_sg_table callback.
|
||||||
*
|
*
|
||||||
* Returns:
|
* Returns:
|
||||||
* A pointer to the scatter/gather table of pinned pages or NULL on failure.
|
* A pointer to the scatter/gather table of pinned pages or NULL on failure.
|
||||||
@ -542,7 +542,7 @@ EXPORT_SYMBOL_GPL(drm_gem_cma_prime_mmap);
|
|||||||
* virtual address space. Since the CMA buffers are already mapped into the
|
* virtual address space. Since the CMA buffers are already mapped into the
|
||||||
* kernel virtual address space this simply returns the cached virtual
|
* kernel virtual address space this simply returns the cached virtual
|
||||||
* address. Drivers using the CMA helpers should set this as their DRM
|
* address. Drivers using the CMA helpers should set this as their DRM
|
||||||
* driver's &drm_driver.gem_prime_vmap callback.
|
* driver's &drm_gem_object_funcs.vmap callback.
|
||||||
*
|
*
|
||||||
* Returns:
|
* Returns:
|
||||||
* The kernel virtual address of the CMA GEM object's backing store.
|
* The kernel virtual address of the CMA GEM object's backing store.
|
||||||
@ -564,7 +564,7 @@ EXPORT_SYMBOL_GPL(drm_gem_cma_prime_vmap);
|
|||||||
* This function removes a buffer exported via DRM PRIME from the kernel's
|
* This function removes a buffer exported via DRM PRIME from the kernel's
|
||||||
* virtual address space. This is a no-op because CMA buffers cannot be
|
* virtual address space. This is a no-op because CMA buffers cannot be
|
||||||
* unmapped from kernel space. Drivers using the CMA helpers should set this
|
* unmapped from kernel space. Drivers using the CMA helpers should set this
|
||||||
* as their &drm_driver.gem_prime_vunmap callback.
|
* as their &drm_gem_object_funcs.vunmap callback.
|
||||||
*/
|
*/
|
||||||
void drm_gem_cma_prime_vunmap(struct drm_gem_object *obj, void *vaddr)
|
void drm_gem_cma_prime_vunmap(struct drm_gem_object *obj, void *vaddr)
|
||||||
{
|
{
|
||||||
|
@ -386,8 +386,6 @@ static struct dma_buf *export_and_register_object(struct drm_device *dev,
|
|||||||
|
|
||||||
if (obj->funcs && obj->funcs->export)
|
if (obj->funcs && obj->funcs->export)
|
||||||
dmabuf = obj->funcs->export(obj, flags);
|
dmabuf = obj->funcs->export(obj, flags);
|
||||||
else if (dev->driver->gem_prime_export)
|
|
||||||
dmabuf = dev->driver->gem_prime_export(obj, flags);
|
|
||||||
else
|
else
|
||||||
dmabuf = drm_gem_prime_export(obj, flags);
|
dmabuf = drm_gem_prime_export(obj, flags);
|
||||||
if (IS_ERR(dmabuf)) {
|
if (IS_ERR(dmabuf)) {
|
||||||
@ -419,7 +417,7 @@ static struct dma_buf *export_and_register_object(struct drm_device *dev,
|
|||||||
* This is the PRIME export function which must be used mandatorily by GEM
|
* This is the PRIME export function which must be used mandatorily by GEM
|
||||||
* drivers to ensure correct lifetime management of the underlying GEM object.
|
* drivers to ensure correct lifetime management of the underlying GEM object.
|
||||||
* The actual exporting from GEM object to a dma-buf is done through the
|
* The actual exporting from GEM object to a dma-buf is done through the
|
||||||
* &drm_driver.gem_prime_export driver callback.
|
* &drm_gem_object_funcs.export callback.
|
||||||
*/
|
*/
|
||||||
int drm_gem_prime_handle_to_fd(struct drm_device *dev,
|
int drm_gem_prime_handle_to_fd(struct drm_device *dev,
|
||||||
struct drm_file *file_priv, uint32_t handle,
|
struct drm_file *file_priv, uint32_t handle,
|
||||||
@ -621,10 +619,12 @@ struct sg_table *drm_gem_map_dma_buf(struct dma_buf_attachment *attach,
|
|||||||
if (WARN_ON(dir == DMA_NONE))
|
if (WARN_ON(dir == DMA_NONE))
|
||||||
return ERR_PTR(-EINVAL);
|
return ERR_PTR(-EINVAL);
|
||||||
|
|
||||||
if (obj->funcs)
|
if (WARN_ON(!obj->funcs->get_sg_table))
|
||||||
sgt = obj->funcs->get_sg_table(obj);
|
return ERR_PTR(-ENOSYS);
|
||||||
else
|
|
||||||
sgt = obj->dev->driver->gem_prime_get_sg_table(obj);
|
sgt = obj->funcs->get_sg_table(obj);
|
||||||
|
if (IS_ERR(sgt))
|
||||||
|
return sgt;
|
||||||
|
|
||||||
if (!dma_map_sg_attrs(attach->dev, sgt->sgl, sgt->nents, dir,
|
if (!dma_map_sg_attrs(attach->dev, sgt->sgl, sgt->nents, dir,
|
||||||
DMA_ATTR_SKIP_CPU_SYNC)) {
|
DMA_ATTR_SKIP_CPU_SYNC)) {
|
||||||
|
@ -36,10 +36,12 @@ struct drm_file;
|
|||||||
struct drm_gem_object;
|
struct drm_gem_object;
|
||||||
struct drm_master;
|
struct drm_master;
|
||||||
struct drm_minor;
|
struct drm_minor;
|
||||||
|
struct dma_buf;
|
||||||
struct dma_buf_attachment;
|
struct dma_buf_attachment;
|
||||||
struct drm_display_mode;
|
struct drm_display_mode;
|
||||||
struct drm_mode_create_dumb;
|
struct drm_mode_create_dumb;
|
||||||
struct drm_printer;
|
struct drm_printer;
|
||||||
|
struct sg_table;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* enum drm_driver_feature - feature flags
|
* enum drm_driver_feature - feature flags
|
||||||
@ -326,32 +328,6 @@ struct drm_driver {
|
|||||||
*/
|
*/
|
||||||
void (*debugfs_init)(struct drm_minor *minor);
|
void (*debugfs_init)(struct drm_minor *minor);
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_free_object_unlocked: deconstructor for drm_gem_objects
|
|
||||||
*
|
|
||||||
* This is deprecated and should not be used by new drivers. Use
|
|
||||||
* &drm_gem_object_funcs.free instead.
|
|
||||||
*/
|
|
||||||
void (*gem_free_object_unlocked) (struct drm_gem_object *obj);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_open_object:
|
|
||||||
*
|
|
||||||
* This callback is deprecated in favour of &drm_gem_object_funcs.open.
|
|
||||||
*
|
|
||||||
* Driver hook called upon gem handle creation
|
|
||||||
*/
|
|
||||||
int (*gem_open_object) (struct drm_gem_object *, struct drm_file *);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_close_object:
|
|
||||||
*
|
|
||||||
* This callback is deprecated in favour of &drm_gem_object_funcs.close.
|
|
||||||
*
|
|
||||||
* Driver hook called upon gem handle release
|
|
||||||
*/
|
|
||||||
void (*gem_close_object) (struct drm_gem_object *, struct drm_file *);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @gem_create_object: constructor for gem objects
|
* @gem_create_object: constructor for gem objects
|
||||||
*
|
*
|
||||||
@ -360,6 +336,7 @@ struct drm_driver {
|
|||||||
*/
|
*/
|
||||||
struct drm_gem_object *(*gem_create_object)(struct drm_device *dev,
|
struct drm_gem_object *(*gem_create_object)(struct drm_device *dev,
|
||||||
size_t size);
|
size_t size);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @prime_handle_to_fd:
|
* @prime_handle_to_fd:
|
||||||
*
|
*
|
||||||
@ -382,14 +359,7 @@ struct drm_driver {
|
|||||||
*/
|
*/
|
||||||
int (*prime_fd_to_handle)(struct drm_device *dev, struct drm_file *file_priv,
|
int (*prime_fd_to_handle)(struct drm_device *dev, struct drm_file *file_priv,
|
||||||
int prime_fd, uint32_t *handle);
|
int prime_fd, uint32_t *handle);
|
||||||
/**
|
|
||||||
* @gem_prime_export:
|
|
||||||
*
|
|
||||||
* Export hook for GEM drivers. Deprecated in favour of
|
|
||||||
* &drm_gem_object_funcs.export.
|
|
||||||
*/
|
|
||||||
struct dma_buf * (*gem_prime_export)(struct drm_gem_object *obj,
|
|
||||||
int flags);
|
|
||||||
/**
|
/**
|
||||||
* @gem_prime_import:
|
* @gem_prime_import:
|
||||||
*
|
*
|
||||||
@ -399,29 +369,6 @@ struct drm_driver {
|
|||||||
*/
|
*/
|
||||||
struct drm_gem_object * (*gem_prime_import)(struct drm_device *dev,
|
struct drm_gem_object * (*gem_prime_import)(struct drm_device *dev,
|
||||||
struct dma_buf *dma_buf);
|
struct dma_buf *dma_buf);
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_prime_pin:
|
|
||||||
*
|
|
||||||
* Deprecated hook in favour of &drm_gem_object_funcs.pin.
|
|
||||||
*/
|
|
||||||
int (*gem_prime_pin)(struct drm_gem_object *obj);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_prime_unpin:
|
|
||||||
*
|
|
||||||
* Deprecated hook in favour of &drm_gem_object_funcs.unpin.
|
|
||||||
*/
|
|
||||||
void (*gem_prime_unpin)(struct drm_gem_object *obj);
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_prime_get_sg_table:
|
|
||||||
*
|
|
||||||
* Deprecated hook in favour of &drm_gem_object_funcs.get_sg_table.
|
|
||||||
*/
|
|
||||||
struct sg_table *(*gem_prime_get_sg_table)(struct drm_gem_object *obj);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @gem_prime_import_sg_table:
|
* @gem_prime_import_sg_table:
|
||||||
*
|
*
|
||||||
@ -432,22 +379,6 @@ struct drm_driver {
|
|||||||
struct drm_device *dev,
|
struct drm_device *dev,
|
||||||
struct dma_buf_attachment *attach,
|
struct dma_buf_attachment *attach,
|
||||||
struct sg_table *sgt);
|
struct sg_table *sgt);
|
||||||
/**
|
|
||||||
* @gem_prime_vmap:
|
|
||||||
*
|
|
||||||
* Deprecated vmap hook for GEM drivers. Please use
|
|
||||||
* &drm_gem_object_funcs.vmap instead.
|
|
||||||
*/
|
|
||||||
void *(*gem_prime_vmap)(struct drm_gem_object *obj);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_prime_vunmap:
|
|
||||||
*
|
|
||||||
* Deprecated vunmap hook for GEM drivers. Please use
|
|
||||||
* &drm_gem_object_funcs.vunmap instead.
|
|
||||||
*/
|
|
||||||
void (*gem_prime_vunmap)(struct drm_gem_object *obj, void *vaddr);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @gem_prime_mmap:
|
* @gem_prime_mmap:
|
||||||
*
|
*
|
||||||
@ -522,14 +453,6 @@ struct drm_driver {
|
|||||||
struct drm_device *dev,
|
struct drm_device *dev,
|
||||||
uint32_t handle);
|
uint32_t handle);
|
||||||
|
|
||||||
/**
|
|
||||||
* @gem_vm_ops: Driver private ops for this object
|
|
||||||
*
|
|
||||||
* For GEM drivers this is deprecated in favour of
|
|
||||||
* &drm_gem_object_funcs.vm_ops.
|
|
||||||
*/
|
|
||||||
const struct vm_operations_struct *gem_vm_ops;
|
|
||||||
|
|
||||||
/** @major: driver major number */
|
/** @major: driver major number */
|
||||||
int major;
|
int major;
|
||||||
/** @minor: driver minor number */
|
/** @minor: driver minor number */
|
||||||
|
@ -272,7 +272,7 @@ struct drm_gem_object {
|
|||||||
* attachment point for the device. This is invariant over the lifetime
|
* attachment point for the device. This is invariant over the lifetime
|
||||||
* of a gem object.
|
* of a gem object.
|
||||||
*
|
*
|
||||||
* The &drm_driver.gem_free_object_unlocked callback is responsible for
|
* The &drm_gem_object_funcs.free callback is responsible for
|
||||||
* cleaning up the dma_buf attachment and references acquired at import
|
* cleaning up the dma_buf attachment and references acquired at import
|
||||||
* time.
|
* time.
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user