|
@@ -427,6 +427,8 @@ EXPORT_SYMBOL_GPL(media_device_unregister);
|
|
|
int __must_check media_device_register_entity(struct media_device *mdev,
|
|
|
struct media_entity *entity)
|
|
|
{
|
|
|
+ int i;
|
|
|
+
|
|
|
/* Warn if we apparently re-register an entity */
|
|
|
WARN_ON(entity->parent != NULL);
|
|
|
entity->parent = mdev;
|
|
@@ -435,6 +437,12 @@ int __must_check media_device_register_entity(struct media_device *mdev,
|
|
|
/* Initialize media_gobj embedded at the entity */
|
|
|
media_gobj_init(mdev, MEDIA_GRAPH_ENTITY, &entity->graph_obj);
|
|
|
list_add_tail(&entity->list, &mdev->entities);
|
|
|
+
|
|
|
+ /* Initialize objects at the pads */
|
|
|
+ for (i = 0; i < entity->num_pads; i++)
|
|
|
+ media_gobj_init(mdev, MEDIA_GRAPH_PAD,
|
|
|
+ &entity->pads[i].graph_obj);
|
|
|
+
|
|
|
spin_unlock(&mdev->lock);
|
|
|
|
|
|
return 0;
|
|
@@ -450,12 +458,15 @@ EXPORT_SYMBOL_GPL(media_device_register_entity);
|
|
|
*/
|
|
|
void media_device_unregister_entity(struct media_entity *entity)
|
|
|
{
|
|
|
+ int i;
|
|
|
struct media_device *mdev = entity->parent;
|
|
|
|
|
|
if (mdev == NULL)
|
|
|
return;
|
|
|
|
|
|
spin_lock(&mdev->lock);
|
|
|
+ for (i = 0; i < entity->num_pads; i++)
|
|
|
+ media_gobj_remove(&entity->pads[i].graph_obj);
|
|
|
media_gobj_remove(&entity->graph_obj);
|
|
|
list_del(&entity->list);
|
|
|
spin_unlock(&mdev->lock);
|