Re: [PATCH v6 3/8] [media] media: use media_gobj inside entities

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

 



Em Fri, 21 Aug 2015 20:51:10 +0300
Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> escreveu:

> Hi Mauro,
> 
> On Friday 21 August 2015 07:09:44 Mauro Carvalho Chehab wrote:
> > Em Fri, 21 Aug 2015 04:10:03 +0300 Laurent Pinchart escreveu:
> > > On Wednesday 19 August 2015 08:01:50 Mauro Carvalho Chehab wrote:
> > >> As entities are graph elements, let's embed media_gobj
> > >> on it. That ensures an unique ID for entities that can be
> > >> global along the entire media controller.
> > >> 
> > >> For now, we'll keep the already existing entity ID. Such
> > >> field need to be dropped at some point, but for now, let's
> > >> not do this, to avoid needing to review all drivers and
> > >> the userspace apps.
> > >> 
> > >> Signed-off-by: Mauro Carvalho Chehab <mchehab@xxxxxxxxxxxxxxx>
> > >> Acked-by: Hans Verkuil <hans.verkuil@xxxxxxxxx>
> > >> Signed-off-by: Mauro Carvalho Chehab <mchehab@xxxxxxxxxxxxxxx>
> > >> 
> > >> diff --git a/drivers/media/media-device.c b/drivers/media/media-device.c
> > >> index e429605ca2c3..81d6a130efef 100644
> > >> --- a/drivers/media/media-device.c
> > >> +++ b/drivers/media/media-device.c
> > >> @@ -379,7 +379,6 @@ int __must_check __media_device_register(struct
> > >> media_device *mdev,
> > >> 	if (WARN_ON(mdev->dev == NULL || mdev->model[0] == 0))
> > >>  		return -EINVAL;
> > >> 
> > >> -	mdev->entity_id = 1;
> > >>  	INIT_LIST_HEAD(&mdev->entities);
> > >>  	spin_lock_init(&mdev->lock);
> > >>  	mutex_init(&mdev->graph_mutex);
> > >> @@ -433,10 +432,8 @@ int __must_check media_device_register_entity(struct
> > >> media_device *mdev,
> > >> 	entity->parent = mdev;
> > >>  	spin_lock(&mdev->lock);
> > >> 
> > >> -	if (entity->id == 0)
> > >> -		entity->id = mdev->entity_id++;
> > >> -	else
> > >> -		mdev->entity_id = max(entity->id + 1, mdev->entity_id);
> > >> +	/* Initialize media_gobj embedded at the entity */
> > >> +	media_gobj_init(mdev, MEDIA_GRAPH_ENTITY, &entity->graph_obj);
> > > 
> > > Graph object initialization should be moved to media_entity_init() to keep
> > > initialization separate from registration.
> > 
> > Won't work. I tried. My first RFC patches were doing that.
> > 
> > The problem is that media_entity_init() is currently called too early
> > at the V4L2 drivers, before having mdev assigned.
> 
> That looks like a problem that should be fixed in the drivers then. The 
> initialization of media devices and entities hasn't been thought of correctly, 
> let's not carry mistakes forward.

In this particular case, calling media_gobj_init() during
media_entity_register() won't cause any troubles, and moving it latter
to media_entity_init() is a two lines patch, once drivers got fixed
by the drivers maintainers.

> > Also, objects without PADs don't call media_entity_init(). At long
> > term, this function may even disappear, as it only exists today to
> > allocate arrays for pads/links. If we get rid of the pads array, it
> > will make no sense to keep it.
> 
> I wouldn't do that, as if we later add a field to media_entity that requires 
> an initialization function to be called we would need to go and patch all the 
> code that instantiates media_entity to add init calls. I'd prefer keeping the 
> media_entity_init function even if all it does is call media_gobj_init.

OK.

> 
> > >>  	list_add_tail(&entity->list, &mdev->entities);
> > >>  	spin_unlock(&mdev->lock);
> > >> 
> > >> @@ -459,6 +456,7 @@ void media_device_unregister_entity(struct
> > >> media_entity *entity)
> > >> 		return;
> > >> 
> > >>  	spin_lock(&mdev->lock);
> > >> +	media_gobj_remove(&entity->graph_obj);
> > >>  	list_del(&entity->list);
> > >>  	spin_unlock(&mdev->lock);
> > >>  	entity->parent = NULL;
> > >> diff --git a/drivers/media/media-entity.c b/drivers/media/media-entity.c
> > >> index 4834172bf6f8..888cb88e19bf 100644
> > >> --- a/drivers/media/media-entity.c
> > >> +++ b/drivers/media/media-entity.c
> > >> @@ -43,7 +43,12 @@ void media_gobj_init(struct media_device *mdev,
> > >>  			   enum media_gobj_type type,
> > >>  			   struct media_gobj *gobj)
> > >>  {
> > >> -	/* For now, nothing to do */
> > >> +	/* Create a per-type unique object ID */
> > >> +	switch (type) {
> > >> +	case MEDIA_GRAPH_ENTITY:
> > >> +		gobj->id = media_gobj_gen_id(type, ++mdev->entity_id);
> > >> +		break;
> > >> +	}
> > >>  }
> > >>  
> > >>  /**
> > >> diff --git a/include/media/media-device.h b/include/media/media-device.h
> > >> index a44f18fdf321..f6deef6e5820 100644
> > >> --- a/include/media/media-device.h
> > >> +++ b/include/media/media-device.h
> > >> @@ -41,7 +41,7 @@ struct device;
> > >>   * @bus_info:	Unique and stable device location identifier
> > >>   * @hw_revision: Hardware device revision
> > >>   * @driver_version: Device driver version
> > >> - * @entity_id:	ID of the next entity to be registered
> > >> + * @entity_id:	Unique ID used on the last entity registered
> > >>   * @entities:	List of registered entities
> > >>   * @lock:	Entities list lock
> > >>   * @graph_mutex: Entities graph operation lock
> > >> @@ -69,6 +69,7 @@ struct media_device {
> > >>  	u32 driver_version;
> > >>  	
> > >>  	u32 entity_id;
> > >> +
> > >>  	struct list_head entities;
> > >>  	
> > >>  	/* Protects the entities list */
> > >> diff --git a/include/media/media-entity.h b/include/media/media-entity.h
> > >> index c1cd4fba051d..9ca366334bcf 100644
> > >> --- a/include/media/media-entity.h
> > >> +++ b/include/media/media-entity.h
> > >> @@ -33,10 +33,10 @@
> > >>  /**
> > >>   * enum media_gobj_type - type of a graph element
> > >>   *
> > >> + * @MEDIA_GRAPH_ENTITY:		Identify a media entity
> > > 
> > > I think we should explicitly define here what an entity is.
> > 
> > I'm happy to add a new text here if you have a better idea.
> >
> > Anyway, for now, I'm more concerned on getting things done than to spend
> > lots of time with the comments. As pointed on patch 1/8, while we're
> > changing a lot the code, those comments tend to become obsolete very
> > quick. The comments there is more like a boilerplate, as, once we finish
> > touching at the core,  it makes sense to review the comments at media *.h
> > files, converting all descriptions to kernel-doc-nano format (there are
> > several not using it) and review Documentation/media-framework.txt, adding
> > the missing parts.
> 
> Yes, we'll need to update Documentation/media-framework.txt. It doesn't have 
> to be done right now, but should be ready by the time patches get merged.

Ok.

> And 
> from my experience, even though writing documentation feels like wasting time 
> when you develop a patch series such as this one, it gets even more painful if 
> you delay it.
> 
> > >>   */
> > >>  enum media_gobj_type {
> > >> -	 /* FIXME: add the types here, as we embed media_gobj */
> > >> -	MEDIA_GRAPH_NONE
> > >> +	MEDIA_GRAPH_ENTITY,
> > >>  };
> 
--
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