From: Felipe Balbi <balbi@kernel.org>
To: Greg KH <greg@kroah.com>, Alan Stern <stern@rowland.harvard.edu>
Cc: Roger Quadros <rogerq@ti.com>,
vivek.gautam@codeaurora.org, USB list <linux-usb@vger.kernel.org>,
Kernel development list <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v3 1/3] usb: udc: allow adding and removing the same gadget device
Date: Wed, 12 Apr 2017 09:01:44 +0300 [thread overview]
Message-ID: <87wpaqb1vb.fsf@linux.intel.com> (raw)
In-Reply-To: <20170411141927.GB27233@kroah.com>
[-- Attachment #1: Type: text/plain, Size: 2989 bytes --]
Hi,
Greg KH <greg@kroah.com> writes:
> On Tue, Apr 11, 2017 at 10:12:01AM -0400, Alan Stern wrote:
>> On Tue, 11 Apr 2017, Felipe Balbi wrote:
>>
>> > > Oddly enough, yes. But it doesn't explain why this code doesn't blow
>> > > up every time it gets called, in its current form.
>> >
>> > Well, it does :-)
>> >
>> > dev_get_drvdata(_dev) -> NULL -> kfree(NULL)
>> >
>> > We're just leaking memory. I guess a patch like below would be best:
>> >
>> > diff --git a/drivers/usb/gadget/udc/net2280.c b/drivers/usb/gadget/udc/net2280.c
>> > index 3828c2ec8623..4dc04253da61 100644
>> > --- a/drivers/usb/gadget/udc/net2280.c
>> > +++ b/drivers/usb/gadget/udc/net2280.c
>> > @@ -3555,13 +3555,6 @@ static irqreturn_t net2280_irq(int irq, void *_dev)
>> >
>> > /*-------------------------------------------------------------------------*/
>> >
>> > -static void gadget_release(struct device *_dev)
>> > -{
>> > - struct net2280 *dev = dev_get_drvdata(_dev);
>> > -
>> > - kfree(dev);
>> > -}
>> > -
>> > /* tear down the binding between this driver and the pci device */
>> >
>> > static void net2280_remove(struct pci_dev *pdev)
>> > @@ -3598,6 +3591,8 @@ static void net2280_remove(struct pci_dev *pdev)
>> > device_remove_file(&pdev->dev, &dev_attr_registers);
>> >
>> > ep_info(dev, "unbind\n");
>> > +
>> > + kfree(dev);
>> > }
>> >
>> > /* wrap this driver around the specified device, but
>> > @@ -3775,8 +3770,7 @@ static int net2280_probe(struct pci_dev *pdev, const struct pci_device_id *id)
>> > if (retval)
>> > goto done;
>> >
>> > - retval = usb_add_gadget_udc_release(&pdev->dev, &dev->gadget,
>> > - gadget_release);
>> > + retval = usb_add_gadget_udc(&pdev->dev, &dev->gadget);
>> > if (retval)
>> > goto done;
>> > return 0;
>>
>> Maybe... But I can't shake the feeling that Greg KH would strongly
>> disagree. Hasn't he said, many times in the past, that any dynamically
>> allocated device structure _must_ have a real release routine?
>> usb_udc_nop_release() doesn't qualify.
>
> Aw, I wanted to publically yell at someone like the kernel documentation
> says I am allowed to do so if anyone does such a foolish thing :)
heh, except that we're not dynamically allocating struct device at all
:-) Here's what we have for most UDCs (net2280.c included):
struct my_udc {
struct gadget gadget;
[...]
};
probe()
{
struct my_udc *u;
u = kzalloc(sizeof(*u), GFP_KERNEL);
[...]
return 0;
}
Now, if this kzalloc() would be replaced with devm_kzalloc() wouldn't
this result on a functionally equivalent execution to the patch I
proposed above?
Iff we change struct gadget to contain a struct device *dev instead of a
struct device dev, then sure, we will need to cope with proper
->release() implementations.
As it is, it brings nothing to the table, IMO.
--
balbi
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 832 bytes --]
next prev parent reply other threads:[~2017-04-12 6:02 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-04-03 12:20 [PATCH v3 0/3] usb: dwc3: dual-role support Roger Quadros
2017-04-03 12:20 ` [PATCH v3 1/3] usb: udc: allow adding and removing the same gadget device Roger Quadros
2017-04-03 14:19 ` Alan Stern
2017-04-04 7:47 ` Felipe Balbi
2017-04-04 14:17 ` Alan Stern
2017-04-05 8:34 ` Felipe Balbi
2017-04-05 14:12 ` Alan Stern
2017-04-10 10:05 ` Felipe Balbi
2017-04-10 15:17 ` Alan Stern
2017-04-11 7:34 ` Felipe Balbi
2017-04-11 14:12 ` Alan Stern
2017-04-11 14:19 ` Greg KH
2017-04-12 6:01 ` Felipe Balbi [this message]
2017-04-12 6:45 ` Greg KH
2017-04-12 7:33 ` Felipe Balbi
2017-04-12 14:30 ` Alan Stern
2017-04-03 12:20 ` [PATCH v3 2/3] usb: dwc3: make role-switching work with debugfs/mode Roger Quadros
2017-04-03 12:20 ` [PATCH v3 3/3] usb: dwc3: Add dual-role support Roger Quadros
2017-04-03 19:21 ` kbuild test robot
2017-04-04 7:42 ` Roger Quadros
2017-04-04 7:46 ` [PATCH v4 " Roger Quadros
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=87wpaqb1vb.fsf@linux.intel.com \
--to=balbi@kernel.org \
--cc=greg@kroah.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-usb@vger.kernel.org \
--cc=rogerq@ti.com \
--cc=stern@rowland.harvard.edu \
--cc=vivek.gautam@codeaurora.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).