diff options
author | Alexandre Belloni | 2017-01-11 13:11:08 +0100 |
---|---|---|
committer | Felipe Balbi | 2017-01-12 09:05:04 +0100 |
commit | 32856eea7bf75dfb99b955ada6e147f553a11366 (patch) | |
tree | 066483e73bb31b1ba14beafc8b296ca8edfb2c08 /drivers/usb/gadget/udc/atmel_usba_udc.c | |
parent | usb: dwc3: exynos fix axius clock error path to do cleanup (diff) | |
download | kernel-qcow2-linux-32856eea7bf75dfb99b955ada6e147f553a11366.tar.gz kernel-qcow2-linux-32856eea7bf75dfb99b955ada6e147f553a11366.tar.xz kernel-qcow2-linux-32856eea7bf75dfb99b955ada6e147f553a11366.zip |
usb: gadget: udc: atmel: remove memory leak
Commit bbe097f092b0 ("usb: gadget: udc: atmel: fix endpoint name")
introduced a memory leak when unbinding the driver. The endpoint names
would not be freed. Solve that by including the name as a string in struct
usba_ep so it is freed when the endpoint is.
Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
Diffstat (limited to 'drivers/usb/gadget/udc/atmel_usba_udc.c')
-rw-r--r-- | drivers/usb/gadget/udc/atmel_usba_udc.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/usb/gadget/udc/atmel_usba_udc.c b/drivers/usb/gadget/udc/atmel_usba_udc.c index f3212db9bc37..12c7687216e6 100644 --- a/drivers/usb/gadget/udc/atmel_usba_udc.c +++ b/drivers/usb/gadget/udc/atmel_usba_udc.c @@ -1978,7 +1978,8 @@ static struct usba_ep * atmel_udc_of_init(struct platform_device *pdev, dev_err(&pdev->dev, "of_probe: name error(%d)\n", ret); goto err; } - ep->ep.name = kasprintf(GFP_KERNEL, "ep%d", ep->index); + sprintf(ep->name, "ep%d", ep->index); + ep->ep.name = ep->name; ep->ep_regs = udc->regs + USBA_EPT_BASE(i); ep->dma_regs = udc->regs + USBA_DMA_BASE(i); |