Commit 18710dc6 authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab

[media] media: use media_gobj inside pads

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: default avatarHans Verkuil <hans.verkuil@cisco.com>
Tested-by: default avatarJavier Martinez Canillas <javier@osg.samsung.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent bfab2aac
...@@ -427,6 +427,8 @@ EXPORT_SYMBOL_GPL(media_device_unregister); ...@@ -427,6 +427,8 @@ EXPORT_SYMBOL_GPL(media_device_unregister);
int __must_check media_device_register_entity(struct media_device *mdev, int __must_check media_device_register_entity(struct media_device *mdev,
struct media_entity *entity) struct media_entity *entity)
{ {
int i;
/* Warn if we apparently re-register an entity */ /* Warn if we apparently re-register an entity */
WARN_ON(entity->parent != NULL); WARN_ON(entity->parent != NULL);
entity->parent = mdev; entity->parent = mdev;
...@@ -435,6 +437,12 @@ int __must_check media_device_register_entity(struct media_device *mdev, ...@@ -435,6 +437,12 @@ int __must_check media_device_register_entity(struct media_device *mdev,
/* Initialize media_gobj embedded at the entity */ /* Initialize media_gobj embedded at the entity */
media_gobj_init(mdev, MEDIA_GRAPH_ENTITY, &entity->graph_obj); media_gobj_init(mdev, MEDIA_GRAPH_ENTITY, &entity->graph_obj);
list_add_tail(&entity->list, &mdev->entities); 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); spin_unlock(&mdev->lock);
return 0; return 0;
...@@ -450,12 +458,15 @@ EXPORT_SYMBOL_GPL(media_device_register_entity); ...@@ -450,12 +458,15 @@ EXPORT_SYMBOL_GPL(media_device_register_entity);
*/ */
void media_device_unregister_entity(struct media_entity *entity) void media_device_unregister_entity(struct media_entity *entity)
{ {
int i;
struct media_device *mdev = entity->parent; struct media_device *mdev = entity->parent;
if (mdev == NULL) if (mdev == NULL)
return; return;
spin_lock(&mdev->lock); 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); media_gobj_remove(&entity->graph_obj);
list_del(&entity->list); list_del(&entity->list);
spin_unlock(&mdev->lock); spin_unlock(&mdev->lock);
......
...@@ -48,6 +48,9 @@ void media_gobj_init(struct media_device *mdev, ...@@ -48,6 +48,9 @@ void media_gobj_init(struct media_device *mdev,
case MEDIA_GRAPH_ENTITY: case MEDIA_GRAPH_ENTITY:
gobj->id = media_gobj_gen_id(type, ++mdev->entity_id); gobj->id = media_gobj_gen_id(type, ++mdev->entity_id);
break; break;
case MEDIA_GRAPH_PAD:
gobj->id = media_gobj_gen_id(type, ++mdev->pad_id);
break;
} }
} }
......
...@@ -42,6 +42,7 @@ struct device; ...@@ -42,6 +42,7 @@ struct device;
* @hw_revision: Hardware device revision * @hw_revision: Hardware device revision
* @driver_version: Device driver version * @driver_version: Device driver version
* @entity_id: Unique ID used on the last entity registered * @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 * @entities: List of registered entities
* @lock: Entities list lock * @lock: Entities list lock
* @graph_mutex: Entities graph operation lock * @graph_mutex: Entities graph operation lock
...@@ -69,6 +70,7 @@ struct media_device { ...@@ -69,6 +70,7 @@ struct media_device {
u32 driver_version; u32 driver_version;
u32 entity_id; u32 entity_id;
u32 pad_id;
struct list_head entities; struct list_head entities;
......
...@@ -34,9 +34,11 @@ ...@@ -34,9 +34,11 @@
* enum media_gobj_type - type of a graph object * enum media_gobj_type - type of a graph object
* *
* @MEDIA_GRAPH_ENTITY: Identify a media entity * @MEDIA_GRAPH_ENTITY: Identify a media entity
* @MEDIA_GRAPH_PAD: Identify a media pad
*/ */
enum media_gobj_type { enum media_gobj_type {
MEDIA_GRAPH_ENTITY, MEDIA_GRAPH_ENTITY,
MEDIA_GRAPH_PAD,
}; };
#define MEDIA_BITS_PER_TYPE 8 #define MEDIA_BITS_PER_TYPE 8
...@@ -72,6 +74,7 @@ struct media_link { ...@@ -72,6 +74,7 @@ struct media_link {
}; };
struct media_pad { struct media_pad {
struct media_gobj graph_obj;
struct media_entity *entity; /* Entity this pad belongs to */ struct media_entity *entity; /* Entity this pad belongs to */
u16 index; /* Pad index in the entity pads array */ u16 index; /* Pad index in the entity pads array */
unsigned long flags; /* Pad flags (MEDIA_PAD_FL_*) */ unsigned long flags; /* Pad flags (MEDIA_PAD_FL_*) */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment