usb: kbd: Fix memleak on usb_kbd_deregister()
Free the keyboard hid-report buffer and private data on deregister. Signed-off-by: Hans de Goede <hdegoede@redhat.com>
This commit is contained in:
parent
be17e752f3
commit
dfe5b1c86f
|
|
@ -524,9 +524,19 @@ int drv_usb_kbd_init(void)
|
||||||
int usb_kbd_deregister(int force)
|
int usb_kbd_deregister(int force)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_SYS_STDIO_DEREGISTER
|
#ifdef CONFIG_SYS_STDIO_DEREGISTER
|
||||||
int ret = stdio_deregister(DEVNAME, force);
|
struct stdio_dev *dev;
|
||||||
if (ret && ret != -ENODEV)
|
struct usb_device *usb_kbd_dev;
|
||||||
return ret;
|
struct usb_kbd_pdata *data;
|
||||||
|
|
||||||
|
dev = stdio_get_by_name(DEVNAME);
|
||||||
|
if (dev) {
|
||||||
|
usb_kbd_dev = (struct usb_device *)dev->priv;
|
||||||
|
data = usb_kbd_dev->privptr;
|
||||||
|
if (stdio_deregister_dev(dev, force) != 0)
|
||||||
|
return 1;
|
||||||
|
free(data->new);
|
||||||
|
free(data);
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
#else
|
#else
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue