Hi Sakari,

Thanks for the patch.

On Friday 02 March 2012 19:30:24 Sakari Ailus wrote:
> Make information available which entities are part of the pipeline before
> link_validate() ops are being called.
> 
> Signed-off-by: Sakari Ailus <sakari.ai...@iki.fi>
> ---
>  drivers/media/media-entity.c |   23 ++++++++++++++++++++---
>  include/media/media-entity.h |    1 +
>  2 files changed, 21 insertions(+), 3 deletions(-)
> 
> diff --git a/drivers/media/media-entity.c b/drivers/media/media-entity.c
> index d6d0e81..55f66c6 100644
> --- a/drivers/media/media-entity.c
> +++ b/drivers/media/media-entity.c
> @@ -220,12 +220,19 @@ __must_check int media_entity_pipeline_start(struct
> media_entity *entity, struct media_device *mdev = entity->parent;
>       struct media_entity_graph graph;
>       struct media_entity *entity_err = entity;
> +     struct {
> +             struct media_entity *entity;
> +             struct media_link *link;
> +     } to_validate[MEDIA_ENTITY_ENUM_MAX_DEPTH];
> +     int nto_validate = 0;
>       int ret;
> 
>       mutex_lock(&mdev->graph_mutex);
> 
>       media_entity_graph_walk_start(&graph, entity);
> 
> +     pipe->entities = 0;
> +
>       while ((entity = media_entity_graph_walk_next(&graph))) {
>               unsigned int i;
> 
> @@ -237,6 +244,8 @@ __must_check int media_entity_pipeline_start(struct
> media_entity *entity, if (entity->stream_count > 1)
>                       continue;
> 
> +             pipe->entities |= 1 << entity->id;
> +
>               if (!entity->ops || !entity->ops->link_validate)
>                       continue;
> 
> @@ -251,12 +260,20 @@ __must_check int media_entity_pipeline_start(struct
> media_entity *entity, if (link->sink->entity != entity)
>                               continue;
> 
> -                     ret = entity->ops->link_validate(link);
> -                     if (ret < 0 && ret != -ENOIOCTLCMD)
> -                             goto error;
> +                     BUG_ON(nto_validate >= MEDIA_ENTITY_ENUM_MAX_DEPTH);
> +                     to_validate[nto_validate].entity = entity;
> +                     to_validate[nto_validate].link = link;
> +                     nto_validate++;
>               }
>       }
> 
> +     for (nto_validate--; nto_validate >= 0; nto_validate--) {
> +             ret = to_validate[nto_validate].entity->ops->
> +                     link_validate(to_validate[nto_validate].link);
> +             if (ret < 0 && ret != -ENOIOCTLCMD)
> +                     goto error;
> +     }
> +
>       mutex_unlock(&mdev->graph_mutex);
> 
>       return 0;
> diff --git a/include/media/media-entity.h b/include/media/media-entity.h
> index 0c16f51..bbfc8f2 100644
> --- a/include/media/media-entity.h
> +++ b/include/media/media-entity.h
> @@ -27,6 +27,7 @@
>  #include <linux/media.h>
> 
>  struct media_pipeline {
> +     u32 entities;

This assume there will be no more than 32 entities. I don't think that's a 
safe assumption, especially with ALSA devices. I'm not sure I would put this 
in the media controller core just yet.

>  };
> 
>  struct media_link {

-- 
Regards,

Laurent Pinchart

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