Re: [PATCH v4 16/34] media: Collect entities that are part of the pipeline before link validation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Laurent,

On Mon, Mar 05, 2012 at 12:13:39PM +0100, Laurent Pinchart wrote:
> 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.ailus@xxxxxx>
> > ---
> >  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.

Based our discussion online, I'm dropping this patch and replacing it with
another which is specific to the omap3isp driver.

Cheers,

-- 
Sakari Ailus
e-mail: sakari.ailus@xxxxxx	jabber/XMPP/Gmail: sailus@xxxxxxxxxxxxxx
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]
  Powered by Linux