Commit 6b6a4278 authored by Mauro Carvalho Chehab's avatar Mauro Carvalho Chehab

[media] media: use media_gobj inside links

Just like entities and pads, links also need to have unique
Object IDs along a given media controller.

So, let's add a media_gobj inside it and initialize
the object then a new link is created.
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 18710dc6
...@@ -438,6 +438,13 @@ int __must_check media_device_register_entity(struct media_device *mdev, ...@@ -438,6 +438,13 @@ int __must_check media_device_register_entity(struct media_device *mdev,
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 links
* in the case where links got created before entity register
*/
for (i = 0; i < entity->num_links; i++)
media_gobj_init(mdev, MEDIA_GRAPH_LINK,
&entity->links[i].graph_obj);
/* Initialize objects at the pads */ /* Initialize objects at the pads */
for (i = 0; i < entity->num_pads; i++) for (i = 0; i < entity->num_pads; i++)
media_gobj_init(mdev, MEDIA_GRAPH_PAD, media_gobj_init(mdev, MEDIA_GRAPH_PAD,
...@@ -465,6 +472,8 @@ void media_device_unregister_entity(struct media_entity *entity) ...@@ -465,6 +472,8 @@ void media_device_unregister_entity(struct media_entity *entity)
return; return;
spin_lock(&mdev->lock); spin_lock(&mdev->lock);
for (i = 0; i < entity->num_links; i++)
media_gobj_remove(&entity->links[i].graph_obj);
for (i = 0; i < entity->num_pads; i++) for (i = 0; i < entity->num_pads; i++)
media_gobj_remove(&entity->pads[i].graph_obj); media_gobj_remove(&entity->pads[i].graph_obj);
media_gobj_remove(&entity->graph_obj); media_gobj_remove(&entity->graph_obj);
......
...@@ -51,6 +51,9 @@ void media_gobj_init(struct media_device *mdev, ...@@ -51,6 +51,9 @@ void media_gobj_init(struct media_device *mdev,
case MEDIA_GRAPH_PAD: case MEDIA_GRAPH_PAD:
gobj->id = media_gobj_gen_id(type, ++mdev->pad_id); gobj->id = media_gobj_gen_id(type, ++mdev->pad_id);
break; break;
case MEDIA_GRAPH_LINK:
gobj->id = media_gobj_gen_id(type, ++mdev->link_id);
break;
} }
} }
...@@ -491,6 +494,9 @@ media_entity_create_link(struct media_entity *source, u16 source_pad, ...@@ -491,6 +494,9 @@ media_entity_create_link(struct media_entity *source, u16 source_pad,
link->sink = &sink->pads[sink_pad]; link->sink = &sink->pads[sink_pad];
link->flags = flags; link->flags = flags;
/* Initialize graph object embedded at the new link */
media_gobj_init(source->parent, MEDIA_GRAPH_LINK, &link->graph_obj);
/* Create the backlink. Backlinks are used to help graph traversal and /* Create the backlink. Backlinks are used to help graph traversal and
* are not reported to userspace. * are not reported to userspace.
*/ */
...@@ -504,6 +510,9 @@ media_entity_create_link(struct media_entity *source, u16 source_pad, ...@@ -504,6 +510,9 @@ media_entity_create_link(struct media_entity *source, u16 source_pad,
backlink->sink = &sink->pads[sink_pad]; backlink->sink = &sink->pads[sink_pad];
backlink->flags = flags; backlink->flags = flags;
/* Initialize graph object embedded at the new link */
media_gobj_init(sink->parent, MEDIA_GRAPH_LINK, &backlink->graph_obj);
link->reverse = backlink; link->reverse = backlink;
backlink->reverse = link; backlink->reverse = link;
......
...@@ -43,6 +43,7 @@ struct device; ...@@ -43,6 +43,7 @@ struct device;
* @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 * @pad_id: Unique ID used on the last pad registered
* @link_id: Unique ID used on the last link 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
...@@ -71,6 +72,7 @@ struct media_device { ...@@ -71,6 +72,7 @@ struct media_device {
u32 entity_id; u32 entity_id;
u32 pad_id; u32 pad_id;
u32 link_id;
struct list_head entities; struct list_head entities;
......
...@@ -35,10 +35,12 @@ ...@@ -35,10 +35,12 @@
* *
* @MEDIA_GRAPH_ENTITY: Identify a media entity * @MEDIA_GRAPH_ENTITY: Identify a media entity
* @MEDIA_GRAPH_PAD: Identify a media pad * @MEDIA_GRAPH_PAD: Identify a media pad
* @MEDIA_GRAPH_LINK: Identify a media link
*/ */
enum media_gobj_type { enum media_gobj_type {
MEDIA_GRAPH_ENTITY, MEDIA_GRAPH_ENTITY,
MEDIA_GRAPH_PAD, MEDIA_GRAPH_PAD,
MEDIA_GRAPH_LINK,
}; };
#define MEDIA_BITS_PER_TYPE 8 #define MEDIA_BITS_PER_TYPE 8
...@@ -67,6 +69,7 @@ struct media_pipeline { ...@@ -67,6 +69,7 @@ struct media_pipeline {
}; };
struct media_link { struct media_link {
struct media_gobj graph_obj;
struct media_pad *source; /* Source pad */ struct media_pad *source; /* Source pad */
struct media_pad *sink; /* Sink pad */ struct media_pad *sink; /* Sink pad */
struct media_link *reverse; /* Link in the reverse direction */ struct media_link *reverse; /* Link in the reverse direction */
......
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