Commit 05981422 authored by Daniel Vetter's avatar Daniel Vetter Committed by Dave Airlie

drm: Improve kerneldoc for new mode object refcounting

Slipped through the cracks in my review. The one issue I spotted
is that drm_mode_object_find now acquires references and can be
used on FB objects, which caused follow-on bugs in get/set_prop ioctls.
Follow-up patches will fix that.

[airlied: fixup some incr fb/decr object mixups]
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent 944a3f32
...@@ -380,10 +380,9 @@ static struct drm_mode_object *_object_find(struct drm_device *dev, ...@@ -380,10 +380,9 @@ static struct drm_mode_object *_object_find(struct drm_device *dev,
* @id: id of the mode object * @id: id of the mode object
* @type: type of the mode object * @type: type of the mode object
* *
* Note that framebuffers cannot be looked up with this functions - since those * This function is used to look up a modeset object. It will acquire a
* are reference counted, they need special treatment. Even with * reference for reference counted objects. This reference must be dropped again
* DRM_MODE_OBJECT_ANY (although that will simply return NULL * by callind drm_mode_object_unreference().
* rather than WARN_ON()).
*/ */
struct drm_mode_object *drm_mode_object_find(struct drm_device *dev, struct drm_mode_object *drm_mode_object_find(struct drm_device *dev,
uint32_t id, uint32_t type) uint32_t id, uint32_t type)
...@@ -398,6 +397,14 @@ struct drm_mode_object *drm_mode_object_find(struct drm_device *dev, ...@@ -398,6 +397,14 @@ struct drm_mode_object *drm_mode_object_find(struct drm_device *dev,
} }
EXPORT_SYMBOL(drm_mode_object_find); EXPORT_SYMBOL(drm_mode_object_find);
/**
* drm_mode_object_unreference - decr the object refcnt
* @obj: mode_object
*
* This functions decrements the object's refcount if it is a refcounted modeset
* object. It is a no-op on any other object. This is used to drop references
* acquired with drm_mode_object_reference().
*/
void drm_mode_object_unreference(struct drm_mode_object *obj) void drm_mode_object_unreference(struct drm_mode_object *obj)
{ {
if (obj->free_cb) { if (obj->free_cb) {
...@@ -408,11 +415,12 @@ void drm_mode_object_unreference(struct drm_mode_object *obj) ...@@ -408,11 +415,12 @@ void drm_mode_object_unreference(struct drm_mode_object *obj)
EXPORT_SYMBOL(drm_mode_object_unreference); EXPORT_SYMBOL(drm_mode_object_unreference);
/** /**
* drm_mode_object_reference - incr the fb refcnt * drm_mode_object_reference - incr the object refcnt
* @obj: mode_object * @obj: mode_object
* *
* This function operates only on refcounted objects. * This functions increments the object's refcount if it is a refcounted modeset
* This functions increments the object's refcount. * object. It is a no-op on any other object. References should be dropped again
* by calling drm_mode_object_unreference().
*/ */
void drm_mode_object_reference(struct drm_mode_object *obj) void drm_mode_object_reference(struct drm_mode_object *obj)
{ {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment