]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/blame - releases/4.14.67/usb-gadget-dwc2-fix-memory-leak-in-gadget_init.patch
4.14-stable patches
[thirdparty/kernel/stable-queue.git] / releases / 4.14.67 / usb-gadget-dwc2-fix-memory-leak-in-gadget_init.patch
CommitLineData
f5ab4f51
GKH
1From foo@baz Wed Aug 22 09:33:46 CEST 2018
2From: Grigor Tovmasyan <Grigor.Tovmasyan@synopsys.com>
3Date: Thu, 24 May 2018 18:22:30 +0400
4Subject: usb: gadget: dwc2: fix memory leak in gadget_init()
5
6From: Grigor Tovmasyan <Grigor.Tovmasyan@synopsys.com>
7
8[ Upstream commit 9bb073a053f0464ea74a4d4c331fdb7da58568d6 ]
9
10Freed allocated request for ep0 to prevent memory leak in case when
11dwc2_driver_probe() failed.
12
13Cc: Stefan Wahren <stefan.wahren@i2se.com>
14Cc: Marek Szyprowski <m.szyprowski@samsung.com>
15Tested-by: Stefan Wahren <stefan.wahren@i2se.com>
16Tested-by: Marek Szyprowski <m.szyprowski@samsung.com>
17Acked-by: Minas Harutyunyan <hminas@synopsys.com>
18Signed-off-by: Grigor Tovmasyan <tovmasya@synopsys.com>
19Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
20Signed-off-by: Sasha Levin <alexander.levin@microsoft.com>
21Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
22---
23 drivers/usb/dwc2/gadget.c | 7 +++++--
24 1 file changed, 5 insertions(+), 2 deletions(-)
25
26--- a/drivers/usb/dwc2/gadget.c
27+++ b/drivers/usb/dwc2/gadget.c
28@@ -4717,9 +4717,11 @@ int dwc2_gadget_init(struct dwc2_hsotg *
29 }
30
31 ret = usb_add_gadget_udc(dev, &hsotg->gadget);
32- if (ret)
33+ if (ret) {
34+ dwc2_hsotg_ep_free_request(&hsotg->eps_out[0]->ep,
35+ hsotg->ctrl_req);
36 return ret;
37-
38+ }
39 dwc2_hsotg_dump(hsotg);
40
41 return 0;
42@@ -4732,6 +4734,7 @@ int dwc2_gadget_init(struct dwc2_hsotg *
43 int dwc2_hsotg_remove(struct dwc2_hsotg *hsotg)
44 {
45 usb_del_gadget_udc(&hsotg->gadget);
46+ dwc2_hsotg_ep_free_request(&hsotg->eps_out[0]->ep, hsotg->ctrl_req);
47
48 return 0;
49 }