diff mbox series

usb: gadget: function: printer: Fix a memory leak for interface descriptor

Message ID 20201209030018.6001-1-qiang.zhang@windriver.com (mailing list archive)
State Superseded
Headers show
Series usb: gadget: function: printer: Fix a memory leak for interface descriptor | expand

Commit Message

Zhang, Qiang Dec. 9, 2020, 3 a.m. UTC
From: Zqiang <qiang.zhang@windriver.com>

When printer driver be load, the printer_func_bind function be called, in
this function, the interface descriptor be allocated memory, if after that,
the error occurred, the interface descriptor memory need to be free.

Signed-off-by: Zqiang <qiang.zhang@windriver.com>
---
 drivers/usb/gadget/function/f_printer.c | 1 +
 1 file changed, 1 insertion(+)

Comments

Peter Chen Dec. 9, 2020, 1:45 p.m. UTC | #1
On 20-12-09 11:00:18, qiang.zhang@windriver.com wrote:
> From: Zqiang <qiang.zhang@windriver.com>
> 
> When printer driver be load, the printer_func_bind function be called, in
		      is loaded				      is called

> this function, the interface descriptor be allocated memory, if after that,
				descriptors memory region are allocated
> the error occurred, the interface descriptor memory need to be free.
		occurs,			

Except Typo, otherwise:
Reviewed-by: Peter Chen <peter.chen@nxp.com>

Besides, it is bug-fix, you could add fixes tag, and cc stable@vger.kernel.org.

Peter

> 
> Signed-off-by: Zqiang <qiang.zhang@windriver.com>
> ---
>  drivers/usb/gadget/function/f_printer.c | 1 +
>  1 file changed, 1 insertion(+)
> 
> diff --git a/drivers/usb/gadget/function/f_printer.c b/drivers/usb/gadget/function/f_printer.c
> index 64a4112068fc..2f1eb2e81d30 100644
> --- a/drivers/usb/gadget/function/f_printer.c
> +++ b/drivers/usb/gadget/function/f_printer.c
> @@ -1162,6 +1162,7 @@ static int printer_func_bind(struct usb_configuration *c,
>  		printer_req_free(dev->in_ep, req);
>  	}
>  
> +	usb_free_all_descriptors(f);
>  	return ret;
>  
>  }
> -- 
> 2.17.1
>
diff mbox series

Patch

diff --git a/drivers/usb/gadget/function/f_printer.c b/drivers/usb/gadget/function/f_printer.c
index 64a4112068fc..2f1eb2e81d30 100644
--- a/drivers/usb/gadget/function/f_printer.c
+++ b/drivers/usb/gadget/function/f_printer.c
@@ -1162,6 +1162,7 @@  static int printer_func_bind(struct usb_configuration *c,
 		printer_req_free(dev->in_ep, req);
 	}
 
+	usb_free_all_descriptors(f);
 	return ret;
 
 }