forked from mirrors/linux
		
	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
					
				
					 7 changed files with 38 additions and 137 deletions
				
			
		| 
						 | 
					@ -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 a new issue