devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
To: Sakari Ailus <sakari.ailus@iki.fi>
Cc: Sakari Ailus <sakari.ailus@linux.intel.com>,
	linux-media@vger.kernel.org, niklas.soderlund@ragnatech.se,
	maxime.ripard@free-electrons.com, robh@kernel.org,
	hverkuil@xs4all.nl, devicetree@vger.kernel.org, pavel@ucw.cz,
	sre@kernel.org
Subject: Re: [PATCH v13 11/25] v4l: async: Introduce helpers for calling async ops callbacks
Date: Tue, 19 Sep 2017 19:27:17 +0300	[thread overview]
Message-ID: <7185208.IfnHDmqMaa@avalon> (raw)
In-Reply-To: <20170919145049.uivohp6qvkf7x4fc@valkosipuli.retiisi.org.uk>

Hi Sakari,

On Tuesday, 19 September 2017 17:50:49 EEST Sakari Ailus wrote:
> On Tue, Sep 19, 2017 at 03:43:48PM +0300, Laurent Pinchart wrote:
> > On Tuesday, 19 September 2017 15:13:11 EEST Sakari Ailus wrote:
> >> On Tue, Sep 19, 2017 at 03:01:14PM +0300, Laurent Pinchart wrote:
> >>> On Friday, 15 September 2017 17:17:10 EEST Sakari Ailus wrote:
> >>>> Add three helper functions to call async operations callbacks.
> >>>> Besides simplifying callbacks, this allows async notifiers to have no
> >>>> ops set, i.e. it can be left NULL.
> >>>> 
> >>>> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
> >>>> Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
> >>>> ---
> >>>> 
> >>>>  drivers/media/v4l2-core/v4l2-async.c | 49 ++++++++++++++++++--------
> >>>>  include/media/v4l2-async.h           |  1 +
> >>>>  2 files changed, 37 insertions(+), 13 deletions(-)
> >>>> 
> >>>> diff --git a/drivers/media/v4l2-core/v4l2-async.c
> >>>> b/drivers/media/v4l2-core/v4l2-async.c index
> >>>> 7b2125b3d62f..c35d04b9122f
> >>>> 100644
> >>>> --- a/drivers/media/v4l2-core/v4l2-async.c
> >>>> +++ b/drivers/media/v4l2-core/v4l2-async.c
> >>>> @@ -25,6 +25,34 @@
> >>>> 
> >>>>  #include <media/v4l2-fwnode.h>
> >>>>  #include <media/v4l2-subdev.h>
> >>>> 
> >>>> +static int v4l2_async_notifier_call_bound(struct v4l2_async_notifier
> >>>> *n,
> >>>> +					  struct v4l2_subdev *subdev,
> >>>> +					  struct v4l2_async_subdev *asd)
> >>>> +{
> >>>> +	if (!n->ops || !n->ops->bound)
> >>>> +		return 0;
> >>>> +
> >>>> +	return n->ops->bound(n, subdev, asd);
> >>>> +}
> >>>> +
> >>>> +static void v4l2_async_notifier_call_unbind(struct
> >>>> v4l2_async_notifier
> >>>> *n,
> >>>> +					    struct v4l2_subdev *subdev,
> >>>> +					    struct v4l2_async_subdev *asd)
> >>>> +{
> >>>> +	if (!n->ops || !n->ops->unbind)
> >>>> +		return;
> >>>> +
> >>>> +	n->ops->unbind(n, subdev, asd);
> >>>> +}
> >>>> +
> >>>> +static int v4l2_async_notifier_call_complete(struct
> >>>> v4l2_async_notifier
> >>>> *n)
> >>>> +{
> >>>> +	if (!n->ops || !n->ops->complete)
> >>>> +		return 0;
> >>>> +
> >>>> +	return n->ops->complete(n);
> >>>> +}
> >>>> +
> >>> 
> >>> Wouldn't it be enough to add a single v4l2_async_notifier_call() macro
> >>> ?
> >>> 
> >>> #define v4l2_async_notifier_call(n, op, args...) \
> >>> 
> >>> 	((n)->ops && (n)->ops->op ? (n)->ops->op(n, ##args) : 0)
> >> 
> >> I actually had that in an earlier version but I changed it based on
> >> review comments from Hans. A single macro isn't enough: some functions
> >> have int return type. I think the way it is now is nicer.
> > 
> > What bothers me there is the overhead of a function call.
> 
> Overhead... of a function call?
> 
> Do you really mean what you're saying? :-) The functions will be called a
> relatively small number of times during module loading / device probing.

That's why I haven't said it's a big deal :-) There's of course no need to 
optimize that if the tradeoff is large, but if all operations had the same 
return type a macro could have been useful (although in this very specific 
case I'm more concerned about code size than about CPU cycles).

> > By the way, what's the use case for ops being NULL ?
> 
> If a driver has no need for any of the callbacks, there's no benefit from
> having to set ops struct either. This applies to devices that are
> associated to the sensor, for instance.

So in that case the subdev notifier is only registered to delay the complete() 
callback until the flash and lens controllers are available, with the sensor 
itself having no need to access the flash and lens controllers ?

-- 
Regards,

Laurent Pinchart

  reply	other threads:[~2017-09-19 16:27 UTC|newest]

Thread overview: 91+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-09-15 14:16 [PATCH v13 00/25] Unified fwnode endpoint parser, async sub-device notifier support, N9 flash DTS Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 02/25] v4l: async: Remove re-probing support Sakari Ailus
     [not found]   ` <20170915141724.23124-3-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19  9:21     ` Laurent Pinchart
2017-09-15 14:17 ` [PATCH v13 04/25] v4l: async: Add V4L2 async documentation to the documentation build Sakari Ailus
     [not found] ` <20170915141724.23124-1-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-15 14:17   ` [PATCH v13 01/25] v4l: fwnode: Move KernelDoc documentation to the header Sakari Ailus
     [not found]     ` <20170915141724.23124-2-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19 10:48       ` Laurent Pinchart
2017-09-19 11:04         ` Hans Verkuil
     [not found]           ` <29354478-ec46-278b-c457-4e6f3cc6848c-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
2017-09-19 11:07             ` Laurent Pinchart
2017-09-19 11:22             ` Sakari Ailus
2017-09-19 11:10         ` Sakari Ailus
     [not found]           ` <20170919111036.5va2unwqh2vymojr-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2017-09-19 11:14             ` Laurent Pinchart
2017-09-19 11:25               ` Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 03/25] v4l: async: Use more intuitive names for internal functions Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 05/25] v4l: fwnode: Support generic parsing of graph endpoints in a device Sakari Ailus
2017-09-19  8:03     ` Hans Verkuil
2017-09-19  8:20       ` Sakari Ailus
     [not found]         ` <20170919082015.vt6olgirnvmpcrpa-z7MJbOB4PBP+e+fPlCVrcFDQ4js95KgL@public.gmane.org>
2017-09-19  8:40           ` Hans Verkuil
     [not found]             ` <af99e12c-6fb8-a633-eec2-c1eb9d82226a-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
2017-09-19  9:30               ` Laurent Pinchart
2017-09-19 11:37                 ` Sakari Ailus
2017-09-19 10:00               ` Sakari Ailus
2017-09-19 10:10                 ` Hans Verkuil
2017-09-19 11:35     ` Laurent Pinchart
2017-09-19 12:11       ` Sakari Ailus
     [not found]         ` <20170919121131.6m4cf4ftzhq7vpnc-z7MJbOB4PBP+e+fPlCVrcFDQ4js95KgL@public.gmane.org>
2017-09-19 12:34           ` Laurent Pinchart
2017-09-26 20:56             ` Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 07/25] rcar-vin: Use generic parser for parsing fwnode endpoints Sakari Ailus
     [not found]     ` <20170915141724.23124-8-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19 11:53       ` Laurent Pinchart
2017-09-19 12:39         ` Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 09/25] omap3isp: Print the name of the entity where no source pads could be found Sakari Ailus
2017-09-19 11:56     ` Laurent Pinchart
2017-09-15 14:17   ` [PATCH v13 11/25] v4l: async: Introduce helpers for calling async ops callbacks Sakari Ailus
     [not found]     ` <20170915141724.23124-12-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-16  7:13       ` Pavel Machek
2017-09-19 12:01       ` Laurent Pinchart
2017-09-19 12:13         ` Sakari Ailus
2017-09-19 12:43           ` Laurent Pinchart
2017-09-19 14:50             ` Sakari Ailus
2017-09-19 16:27               ` Laurent Pinchart [this message]
2017-09-20 15:54                 ` Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 14/25] v4l: async: Allow binding notifiers to sub-devices Sakari Ailus
     [not found]     ` <20170915141724.23124-15-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19  8:06       ` Hans Verkuil
2017-09-19 13:52       ` Laurent Pinchart
2017-09-19 15:17         ` Sakari Ailus
     [not found]           ` <20170919151732.4yafxfcxrreizd7r-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2017-09-19 17:52             ` Laurent Pinchart
2017-09-20  9:42               ` Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 19/25] v4l: fwnode: Add convenience function for parsing common external refs Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 21/25] smiapp: Add support for flash and lens devices Sakari Ailus
     [not found]     ` <20170915141724.23124-22-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19 12:08       ` Laurent Pinchart
2017-09-19 12:20         ` Sakari Ailus
2017-09-19 12:38           ` Laurent Pinchart
2017-09-15 14:17   ` [PATCH v13 23/25] ov5670: " Sakari Ailus
2017-09-15 14:17   ` [PATCH v13 24/25] ov13858: " Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 06/25] omap3isp: Use generic parser for parsing fwnode endpoints Sakari Ailus
2017-09-16  7:04   ` Pavel Machek
2017-09-16  7:18     ` Pavel Machek
2017-09-19 11:40   ` Laurent Pinchart
2017-09-19 12:41     ` Sakari Ailus
2017-09-19 12:43     ` Sakari Ailus
2017-09-19 12:46       ` Laurent Pinchart
2017-09-19 14:47         ` Sakari Ailus
2017-09-19 16:12           ` Laurent Pinchart
2017-09-21  8:46             ` Sakari Ailus
2017-09-20 15:50         ` Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 08/25] omap3isp: Fix check for our own sub-devices Sakari Ailus
     [not found]   ` <20170915141724.23124-9-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19 11:55     ` Laurent Pinchart
2017-09-15 14:17 ` [PATCH v13 10/25] v4l: async: Move async subdev notifier operations to a separate structure Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 12/25] v4l: async: Register sub-devices before calling bound callback Sakari Ailus
2017-09-19 12:01   ` Laurent Pinchart
2017-09-15 14:17 ` [PATCH v13 13/25] v4l: async: Allow async notifier register call succeed with no subdevs Sakari Ailus
2017-09-19 12:04   ` Laurent Pinchart
2017-09-19 12:52     ` Laurent Pinchart
2017-09-19 14:58       ` Sakari Ailus
     [not found]         ` <20170919145831.uztphjdtd3fdxzvr-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2017-09-19 15:03           ` Sakari Ailus
2017-09-19 17:54             ` Laurent Pinchart
2017-09-20 10:51               ` Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 15/25] dt: bindings: Add a binding for flash LED devices associated to a sensor Sakari Ailus
     [not found]   ` <20170915141724.23124-16-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19 12:12     ` Laurent Pinchart
2017-09-19 12:16       ` Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 16/25] dt: bindings: Add lens-focus binding for image sensors Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 17/25] v4l: fwnode: Add a helper function for parsing generic references Sakari Ailus
     [not found]   ` <20170915141724.23124-18-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-19  8:14     ` Hans Verkuil
2017-09-19 12:19     ` Laurent Pinchart
2017-09-19 13:04       ` Sakari Ailus
     [not found]         ` <20170919130453.ii5kz54qxlot4of2-z7MJbOB4PBP+e+fPlCVrcFDQ4js95KgL@public.gmane.org>
2017-09-19 14:01           ` Laurent Pinchart
2017-09-15 14:17 ` [PATCH v13 18/25] v4l: fwnode: Add a helper function to obtain device / integer references Sakari Ailus
2017-09-19  8:31   ` Hans Verkuil
2017-09-19  8:45     ` Sakari Ailus
2017-09-19  9:21       ` Hans Verkuil
     [not found]         ` <09f8ce37-c6e0-e448-c773-e1f3510d1024-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
2017-09-19 10:16           ` Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 20/25] dt: bindings: smiapp: Document lens-focus and flash-leds properties Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 22/25] et8ek8: Add support for flash and lens devices Sakari Ailus
2017-09-15 14:17 ` [PATCH v13 25/25] arm: dts: omap3: N9/N950: Add flash references to the camera Sakari Ailus

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=7185208.IfnHDmqMaa@avalon \
    --to=laurent.pinchart@ideasonboard.com \
    --cc=devicetree@vger.kernel.org \
    --cc=hverkuil@xs4all.nl \
    --cc=linux-media@vger.kernel.org \
    --cc=maxime.ripard@free-electrons.com \
    --cc=niklas.soderlund@ragnatech.se \
    --cc=pavel@ucw.cz \
    --cc=robh@kernel.org \
    --cc=sakari.ailus@iki.fi \
    --cc=sakari.ailus@linux.intel.com \
    --cc=sre@kernel.org \
    /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;
as well as URLs for NNTP newsgroup(s).