[media] media: use media_gobj inside pads
authorMauro Carvalho Chehab <mchehab@osg.samsung.com>
Fri, 14 Aug 2015 15:50:08 +0000 (12:50 -0300)
committerMauro Carvalho Chehab <mchehab@osg.samsung.com>
Mon, 11 Jan 2016 14:18:42 +0000 (12:18 -0200)
PADs also need unique object IDs that won't conflict with
the entity object IDs.

The pad objects are currently created via media_entity_init()
and, once created, never change.

While this will likely change in the future in order to
support dynamic changes, for now we'll keep PADs as arrays
and initialize the media_gobj embedded structs when
registering the entity.

Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
Tested-by: Javier Martinez Canillas <javier@osg.samsung.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@osg.samsung.com>
drivers/media/media-device.c
drivers/media/media-entity.c
include/media/media-device.h
include/media/media-entity.h

index 81d6a130efef57a784c89fb30a447c12f1a385c8..3bdda16584fe95fa7ae1ebbe8ee1c77fb3ce8dab 100644 (file)
@@ -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);
index 9f6f056eaeb01095b7354c77a087411f164c9211..2d94c859057b2b9a429e41d63cbc0e5cea5e7ab6 100644 (file)
@@ -48,6 +48,9 @@ void media_gobj_init(struct media_device *mdev,
        case MEDIA_GRAPH_ENTITY:
                gobj->id = media_gobj_gen_id(type, ++mdev->entity_id);
                break;
+       case MEDIA_GRAPH_PAD:
+               gobj->id = media_gobj_gen_id(type, ++mdev->pad_id);
+               break;
        }
 }
 
index f6deef6e58206eaae8b1df057e8cbad950c0215d..9493721f630ecf0f8121e0c91555917bd11e1cb0 100644 (file)
@@ -42,6 +42,7 @@ struct device;
  * @hw_revision: Hardware device revision
  * @driver_version: Device driver version
  * @entity_id: Unique ID used on the last entity registered
+ * @pad_id:    Unique ID used on the last pad registered
  * @entities:  List of registered entities
  * @lock:      Entities list lock
  * @graph_mutex: Entities graph operation lock
@@ -69,6 +70,7 @@ struct media_device {
        u32 driver_version;
 
        u32 entity_id;
+       u32 pad_id;
 
        struct list_head entities;
 
index 4faa4d830da4b0463c463e19b1f8bb412083ac15..b91c78d34f79b032a593064f550d7b9f184e21d9 100644 (file)
  * enum media_gobj_type - type of a graph object
  *
  * @MEDIA_GRAPH_ENTITY:                Identify a media entity
+ * @MEDIA_GRAPH_PAD:           Identify a media pad
  */
 enum media_gobj_type {
        MEDIA_GRAPH_ENTITY,
+       MEDIA_GRAPH_PAD,
 };
 
 #define MEDIA_BITS_PER_TYPE            8
@@ -72,6 +74,7 @@ struct media_link {
 };
 
 struct media_pad {
+       struct media_gobj graph_obj;
        struct media_entity *entity;    /* Entity this pad belongs to */
        u16 index;                      /* Pad index in the entity pads array */
        unsigned long flags;            /* Pad flags (MEDIA_PAD_FL_*) */