drm/vma_manage: Drop has_offset
It's racy, creating mmap offsets is a slowpath, so better to remove it to avoid drivers doing broken things. The only user is i915, and it's ok there because everything (well almost) is protected by dev->struct_mutex in i915-gem. While at it add a note in the create_mmap_offset kerneldoc that drivers must release it again. And then I also noticed that drm_gem_object_release entirely lacks kerneldoc. Cc: David Herrmann <dh.herrmann@gmail.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1459330852-27668-14-git-send-email-daniel.vetter@ffwll.ch
This commit is contained in:
@@ -422,6 +422,10 @@ EXPORT_SYMBOL(drm_gem_handle_create);
|
||||
* @obj: obj in question
|
||||
*
|
||||
* This routine frees fake offsets allocated by drm_gem_create_mmap_offset().
|
||||
*
|
||||
* Note that drm_gem_object_release() already calls this function, so drivers
|
||||
* don't have to take care of releasing the mmap offset themselves when freeing
|
||||
* the GEM object.
|
||||
*/
|
||||
void
|
||||
drm_gem_free_mmap_offset(struct drm_gem_object *obj)
|
||||
@@ -445,6 +449,9 @@ EXPORT_SYMBOL(drm_gem_free_mmap_offset);
|
||||
* This routine allocates and attaches a fake offset for @obj, in cases where
|
||||
* the virtual size differs from the physical size (ie. obj->size). Otherwise
|
||||
* just use drm_gem_create_mmap_offset().
|
||||
*
|
||||
* This function is idempotent and handles an already allocated mmap offset
|
||||
* transparently. Drivers do not need to check for this case.
|
||||
*/
|
||||
int
|
||||
drm_gem_create_mmap_offset_size(struct drm_gem_object *obj, size_t size)
|
||||
@@ -466,6 +473,9 @@ EXPORT_SYMBOL(drm_gem_create_mmap_offset_size);
|
||||
* structures.
|
||||
*
|
||||
* This routine allocates and attaches a fake offset for @obj.
|
||||
*
|
||||
* Drivers can call drm_gem_free_mmap_offset() before freeing @obj to release
|
||||
* the fake offset again.
|
||||
*/
|
||||
int drm_gem_create_mmap_offset(struct drm_gem_object *obj)
|
||||
{
|
||||
@@ -759,6 +769,13 @@ drm_gem_release(struct drm_device *dev, struct drm_file *file_private)
|
||||
idr_destroy(&file_private->object_idr);
|
||||
}
|
||||
|
||||
/**
|
||||
* drm_gem_object_release - release GEM buffer object resources
|
||||
* @obj: GEM buffer object
|
||||
*
|
||||
* This releases any structures and resources used by @obj and is the invers of
|
||||
* drm_gem_object_init().
|
||||
*/
|
||||
void
|
||||
drm_gem_object_release(struct drm_gem_object *obj)
|
||||
{
|
||||
|
Reference in New Issue
Block a user