From: Alexey Khoroshilov Date: Fri, 28 Mar 2014 20:26:15 +0000 (+0400) Subject: rtl8187: fix use after free on failure path in rtl8187_probe() X-Git-Tag: v3.15-rc1~113^2~18^2^2 X-Git-Url: https://repo.jachan.dev/linux.git/commitdiff_plain/a31267c30880ebdc73e6815f58c69a665052fab8 rtl8187: fix use after free on failure path in rtl8187_probe() If allocation of io_dmabuf fails, rtl8187_probe() calls usb_put_dev(udev) while usb_get_dev(udev) is not called yet. As a result refcnt is decremented incorrectly and usb_dev can be used after memory deallocation. Found by Linux Driver Verification project (linuxtesting.org). Signed-off-by: Alexey Khoroshilov Acked-by: Larry Finger Signed-off-by: John W. Linville --- diff --git a/drivers/net/wireless/rtl818x/rtl8187/dev.c b/drivers/net/wireless/rtl818x/rtl8187/dev.c index 2c79bcc6ae65..0ca17cda48fa 100644 --- a/drivers/net/wireless/rtl818x/rtl8187/dev.c +++ b/drivers/net/wireless/rtl818x/rtl8187/dev.c @@ -1636,10 +1636,10 @@ static int rtl8187_probe(struct usb_interface *intf, err_free_dmabuf: kfree(priv->io_dmabuf); - err_free_dev: - ieee80211_free_hw(dev); usb_set_intfdata(intf, NULL); usb_put_dev(udev); + err_free_dev: + ieee80211_free_hw(dev); return err; }