Call media_devnode_init() from media_device_init(). This has the effect of
creating a struct device for the media_devnode before it is registered,
making it possible to obtain a reference to it for e.g. video devices.

Signed-off-by: Sakari Ailus <sakari.ai...@linux.intel.com>
---
 drivers/media/media-device.c | 26 ++++++++++++--------------
 1 file changed, 12 insertions(+), 14 deletions(-)

diff --git a/drivers/media/media-device.c b/drivers/media/media-device.c
index 5d3ec84..d534011 100644
--- a/drivers/media/media-device.c
+++ b/drivers/media/media-device.c
@@ -710,6 +710,8 @@ void media_device_init(struct media_device *mdev)
        mutex_init(&mdev->graph_mutex);
        ida_init(&mdev->entity_internal_idx);
 
+       media_devnode_init(&mdev->devnode);
+
        dev_dbg(mdev->dev, "Media device initialized\n");
 }
 EXPORT_SYMBOL_GPL(media_device_init);
@@ -720,7 +722,10 @@ static void media_device_release(struct media_devnode 
*devnode)
 
        dev_dbg(devnode->parent, "Media device released\n");
 
-       media_device_cleanup(mdev);
+       ida_destroy(&mdev->entity_internal_idx);
+       mdev->entity_internal_idx_max = 0;
+       media_entity_graph_walk_cleanup(&mdev->pm_count_walk);
+       mutex_destroy(&mdev->graph_mutex);
 
        kfree(mdev);
 }
@@ -748,6 +753,7 @@ void media_device_cleanup(struct media_device *mdev)
        mdev->entity_internal_idx_max = 0;
        media_entity_graph_walk_cleanup(&mdev->pm_count_walk);
        mutex_destroy(&mdev->graph_mutex);
+       media_device_put(mdev);
 }
 EXPORT_SYMBOL_GPL(media_device_cleanup);
 
@@ -763,26 +769,19 @@ int __must_check __media_device_register(struct 
media_device *mdev,
        /* Set version 0 to indicate user-space that the graph is static */
        mdev->topology_version = 0;
 
-       media_devnode_init(&mdev->devnode);
-
        ret = media_devnode_register(&mdev->devnode, owner);
        if (ret < 0)
-               goto out_put;
+               return ret;
 
        ret = device_create_file(&mdev->devnode.dev, &dev_attr_model);
-       if (ret < 0)
-               goto out_unregister;
+       if (ret < 0) {
+               media_devnode_unregister(&mdev->devnode);
+               return ret;
+       }
 
        dev_dbg(mdev->dev, "Media device registered\n");
 
        return 0;
-
-out_unregister:
-       media_devnode_unregister(&mdev->devnode);
-out_put:
-       put_device(&mdev->devnode.dev);
-
-       return ret;
 }
 EXPORT_SYMBOL_GPL(__media_device_register);
 
@@ -825,7 +824,6 @@ void media_device_unregister(struct media_device *mdev)
        device_remove_file(&mdev->devnode.dev, &dev_attr_model);
        dev_dbg(mdev->dev, "Media device unregistering\n");
        media_devnode_unregister(&mdev->devnode);
-       put_device(&mdev->devnode.dev);
 }
 EXPORT_SYMBOL_GPL(media_device_unregister);
 
-- 
2.1.4

--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to