drm: Unify handling of blob and object properties
They work exactly the same now, after the refcounting unification a bit ago. The only reason they're distinct is backwards compat with existing userspace. Cc: Daniel Stone <daniels@collabora.com> Reviewed-by: Archit Taneja <architt@codeaurora.org> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch> Link: http://patchwork.freedesktop.org/patch/msgid/20160829082757.17913-8-daniel.vetter@ffwll.ch
This commit is contained in:
parent
59e71ee746
commit
77953bd136
@ -911,20 +911,8 @@ bool drm_property_change_valid_get(struct drm_property *property,
|
||||
for (i = 0; i < property->num_values; i++)
|
||||
valid_mask |= (1ULL << property->values[i]);
|
||||
return !(value & ~valid_mask);
|
||||
} else if (drm_property_type_is(property, DRM_MODE_PROP_BLOB)) {
|
||||
struct drm_property_blob *blob;
|
||||
|
||||
if (value == 0)
|
||||
return true;
|
||||
|
||||
blob = drm_property_lookup_blob(property->dev, value);
|
||||
if (blob) {
|
||||
*ref = &blob->base;
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
} else if (drm_property_type_is(property, DRM_MODE_PROP_OBJECT)) {
|
||||
} else if (drm_property_type_is(property, DRM_MODE_PROP_BLOB) ||
|
||||
drm_property_type_is(property, DRM_MODE_PROP_OBJECT)) {
|
||||
/* a zero value for an object property translates to null: */
|
||||
if (value == 0)
|
||||
return true;
|
||||
@ -941,13 +929,12 @@ bool drm_property_change_valid_get(struct drm_property *property,
|
||||
}
|
||||
|
||||
void drm_property_change_valid_put(struct drm_property *property,
|
||||
struct drm_mode_object *ref)
|
||||
struct drm_mode_object *ref)
|
||||
{
|
||||
if (!ref)
|
||||
return;
|
||||
|
||||
if (drm_property_type_is(property, DRM_MODE_PROP_OBJECT)) {
|
||||
if (drm_property_type_is(property, DRM_MODE_PROP_OBJECT) ||
|
||||
drm_property_type_is(property, DRM_MODE_PROP_BLOB))
|
||||
drm_mode_object_unreference(ref);
|
||||
} else if (drm_property_type_is(property, DRM_MODE_PROP_BLOB))
|
||||
drm_property_unreference_blob(obj_to_blob(ref));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user