usb: core: fix memory leak on port_dev_path allocation
Currently the allocation of port_dev_path from the call to
kobject_get_path is not being kfree'd, causing a memory leak. Fix
this by kfree'ing this at the end of the function. Add an extra
error exit path to fix one of the early leaks when envp[0] fails
to be allocated.
Detected by CoverityScan, CID#1473771 ("Resource Leak")
Fixes: 201af55da8
("usb: core: added uevent for over-current")
Signed-off-by: Colin Ian King <colin.king@canonical.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
6503016ea5
commit
bf7f547ecd
|
@ -5170,7 +5170,7 @@ static void port_over_current_notify(struct usb_port *port_dev)
|
|||
|
||||
envp[0] = kasprintf(GFP_KERNEL, "OVER_CURRENT_PORT=%s", port_dev_path);
|
||||
if (!envp[0])
|
||||
return;
|
||||
goto exit_path;
|
||||
|
||||
envp[1] = kasprintf(GFP_KERNEL, "OVER_CURRENT_COUNT=%u",
|
||||
port_dev->over_current_count);
|
||||
|
@ -5182,6 +5182,8 @@ static void port_over_current_notify(struct usb_port *port_dev)
|
|||
kfree(envp[1]);
|
||||
exit:
|
||||
kfree(envp[0]);
|
||||
exit_path:
|
||||
kfree(port_dev_path);
|
||||
}
|
||||
|
||||
static void port_event(struct usb_hub *hub, int port1)
|
||||
|
|
Loading…
Reference in New Issue