We need to be able to navigate at the interfaces that
belong to a given media device, in to indirect
interface links.

So, add a linked list to track them.

Signed-off-by: Mauro Carvalho Chehab <mche...@osg.samsung.com>

diff --git a/drivers/media/media-device.c b/drivers/media/media-device.c
index 3e649cacfc07..659507bce63f 100644
--- a/drivers/media/media-device.c
+++ b/drivers/media/media-device.c
@@ -381,6 +381,7 @@ int __must_check __media_device_register(struct 
media_device *mdev,
                return -EINVAL;
 
        INIT_LIST_HEAD(&mdev->entities);
+       INIT_LIST_HEAD(&mdev->interfaces);
        spin_lock_init(&mdev->lock);
        mutex_init(&mdev->graph_mutex);
 
diff --git a/drivers/media/media-entity.c b/drivers/media/media-entity.c
index 16d7d96abb9f..05976c891c17 100644
--- a/drivers/media/media-entity.c
+++ b/drivers/media/media-entity.c
@@ -875,6 +875,8 @@ struct media_intf_devnode *media_devnode_create(struct 
media_device *mdev,
        media_gobj_init(mdev, MEDIA_GRAPH_INTF_DEVNODE,
                       &devnode->intf.graph_obj);
 
+       list_add_tail(&intf->list, &mdev->interfaces);
+
        return devnode;
 }
 EXPORT_SYMBOL_GPL(media_devnode_create);
@@ -882,6 +884,7 @@ EXPORT_SYMBOL_GPL(media_devnode_create);
 void media_devnode_remove(struct media_intf_devnode *devnode)
 {
        media_gobj_remove(&devnode->intf.graph_obj);
+       list_del(&devnode->intf.list);
        kfree(devnode);
 }
 EXPORT_SYMBOL_GPL(media_devnode_remove);
diff --git a/include/media/media-device.h b/include/media/media-device.h
index 3b14394d5701..51807efa505b 100644
--- a/include/media/media-device.h
+++ b/include/media/media-device.h
@@ -46,6 +46,7 @@ struct device;
  * @link_id:   Unique ID used on the last link registered
  * @intf_devnode_id: Unique ID used on the last interface devnode registered
  * @entities:  List of registered entities
+ * @interfaces:        List of registered interfaces
  * @lock:      Entities list lock
  * @graph_mutex: Entities graph operation lock
  * @link_notify: Link state change notification callback
@@ -77,6 +78,7 @@ struct media_device {
        u32 intf_devnode_id;
 
        struct list_head entities;
+       struct list_head interfaces;
 
        /* Protects the entities list */
        spinlock_t lock;
diff --git a/include/media/media-entity.h b/include/media/media-entity.h
index aeb390a9e0f3..35d97017dd19 100644
--- a/include/media/media-entity.h
+++ b/include/media/media-entity.h
@@ -156,6 +156,8 @@ struct media_entity {
  * struct media_intf_devnode - Define a Kernel API interface
  *
  * @graph_obj:         embedded graph object
+ * @list:              Linked list used to find other interfaces that belong
+ *                     to the same media controller
  * @links:             List of links pointing to graph entities
  * @type:              Type of the interface as defined at the
  *                     uapi/media/media.h header, e. g.
@@ -164,6 +166,7 @@ struct media_entity {
  */
 struct media_interface {
        struct media_gobj               graph_obj;
+       struct list_head                list;
        struct list_head                links;
        u32                             type;
        u32                             flags;
-- 
2.4.3

--
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