[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <5061895a-bbd3-6a9f-c938-f101123ac308@huawei.com>
Date:   Fri, 25 Nov 2022 17:49:11 +0800
From:   Yang Yingliang <yangyingliang@...wei.com>
To:     Daniel Scally <djrscally@...il.com>,
        Andy Shevchenko <andriy.shevchenko@...ux.intel.com>
CC:     <linux-acpi@...r.kernel.org>, <linux-kernel@...r.kernel.org>,
        <heikki.krogerus@...ux.intel.com>, <sakari.ailus@...ux.intel.com>,
        <gregkh@...uxfoundation.org>, <rafael@...nel.org>,
        <yangyingliang@...wei.com>
Subject: Re: [PATCH v3] device property: fix of node refcount leak in
 fwnode_graph_get_next_endpoint()
On 2022/11/25 17:32, Daniel Scally wrote:
> Hello
>
> On 23/11/2022 13:31, Andy Shevchenko wrote:
>> On Wed, Nov 23, 2022 at 10:25:42AM +0800, Yang Yingliang wrote:
>>> The 'parent' returned by fwnode_graph_get_port_parent()
>>> with refcount incremented when 'prev' is not NULL, it
>>> needs be put when finish using it.
>>>
>>> Because the parent is const, introduce a new variable to
>>> store the returned fwnode, then put it before returning
>>> from fwnode_graph_get_next_endpoint().
>> To me this looks good enough. Not sure if Dan has a chance (time) to look at
>> this, though. And maybe even test...
>>
>> Reviewed-by: Andy Shevchenko <andriy.shevchenko@...ux.intel.com>
>
> Apologies; didn't notice this earlier. I will look at and test this today
Thanks,
I tested it, without this patch, I got this message:
OF: ERROR: memory leak, expected refcount 1 instead of 4, 
of_node_get()/of_node_put() unbalanced - destroy cset entry: attach 
overlay node /i2c/pmic@...tcpc/connector
after this patch,  the message is gone.
>
>>> Fixes: b5b41ab6b0c1 ("device property: Check fwnode->secondary in fwnode_graph_get_next_endpoint()")
>>> Signed-off-by: Yang Yingliang <yangyingliang@...wei.com>
>>> ---
>>> v2 -> v3:
>>>    Add a out label.
>>>
>>> v1 -> v2:
>>>    Introduce a new variable to store the returned fwnode.
>>> ---
>>>   drivers/base/property.c | 18 ++++++++++++------
>>>   1 file changed, 12 insertions(+), 6 deletions(-)
>>>
>>> diff --git a/drivers/base/property.c b/drivers/base/property.c
>>> index 2a5a37fcd998..7f338cb4fb7b 100644
>>> --- a/drivers/base/property.c
>>> +++ b/drivers/base/property.c
>>> @@ -989,26 +989,32 @@ struct fwnode_handle *
>>>   fwnode_graph_get_next_endpoint(const struct fwnode_handle *fwnode,
>>>   			       struct fwnode_handle *prev)
>>>   {
>>> +	struct fwnode_handle *ep, *port_parent = NULL;
>>>   	const struct fwnode_handle *parent;
>>> -	struct fwnode_handle *ep;
>>>   
>>>   	/*
>>>   	 * If this function is in a loop and the previous iteration returned
>>>   	 * an endpoint from fwnode->secondary, then we need to use the secondary
>>>   	 * as parent rather than @fwnode.
>>>   	 */
>>> -	if (prev)
>>> -		parent = fwnode_graph_get_port_parent(prev);
>>> -	else
>>> +	if (prev) {
>>> +		port_parent = fwnode_graph_get_port_parent(prev);
>>> +		parent = port_parent;
>>> +	} else {
>>>   		parent = fwnode;
>>> +	}
>>>   	if (IS_ERR_OR_NULL(parent))
>>>   		return NULL;
>>>   
>>>   	ep = fwnode_call_ptr_op(parent, graph_get_next_endpoint, prev);
>>>   	if (ep)
>>> -		return ep;
>>> +		goto out_put_port_parent;
>>> +
>>> +	ep = fwnode_graph_get_next_endpoint(parent->secondary, NULL);
>>>   
>>> -	return fwnode_graph_get_next_endpoint(parent->secondary, NULL);
>>> +out_put_port_parent:
>>> +	fwnode_handle_put(port_parent);
>>> +	return ep;
>>>   }
>>>   EXPORT_SYMBOL_GPL(fwnode_graph_get_next_endpoint);
>>>   
>>> -- 
>>> 2.25.1
>>>
> .
Powered by blists - more mailing lists
 
