All of lore.kernel.org
 help / color / mirror / Atom feed
From: Hans Verkuil <hverkuil-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
To: Sakari Ailus <sakari.ailus-X3B1VOXEql0@public.gmane.org>
Cc: Sakari Ailus
	<sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>,
	linux-media-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	niklas.soderlund-1zkq55x86MTxsAP9Fp7wbw@public.gmane.org,
	robh-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org,
	laurent.pinchart-ryLnwIuWjnjg/C1BVhZhaw@public.gmane.org,
	devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	pavel-+ZI9xUNit7I@public.gmane.org,
	sre-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org
Subject: Re: [PATCH v8 06/21] v4l: fwnode: Support generic parsing of graph endpoints in a device
Date: Thu, 7 Sep 2017 14:03:57 +0200	[thread overview]
Message-ID: <8123f8c5-9045-2a22-c97f-09d36e504e2e@xs4all.nl> (raw)
In-Reply-To: <20170907095850.m7mlag3tofwbj2jc-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>

On 09/07/17 11:58, Sakari Ailus wrote:
> Hi Hans,
> 
> On Thu, Sep 07, 2017 at 10:51:21AM +0200, Hans Verkuil wrote:
>> On 09/07/17 09:34, Sakari Ailus wrote:
>>> Hi Hans,
>>>
>>> On Wed, Sep 06, 2017 at 09:41:40AM +0200, Hans Verkuil wrote:
>>>> On 09/05/2017 03:05 PM, Sakari Ailus wrote:
>>>>> The current practice is that drivers iterate over their endpoints and
>>>>> parse each endpoint separately. This is very similar in a number of
>>>>> drivers, implement a generic function for the job. Driver specific matters
>>>>> can be taken into account in the driver specific callback.
>>>>>
>>>>> Signed-off-by: Sakari Ailus <sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
>>>>> ---
>>>>>  drivers/media/v4l2-core/v4l2-async.c  |  19 +++++
>>>>>  drivers/media/v4l2-core/v4l2-fwnode.c | 140 ++++++++++++++++++++++++++++++++++
>>>>>  include/media/v4l2-async.h            |  24 +++++-
>>>>>  include/media/v4l2-fwnode.h           |  53 +++++++++++++
>>>>>  4 files changed, 234 insertions(+), 2 deletions(-)
>>>>>
>>>>> diff --git a/drivers/media/v4l2-core/v4l2-async.c b/drivers/media/v4l2-core/v4l2-async.c
>>>>> index 3d81ff6a496f..7bd595c4094a 100644
>>>>> --- a/drivers/media/v4l2-core/v4l2-async.c
>>>>> +++ b/drivers/media/v4l2-core/v4l2-async.c
>>>>> @@ -22,6 +22,7 @@
>>>>>  
>>>>>  #include <media/v4l2-async.h>
>>>>>  #include <media/v4l2-device.h>
>>>>> +#include <media/v4l2-fwnode.h>
>>>>>  #include <media/v4l2-subdev.h>
>>>>>  
>>>>>  static bool match_i2c(struct v4l2_subdev *sd, struct v4l2_async_subdev *asd)
>>>>> @@ -224,6 +225,24 @@ void v4l2_async_notifier_unregister(struct v4l2_async_notifier *notifier)
>>>>>  }
>>>>>  EXPORT_SYMBOL(v4l2_async_notifier_unregister);
>>>>>  
>>>>> +void v4l2_async_notifier_release(struct v4l2_async_notifier *notifier)
>>>>> +{
>>>>> +	unsigned int i;
>>>>> +
>>>>> +	if (!notifier->max_subdevs)
>>>>> +		return;
>>>>> +
>>>>> +	for (i = 0; i < notifier->num_subdevs; i++)
>>>>> +		kfree(notifier->subdevs[i]);
>>>>> +
>>>>> +	notifier->max_subdevs = 0;
>>>>> +	notifier->num_subdevs = 0;
>>>>> +
>>>>> +	kvfree(notifier->subdevs);
>>>>> +	notifier->subdevs = NULL;
>>>>> +}
>>>>> +EXPORT_SYMBOL_GPL(v4l2_async_notifier_release);
>>>>> +
>>>>>  int v4l2_async_register_subdev(struct v4l2_subdev *sd)
>>>>>  {
>>>>>  	struct v4l2_async_notifier *notifier;
>>>>> diff --git a/drivers/media/v4l2-core/v4l2-fwnode.c b/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> index 706f9e7b90f1..e6932d7d47b6 100644
>>>>> --- a/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> +++ b/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> @@ -19,6 +19,7 @@
>>>>>   */
>>>>>  #include <linux/acpi.h>
>>>>>  #include <linux/kernel.h>
>>>>> +#include <linux/mm.h>
>>>>>  #include <linux/module.h>
>>>>>  #include <linux/of.h>
>>>>>  #include <linux/property.h>
>>>>> @@ -26,6 +27,7 @@
>>>>>  #include <linux/string.h>
>>>>>  #include <linux/types.h>
>>>>>  
>>>>> +#include <media/v4l2-async.h>
>>>>>  #include <media/v4l2-fwnode.h>
>>>>>  
>>>>>  enum v4l2_fwnode_bus_type {
>>>>> @@ -313,6 +315,144 @@ void v4l2_fwnode_put_link(struct v4l2_fwnode_link *link)
>>>>>  }
>>>>>  EXPORT_SYMBOL_GPL(v4l2_fwnode_put_link);
>>>>>  
>>>>> +static int v4l2_async_notifier_realloc(struct v4l2_async_notifier *notifier,
>>>>> +				       unsigned int max_subdevs)
>>>>> +{
>>>>> +	struct v4l2_async_subdev **subdevs;
>>>>> +
>>>>> +	if (max_subdevs <= notifier->max_subdevs)
>>>>> +		return 0;
>>>>> +
>>>>> +	subdevs = kvmalloc_array(
>>>>> +		max_subdevs, sizeof(*notifier->subdevs),
>>>>> +		GFP_KERNEL | __GFP_ZERO);
>>>>> +	if (!subdevs)
>>>>> +		return -ENOMEM;
>>>>> +
>>>>> +	if (notifier->subdevs) {
>>>>> +		memcpy(subdevs, notifier->subdevs,
>>>>> +		       sizeof(*subdevs) * notifier->num_subdevs);
>>>>> +
>>>>> +		kvfree(notifier->subdevs);
>>>>> +	}
>>>>> +
>>>>> +	notifier->subdevs = subdevs;
>>>>> +	notifier->max_subdevs = max_subdevs;
>>>>> +
>>>>> +	return 0;
>>>>> +}
>>>>> +
>>>>> +static int v4l2_async_notifier_fwnode_parse_endpoint(
>>>>> +	struct device *dev, struct v4l2_async_notifier *notifier,
>>>>> +	struct fwnode_handle *endpoint, unsigned int asd_struct_size,
>>>>> +	int (*parse_endpoint)(struct device *dev,
>>>>> +			    struct v4l2_fwnode_endpoint *vep,
>>>>> +			    struct v4l2_async_subdev *asd))
>>>>> +{
>>>>> +	struct v4l2_async_subdev *asd;
>>>>> +	struct v4l2_fwnode_endpoint *vep;
>>>>> +	struct fwnode_endpoint ep;
>>>>> +	int ret = 0;
>>>>> +
>>>>> +	asd = kzalloc(asd_struct_size, GFP_KERNEL);
>>>>> +	if (!asd)
>>>>> +		return -ENOMEM;
>>>>> +
>>>>> +	asd->match.fwnode.fwnode =
>>>>> +		fwnode_graph_get_remote_port_parent(endpoint);
>>>>> +	if (!asd->match.fwnode.fwnode) {
>>>>> +		dev_warn(dev, "bad remote port parent\n");
>>>>> +		ret = -EINVAL;
>>>>> +		goto out_err;
>>>>> +	}
>>>>> +
>>>>> +	/* Ignore endpoints the parsing of which failed. */
>>>>> +	vep = v4l2_fwnode_endpoint_alloc_parse(endpoint);
>>>>> +	if (IS_ERR(vep)) {
>>>>> +		ret = PTR_ERR(vep);
>>>>> +		dev_warn(dev, "unable to parse V4L2 fwnode endpoint (%d)\n",
>>>>> +			 ret);
>>>>> +		goto out_err;
>>>>> +	}
>>>>> +
>>>>> +	ep = vep->base;
>>>>> +
>>>>> +	ret = parse_endpoint ? parse_endpoint(dev, vep, asd) : 0;
>>>>> +	v4l2_fwnode_endpoint_free(vep);
>>>>> +	if (ret == -ENOTCONN) {
>>>>> +		dev_dbg(dev, "ignoring endpoint %u,%u\n", ep.port, ep.id);
>>>>> +		kfree(asd);
>>>>
>>>> Shouldn't there be a call to fwnode_handle_put()?
>>>
>>> Actually no. But your hunch is right in the sense that I think there are
>>> issues. The fwnode_endpoint (as of_endpoint) contains the fwnode which is
>>> referenced, but no reference is taken here. One couldn't be released either
>>> later on, as the fwnode field is const.
>>>
>>> I guess this is almost fine as long as the fwnode field is used for pointer
>>> comparison and nothing else but you can never be sure what drivers actually
>>> do.
>>>
>>> This actually should be addressed for both OF and fwnode but it's mostly
>>> independent of this patchset. Luckily there are not *that* many users of
>>> this. The V4L2 fwnode interface that allocates and releases endpoints makes
>>> this quite a bit easier actually.
>>
>> I think a comment or two here would be helpful. If I tripped over this, so
>> will others.
> 
> Reading the code again, I noticed I didn't read far enough the last time.
> While v4l2_fwnode_endpoint_alloc_parse() won't take a reference,
> fwnode_graph_get_remote_port_parent() does. That reference indeed isn't
> released right now.
> 
> It shouldn't be too hard to do that properly in
> v4l2_async_notifier_release(). I guess I'll do just that actually. By that
> time, there are no users left anymore.
> 
> Good catch.
> 
>>
>>>
>>>>
>>>>> +		return 0;
>>>>> +	} else if (ret < 0) {
>>>>> +		dev_warn(dev, "driver could not parse endpoint %u,%u (%d)\n",
>>>>> +			 ep.port, ep.id, ret);
>>>>> +		goto out_err;
>>>>> +	}
>>>>
>>>> I think this would be better and it avoids the need for the ep local variable:
>>>>
>>>> 	ret = parse_endpoint ? parse_endpoint(dev, vep, asd) : 0;
>>>> 	if (ret == -ENOTCONN)
>>>> 		dev_dbg(dev, "ignoring endpoint %u,%u\n", vep->base.port, vep->base.id);
>>>> 	else if (ret < 0)
>>>> 		dev_warn(dev, "driver could not parse endpoint %u,%u (%d)\n",
>>>> 			 vep->base.port, vep->base.id, ret);
>>>> 	v4l2_fwnode_endpoint_free(vep);
>>>> 	if (ret < 0)
>>>> 		goto out_err;
>>>>
>>>> And the 'return ret;' below would become:
>>>>
>>>> 	return ret == -ENOTCONN ? 0 : ret;
>>>
>>> Looks good to me, I'll use it.
>>>
>>>>
>>>>> +
>>>>> +	asd->match_type = V4L2_ASYNC_MATCH_FWNODE;
>>>>> +	notifier->subdevs[notifier->num_subdevs] = asd;
>>>>> +	notifier->num_subdevs++;
>>>>> +
>>>>> +	return 0;
>>>>> +
>>>>> +out_err:
>>>>> +	fwnode_handle_put(asd->match.fwnode.fwnode);
>>
>> Just a reminder: this put() should now check if ret != -ENOTCONN.
> 
> Should it? Even if ret == -ENOTCONN, the reference is there and needs to be
> released as the endpoint is not used (just as in the case of an error).

Well, in the previous reply you mentioned that the put wasn't necessary, hence
my comment. Since it is now needed again you can ignore this.

Regards,

	Hans

> 
>>
>>>>> +	kfree(asd);
>>>>> +
>>>>> +	return ret;
>>>>> +}
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

WARNING: multiple messages have this Message-ID (diff)
From: Hans Verkuil <hverkuil@xs4all.nl>
To: Sakari Ailus <sakari.ailus@iki.fi>
Cc: Sakari Ailus <sakari.ailus@linux.intel.com>,
	linux-media@vger.kernel.org, niklas.soderlund@ragnatech.se,
	robh@kernel.org, laurent.pinchart@ideasonboard.com,
	devicetree@vger.kernel.org, pavel@ucw.cz, sre@kernel.org
Subject: Re: [PATCH v8 06/21] v4l: fwnode: Support generic parsing of graph endpoints in a device
Date: Thu, 7 Sep 2017 14:03:57 +0200	[thread overview]
Message-ID: <8123f8c5-9045-2a22-c97f-09d36e504e2e@xs4all.nl> (raw)
In-Reply-To: <20170907095850.m7mlag3tofwbj2jc@valkosipuli.retiisi.org.uk>

On 09/07/17 11:58, Sakari Ailus wrote:
> Hi Hans,
> 
> On Thu, Sep 07, 2017 at 10:51:21AM +0200, Hans Verkuil wrote:
>> On 09/07/17 09:34, Sakari Ailus wrote:
>>> Hi Hans,
>>>
>>> On Wed, Sep 06, 2017 at 09:41:40AM +0200, Hans Verkuil wrote:
>>>> On 09/05/2017 03:05 PM, Sakari Ailus wrote:
>>>>> The current practice is that drivers iterate over their endpoints and
>>>>> parse each endpoint separately. This is very similar in a number of
>>>>> drivers, implement a generic function for the job. Driver specific matters
>>>>> can be taken into account in the driver specific callback.
>>>>>
>>>>> Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
>>>>> ---
>>>>>  drivers/media/v4l2-core/v4l2-async.c  |  19 +++++
>>>>>  drivers/media/v4l2-core/v4l2-fwnode.c | 140 ++++++++++++++++++++++++++++++++++
>>>>>  include/media/v4l2-async.h            |  24 +++++-
>>>>>  include/media/v4l2-fwnode.h           |  53 +++++++++++++
>>>>>  4 files changed, 234 insertions(+), 2 deletions(-)
>>>>>
>>>>> diff --git a/drivers/media/v4l2-core/v4l2-async.c b/drivers/media/v4l2-core/v4l2-async.c
>>>>> index 3d81ff6a496f..7bd595c4094a 100644
>>>>> --- a/drivers/media/v4l2-core/v4l2-async.c
>>>>> +++ b/drivers/media/v4l2-core/v4l2-async.c
>>>>> @@ -22,6 +22,7 @@
>>>>>  
>>>>>  #include <media/v4l2-async.h>
>>>>>  #include <media/v4l2-device.h>
>>>>> +#include <media/v4l2-fwnode.h>
>>>>>  #include <media/v4l2-subdev.h>
>>>>>  
>>>>>  static bool match_i2c(struct v4l2_subdev *sd, struct v4l2_async_subdev *asd)
>>>>> @@ -224,6 +225,24 @@ void v4l2_async_notifier_unregister(struct v4l2_async_notifier *notifier)
>>>>>  }
>>>>>  EXPORT_SYMBOL(v4l2_async_notifier_unregister);
>>>>>  
>>>>> +void v4l2_async_notifier_release(struct v4l2_async_notifier *notifier)
>>>>> +{
>>>>> +	unsigned int i;
>>>>> +
>>>>> +	if (!notifier->max_subdevs)
>>>>> +		return;
>>>>> +
>>>>> +	for (i = 0; i < notifier->num_subdevs; i++)
>>>>> +		kfree(notifier->subdevs[i]);
>>>>> +
>>>>> +	notifier->max_subdevs = 0;
>>>>> +	notifier->num_subdevs = 0;
>>>>> +
>>>>> +	kvfree(notifier->subdevs);
>>>>> +	notifier->subdevs = NULL;
>>>>> +}
>>>>> +EXPORT_SYMBOL_GPL(v4l2_async_notifier_release);
>>>>> +
>>>>>  int v4l2_async_register_subdev(struct v4l2_subdev *sd)
>>>>>  {
>>>>>  	struct v4l2_async_notifier *notifier;
>>>>> diff --git a/drivers/media/v4l2-core/v4l2-fwnode.c b/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> index 706f9e7b90f1..e6932d7d47b6 100644
>>>>> --- a/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> +++ b/drivers/media/v4l2-core/v4l2-fwnode.c
>>>>> @@ -19,6 +19,7 @@
>>>>>   */
>>>>>  #include <linux/acpi.h>
>>>>>  #include <linux/kernel.h>
>>>>> +#include <linux/mm.h>
>>>>>  #include <linux/module.h>
>>>>>  #include <linux/of.h>
>>>>>  #include <linux/property.h>
>>>>> @@ -26,6 +27,7 @@
>>>>>  #include <linux/string.h>
>>>>>  #include <linux/types.h>
>>>>>  
>>>>> +#include <media/v4l2-async.h>
>>>>>  #include <media/v4l2-fwnode.h>
>>>>>  
>>>>>  enum v4l2_fwnode_bus_type {
>>>>> @@ -313,6 +315,144 @@ void v4l2_fwnode_put_link(struct v4l2_fwnode_link *link)
>>>>>  }
>>>>>  EXPORT_SYMBOL_GPL(v4l2_fwnode_put_link);
>>>>>  
>>>>> +static int v4l2_async_notifier_realloc(struct v4l2_async_notifier *notifier,
>>>>> +				       unsigned int max_subdevs)
>>>>> +{
>>>>> +	struct v4l2_async_subdev **subdevs;
>>>>> +
>>>>> +	if (max_subdevs <= notifier->max_subdevs)
>>>>> +		return 0;
>>>>> +
>>>>> +	subdevs = kvmalloc_array(
>>>>> +		max_subdevs, sizeof(*notifier->subdevs),
>>>>> +		GFP_KERNEL | __GFP_ZERO);
>>>>> +	if (!subdevs)
>>>>> +		return -ENOMEM;
>>>>> +
>>>>> +	if (notifier->subdevs) {
>>>>> +		memcpy(subdevs, notifier->subdevs,
>>>>> +		       sizeof(*subdevs) * notifier->num_subdevs);
>>>>> +
>>>>> +		kvfree(notifier->subdevs);
>>>>> +	}
>>>>> +
>>>>> +	notifier->subdevs = subdevs;
>>>>> +	notifier->max_subdevs = max_subdevs;
>>>>> +
>>>>> +	return 0;
>>>>> +}
>>>>> +
>>>>> +static int v4l2_async_notifier_fwnode_parse_endpoint(
>>>>> +	struct device *dev, struct v4l2_async_notifier *notifier,
>>>>> +	struct fwnode_handle *endpoint, unsigned int asd_struct_size,
>>>>> +	int (*parse_endpoint)(struct device *dev,
>>>>> +			    struct v4l2_fwnode_endpoint *vep,
>>>>> +			    struct v4l2_async_subdev *asd))
>>>>> +{
>>>>> +	struct v4l2_async_subdev *asd;
>>>>> +	struct v4l2_fwnode_endpoint *vep;
>>>>> +	struct fwnode_endpoint ep;
>>>>> +	int ret = 0;
>>>>> +
>>>>> +	asd = kzalloc(asd_struct_size, GFP_KERNEL);
>>>>> +	if (!asd)
>>>>> +		return -ENOMEM;
>>>>> +
>>>>> +	asd->match.fwnode.fwnode =
>>>>> +		fwnode_graph_get_remote_port_parent(endpoint);
>>>>> +	if (!asd->match.fwnode.fwnode) {
>>>>> +		dev_warn(dev, "bad remote port parent\n");
>>>>> +		ret = -EINVAL;
>>>>> +		goto out_err;
>>>>> +	}
>>>>> +
>>>>> +	/* Ignore endpoints the parsing of which failed. */
>>>>> +	vep = v4l2_fwnode_endpoint_alloc_parse(endpoint);
>>>>> +	if (IS_ERR(vep)) {
>>>>> +		ret = PTR_ERR(vep);
>>>>> +		dev_warn(dev, "unable to parse V4L2 fwnode endpoint (%d)\n",
>>>>> +			 ret);
>>>>> +		goto out_err;
>>>>> +	}
>>>>> +
>>>>> +	ep = vep->base;
>>>>> +
>>>>> +	ret = parse_endpoint ? parse_endpoint(dev, vep, asd) : 0;
>>>>> +	v4l2_fwnode_endpoint_free(vep);
>>>>> +	if (ret == -ENOTCONN) {
>>>>> +		dev_dbg(dev, "ignoring endpoint %u,%u\n", ep.port, ep.id);
>>>>> +		kfree(asd);
>>>>
>>>> Shouldn't there be a call to fwnode_handle_put()?
>>>
>>> Actually no. But your hunch is right in the sense that I think there are
>>> issues. The fwnode_endpoint (as of_endpoint) contains the fwnode which is
>>> referenced, but no reference is taken here. One couldn't be released either
>>> later on, as the fwnode field is const.
>>>
>>> I guess this is almost fine as long as the fwnode field is used for pointer
>>> comparison and nothing else but you can never be sure what drivers actually
>>> do.
>>>
>>> This actually should be addressed for both OF and fwnode but it's mostly
>>> independent of this patchset. Luckily there are not *that* many users of
>>> this. The V4L2 fwnode interface that allocates and releases endpoints makes
>>> this quite a bit easier actually.
>>
>> I think a comment or two here would be helpful. If I tripped over this, so
>> will others.
> 
> Reading the code again, I noticed I didn't read far enough the last time.
> While v4l2_fwnode_endpoint_alloc_parse() won't take a reference,
> fwnode_graph_get_remote_port_parent() does. That reference indeed isn't
> released right now.
> 
> It shouldn't be too hard to do that properly in
> v4l2_async_notifier_release(). I guess I'll do just that actually. By that
> time, there are no users left anymore.
> 
> Good catch.
> 
>>
>>>
>>>>
>>>>> +		return 0;
>>>>> +	} else if (ret < 0) {
>>>>> +		dev_warn(dev, "driver could not parse endpoint %u,%u (%d)\n",
>>>>> +			 ep.port, ep.id, ret);
>>>>> +		goto out_err;
>>>>> +	}
>>>>
>>>> I think this would be better and it avoids the need for the ep local variable:
>>>>
>>>> 	ret = parse_endpoint ? parse_endpoint(dev, vep, asd) : 0;
>>>> 	if (ret == -ENOTCONN)
>>>> 		dev_dbg(dev, "ignoring endpoint %u,%u\n", vep->base.port, vep->base.id);
>>>> 	else if (ret < 0)
>>>> 		dev_warn(dev, "driver could not parse endpoint %u,%u (%d)\n",
>>>> 			 vep->base.port, vep->base.id, ret);
>>>> 	v4l2_fwnode_endpoint_free(vep);
>>>> 	if (ret < 0)
>>>> 		goto out_err;
>>>>
>>>> And the 'return ret;' below would become:
>>>>
>>>> 	return ret == -ENOTCONN ? 0 : ret;
>>>
>>> Looks good to me, I'll use it.
>>>
>>>>
>>>>> +
>>>>> +	asd->match_type = V4L2_ASYNC_MATCH_FWNODE;
>>>>> +	notifier->subdevs[notifier->num_subdevs] = asd;
>>>>> +	notifier->num_subdevs++;
>>>>> +
>>>>> +	return 0;
>>>>> +
>>>>> +out_err:
>>>>> +	fwnode_handle_put(asd->match.fwnode.fwnode);
>>
>> Just a reminder: this put() should now check if ret != -ENOTCONN.
> 
> Should it? Even if ret == -ENOTCONN, the reference is there and needs to be
> released as the endpoint is not used (just as in the case of an error).

Well, in the previous reply you mentioned that the put wasn't necessary, hence
my comment. Since it is now needed again you can ignore this.

Regards,

	Hans

> 
>>
>>>>> +	kfree(asd);
>>>>> +
>>>>> +	return ret;
>>>>> +}

  parent reply	other threads:[~2017-09-07 12:03 UTC|newest]

Thread overview: 69+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-09-05 13:05 [PATCH v8 00/21] Unified fwnode endpoint parser, async sub-device notifier support, N9 flash DTS Sakari Ailus
2017-09-05 13:05 ` [PATCH v8 02/21] v4l: async: Remove re-probing support Sakari Ailus
2017-09-06  7:00   ` Hans Verkuil
2017-09-05 13:05 ` [PATCH v8 03/21] v4l: async: Use more intuitive names for internal functions Sakari Ailus
2017-09-06  7:01   ` Hans Verkuil
2017-09-08 12:40   ` Pavel Machek
2017-09-05 13:05 ` [PATCH v8 05/21] docs-rst: v4l: Include Qualcomm CAMSS in documentation build Sakari Ailus
2017-09-05 13:05 ` [PATCH v8 06/21] v4l: fwnode: Support generic parsing of graph endpoints in a device Sakari Ailus
     [not found]   ` <20170905130553.1332-7-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:41     ` Hans Verkuil
2017-09-06  7:41       ` Hans Verkuil
     [not found]       ` <dd3a2e55-8de0-c30e-04a7-cb26b519689c-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
2017-09-07  7:34         ` Sakari Ailus
2017-09-07  7:34           ` Sakari Ailus
2017-09-07  8:51           ` Hans Verkuil
2017-09-07  9:58             ` Sakari Ailus
     [not found]               ` <20170907095850.m7mlag3tofwbj2jc-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2017-09-07 12:03                 ` Hans Verkuil [this message]
2017-09-07 12:03                   ` Hans Verkuil
2017-09-05 13:05 ` [PATCH v8 09/21] omap3isp: Fix check for our own sub-devices Sakari Ailus
     [not found]   ` <20170905130553.1332-10-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:45     ` Hans Verkuil
2017-09-06  7:45       ` Hans Verkuil
2017-09-05 13:05 ` [PATCH v8 12/21] v4l: async: Introduce helpers for calling async ops callbacks Sakari Ailus
     [not found]   ` <20170905130553.1332-13-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:50     ` Hans Verkuil
2017-09-06  7:50       ` Hans Verkuil
2017-09-07  7:51       ` Sakari Ailus
2017-09-05 13:05 ` [PATCH v8 16/21] dt: bindings: Add lens-focus binding for image sensors Sakari Ailus
     [not found]   ` <20170905130553.1332-17-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  8:48     ` Hans Verkuil
2017-09-06  8:48       ` Hans Verkuil
     [not found] ` <20170905130553.1332-1-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-05 13:05   ` [PATCH v8 01/21] v4l: fwnode: Move KernelDoc documentation to the header Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
     [not found]     ` <20170905130553.1332-2-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-08 12:39       ` Pavel Machek
2017-09-08 12:39         ` Pavel Machek
2017-09-05 13:05   ` [PATCH v8 04/21] v4l: async: Add V4L2 async documentation to the documentation build Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-05 13:05   ` [PATCH v8 07/21] omap3isp: Use generic parser for parsing fwnode endpoints Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
     [not found]     ` <20170905130553.1332-8-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:42       ` Hans Verkuil
2017-09-06  7:42         ` Hans Verkuil
2017-09-05 13:05   ` [PATCH v8 08/21] rcar-vin: " Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
     [not found]     ` <20170905130553.1332-9-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:44       ` Hans Verkuil
2017-09-06  7:44         ` Hans Verkuil
     [not found]         ` <a51aea1f-0a00-7a7b-8197-e0f5a0443a05-qWit8jRvyhVmR6Xm/wNWPw@public.gmane.org>
2017-09-07  8:09           ` Sakari Ailus
2017-09-07  8:09             ` Sakari Ailus
2017-09-05 13:05   ` [PATCH v8 10/21] omap3isp: Print the name of the entity where no source pads could be found Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-06  7:45     ` Hans Verkuil
2017-09-05 13:05   ` [PATCH v8 11/21] v4l: async: Move async subdev notifier operations to a separate structure Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-05 13:05   ` [PATCH v8 13/21] v4l: async: Register sub-devices before calling bound callback Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
     [not found]     ` <20170905130553.1332-14-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  7:51       ` Hans Verkuil
2017-09-06  7:51         ` Hans Verkuil
2017-09-05 13:05   ` [PATCH v8 14/21] v4l: async: Allow binding notifiers to sub-devices Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
     [not found]     ` <20170905130553.1332-15-sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org>
2017-09-06  8:46       ` Hans Verkuil
2017-09-06  8:46         ` Hans Verkuil
2017-09-07  8:32         ` Sakari Ailus
     [not found]           ` <20170907083209.3xtaxwhrfmgrtpfz-S+BSfZ9RZZmRSg0ZkenSGLdO1Tsj/99ntUK59QYPAWc@public.gmane.org>
2017-09-07 12:02             ` Hans Verkuil
2017-09-07 12:02               ` Hans Verkuil
2017-09-05 13:05   ` [PATCH v8 15/21] dt: bindings: Add a binding for flash devices associated to a sensor Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-06  8:47     ` Hans Verkuil
2017-09-05 13:05   ` [PATCH v8 17/21] v4l: fwnode: Add convenience function for parsing generic references Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-05 13:05   ` [PATCH v8 18/21] v4l: fwnode: Add convenience function for parsing common external refs Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-05 13:05   ` [PATCH v8 19/21] smiapp: Add support for flash and lens devices Sakari Ailus
2017-09-05 13:05     ` Sakari Ailus
2017-09-05 13:05 ` [PATCH v8 20/21] dt: bindings: smiapp: Document lens-focus and flash properties Sakari Ailus
2017-09-05 13:05 ` [PATCH v8 21/21] 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=8123f8c5-9045-2a22-c97f-09d36e504e2e@xs4all.nl \
    --to=hverkuil-qwit8jrvyhvmr6xm/wnwpw@public.gmane.org \
    --cc=devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=laurent.pinchart-ryLnwIuWjnjg/C1BVhZhaw@public.gmane.org \
    --cc=linux-media-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=niklas.soderlund-1zkq55x86MTxsAP9Fp7wbw@public.gmane.org \
    --cc=pavel-+ZI9xUNit7I@public.gmane.org \
    --cc=robh-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
    --cc=sakari.ailus-VuQAYsv1563Yd54FQh9/CA@public.gmane.org \
    --cc=sakari.ailus-X3B1VOXEql0@public.gmane.org \
    --cc=sre-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.