From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: Hans Verkuil <hverkuil@xs4all.nl>
Cc: Mauro Carvalho Chehab <mchehab@osg.samsung.com>,
Sakari Ailus <sakari.ailus@iki.fi>,
Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>,
linux-media@vger.kernel.org,
Sakari Ailus <sakari.ailus@linux.intel.com>
Subject: Re: [PATCH] media: Add type field to struct media_entity
Date: Mon, 29 Feb 2016 12:43:30 +0200 [thread overview]
Message-ID: <2531247.20gWSsdPQH@avalon> (raw)
In-Reply-To: <56D40122.6090502@xs4all.nl>
Hi Hans,
On Monday 29 February 2016 09:28:18 Hans Verkuil wrote:
> On 02/28/2016 08:09 PM, Laurent Pinchart wrote:
> > On Friday 26 February 2016 15:00:06 Hans Verkuil wrote:
> >> On 02/26/2016 02:21 PM, Mauro Carvalho Chehab wrote:
> >>> Em Fri, 26 Feb 2016 13:18:30 +0200 Laurent Pinchart escreveu:
> >>>> On Monday 22 February 2016 23:20:58 Sakari Ailus wrote:
> >>>>> On Mon, Feb 22, 2016 at 06:46:01AM -0300, Mauro Carvalho Chehab wrote:
> >>>>>> Em Mon, 22 Feb 2016 03:53:16 +0200 Laurent Pinchart escreveu:
> >>>>>>> Code that processes media entities can require knowledge of the
> >>>>>>> structure type that embeds a particular media entity instance in
> >>>>>>> order to use the API provided by that structure. This needs is shown
> >>>>>>> by the presence of the is_media_entity_v4l2_io and
> >>>>>>> is_media_entity_v4l2_subdev
> >>>>>>> functions.
> >>>>>>>
> >>>>>>> The implementation of those two functions relies on the entity
> >>>>>>> function field, which is both a wrong and an inefficient design,
> >>>>>>> without even
> >>>>>
> >>>>> I wouldn't necessarily say "wrong", but it is risky. A device's
> >>>>> function not only defines the interface it offers but also which
> >>>>> struct is considered to contain the media entity. Having a wrong value
> >>>>> in the function field may thus lead memory corruption and / or system
> >>>>> crash.
> >>>>>
> >>>>>>> mentioning the maintenance issue involved in updating the functions
> >>>>>>> every time a new entity function is added. Fix this by adding add a
> >>>>>>> type field to the media entity structure to carry the information.
> >>>>>>>
> >>>>>>> Signed-off-by: Laurent Pinchart
> >>>>>>> <laurent.pinchart+renesas@ideasonboard.com>
> >>>>>>> ---
> >>>>>>>
> >>>>>>> drivers/media/v4l2-core/v4l2-dev.c | 1 +
> >>>>>>> drivers/media/v4l2-core/v4l2-subdev.c | 1 +
> >>>>>>> include/media/media-entity.h | 65 +++++++++--------------
> >>>>>>> 3 files changed, 30 insertions(+), 37 deletions(-)
> >>>>
> >>>> [snip]
> >>>>
> >>>>>>> diff --git a/include/media/media-entity.h
> >>>>>>> b/include/media/media-entity.h
> >>>>>>> index fe485d367985..2be38483f3a4 100644
> >>>>>>> --- a/include/media/media-entity.h
> >>>>>>> +++ b/include/media/media-entity.h
> >>>>>>> @@ -187,10 +187,27 @@ struct media_entity_operations {
> >>>>>>> };
> >>>>>>>
> >>>>>>> /**
> >>>>>>> + * enum MEDIA_ENTITY_TYPE_NONE - Media entity type
> >>>>>>> + *
> >>>>>>
> >>>>>> s/MEDIA_ENTITY_TYPE_NONE/media_entity_type/
> >>>>>>
> >>>>>> (it seems you didn't test producing the docbook, otherwise you would
> >>>>>> have seen this error - Please always generate the docbook when the
> >>>>>> patch contains kernel-doc markups)
> >>>>
> >>>> Oops, sorry. I'll fix that.
> >>>>
> >>>>>> I don't like the idea of calling it as "type", as this is confusing,
> >>>>>> specially since we used to call entity.type for what we now call
> >>>>>> function.
> >>>>>
> >>>>> What that field essentially defines is which struct embeds the media
> >>>>> entity. (Well, there's some cleanups to be done there, as we have
> >>>>> extra entity for V4L2 subdevices, but that's another story.)
> >>>>>
> >>>>> The old type field had that information, plus the "function" of the
> >>>>> entity.
> >>>>>
> >>>>> I think "type" isn't a bad name for this field, as what we would
> >>>>> really need is inheritance. It refers to the object type. What would
> >>>>> you think of "class"?
> >>>>
> >>>> I'd prefer type as class has other meanings in the kernel, but I can
> >>>> live with it. Mauro, I agree with Sakari here, what the field contains
> >>>> is really the object type in an object-oriented programming context.
> >>>
> >>> Well, as we could have entities not embedded on some other object, this
> >>> is actually not an object type, even on OO programming. What we're
> >>> actually representing here is a graph object class.
> >>>
> >>> The problem is that "type" is a very generic term, and, as we used it
> >>> before with some other meaning, so I prefer to call it as something
> >>> else.
> >>>
> >>> I'm ok with any other name, although I agree that Kernel uses "class"
> >>> for other things. Maybe gr_class or obj_class?
> >>
> >> I had to think about this a bit, but IMHO it is an entity classification
> >> that a subsystem sets when creating the entity.
> >>
> >> So v4l2 has the classifications V4L2_SUBDEV and V4L2_IO. And while all
> >> entities of the V4L2_SUBDEV classification are indeed embedded in a
> >> struct v4l2_subdev, that is not true for V4L2_IO (radio interface
> >> entities are embedded in struct video_device, but are not of the V4L2_IO
> >> class).
> >>
> >> Other subsystems may need other classifications.
> >>
> >> So what about this:
> >>
> >> enum media_entity_class {
> >>
> >> MEDIA_ENTITY_CLASS_UNDEFINED, // Actually, CLASS_NONE would work here
> >> too
> >> MEDIA_ENTITY_CLASS_V4L2_IO,
> >> MEDIA_ENTITY_CLASS_V4L2_SUBDEV,
> >>
> >> };
> >
> > The purpose of the type is solely to identify the type of the media_entity
> > instance to safely cast it to the proper object type (in an OOP sense).
> > That's what I want the name of the field to describe. It's not about a
> > classification, it's about object instance type identification.
>
> No, it's not. The way it is used is to find entities that are embedded in a
> video_device AND that do I/O.
Used by who ? There are currently 5 drivers using the
is_media_entity_v4l2_io() function (exynos4-is, omap3isp, vsp1, omap4iss,
davinci_vpfe). They all use two entity types only (video_device and
v4l2_subdev), and use is_media_entity_v4l2_io() to check whether the entity is
implemented by a video_device (and in the case of the vsp1 driver to check
whether the entity is not a subdev, I should probably use
!is_media_entity_v4l2_subdev() instead). Those are the current use cases, and
they make sense to me. They might not align with the function name though,
which is why I propose renaming it in the v2 I've sent yesterday.
Furthermore, the type of the entity embedded in struct video_device is
unconditionally set to MEDIA_ENTITY_TYPE_V4L2_VIDEO_DEVICE in the video device
registration function. In practice is_media_entity_v4l2_io() will return true
for all video_device instances, regardless of whether they can do I/O.
I agree that knowing whether a particular video_device instance can perform
I/O could be useful to drivers, but I believe that information shouldn't be
carried by the media_entity type field but discovered through a method
specific to struct video_device instances. We have no driver requiring that
information today, so there's no urgency.
> While all I/O V4L2 entities are a video_device, the reverse is not true.
> Most obviously radio devices, but video devices can also be used for control
> only and not for I/O. For example (a real-life example) a sensor -> FPGA ->
> HDMI TX pipeline where video devices are used to control the sensor and HDMI
> transmitter, but no I/O to/from memory happens since that's all inside the
> FPGA.
>
> So this really is CLASS_V4L2_IO.
>
> And the name is_media_entity_v4l2_io is OK too.
>
> This could be done differently, though, but it requires more work.
>
> I do think it would be useful to know that the entity is embedded in the
> video_device, so I agree with you on that.
>
> But to make is_media_entity_v4l2_io work you would need to know if the
> device could do I/O. One way this can be done is to make the device_caps of
> v4l2_capabilities part of struct video_device.
>
> This would have other beneficial results as well since the core can now know
> the caps of the device and it can take decisions accordingly. I've thought
> about this before but never had enough of a reason to implement it.
Given that caps are static (at least in the use cases I can think of, and we
could allow drivers to override the capabilities operation if really needed)
it would indeed make sense and would allow getting rid of a bunch of trivial
functions. At the expense of 8 more bytes per video_device instance I believe
we could still decrease memory usage.
> So the is_media_entity_v4l2_io() function would check if the entity is of
> type VIDEO_DEVICE, then use container_of to get the caps from video_device
> and check for (CAP_STREAMING | CAP_READWRITE).
>
> In this case I would call it:
>
> enum media_entity_is_of_type {
> MEDIA_ENTITY_TYPE_UNDEFINED,
> MEDIA_ENTITY_TYPE_V4L2_VIDEO_DEVICE,
> MEDIA_ENTITY_TYPE_V4L2_SUBDEV,
> };
>
> And the field name would be:
>
> enum media_entity_is_of_type type;
>
> But this requires more work since all drivers need to be modified, starting
> with those used by those drivers are also use the is_media_entity_*
> functions. I do think it would be beneficial to make the device_caps part
> of video_device regardless.
>
> Regards,
>
> Hans
>
> > From that point of view, the V4L2_IO class/type is wrong. We want to tell
> > that the entity instance is a video_device instance (and given that we
> > use C, this OOP construct is implemented by embedding the struct
> > media_entity in a struct video_device). We really want VIDEO_DEVICE here,
> > there is no struct v4l2_io.>
> >> and the field enum media_entity_class class; in struct media_entity with
> >> documentation:
> >>
> >> @class: Classification of the media_entity, subsystems can set this to
> >> quickly classify what sort of media_entity this is.
--
Regards,
Laurent Pinchart
next prev parent reply other threads:[~2016-02-29 10:43 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-02-22 1:53 [PATCH] media: Add type field to struct media_entity Laurent Pinchart
2016-02-22 9:46 ` Mauro Carvalho Chehab
2016-02-22 21:20 ` Sakari Ailus
2016-02-26 11:18 ` Laurent Pinchart
2016-02-26 13:21 ` Mauro Carvalho Chehab
2016-02-26 14:00 ` Hans Verkuil
2016-02-26 14:12 ` Mauro Carvalho Chehab
2016-02-28 19:09 ` Laurent Pinchart
2016-02-29 8:28 ` Hans Verkuil
2016-02-29 10:43 ` Laurent Pinchart [this message]
2016-02-28 19:03 ` Laurent Pinchart
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=2531247.20gWSsdPQH@avalon \
--to=laurent.pinchart@ideasonboard.com \
--cc=hverkuil@xs4all.nl \
--cc=laurent.pinchart+renesas@ideasonboard.com \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@osg.samsung.com \
--cc=sakari.ailus@iki.fi \
--cc=sakari.ailus@linux.intel.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox