提交 5be7713c 编写于 作者: O Oliver Neukum 提交者: Yang Yingliang

hso: fix bailout in error case of probe

mainline inclusion
from mainline-v5.9-rc1
commit 5fcfb6d0
category: bugfix
bugzilla: NA
CVE: CVE-2021-37159

---------------------------

The driver tries to reuse code for disconnect in case
of a failed probe.
If resources need to be freed after an error in probe, the
netdev must not be freed because it has never been registered.
Fix it by telling the helper which path we are in.
Signed-off-by: NOliver Neukum <oneukum@suse.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
Signed-off-by: NYang Yingliang <yangyingliang@huawei.com>
Reviewed-by: NYue Haibing <yuehaibing@huawei.com>
Reviewed-by: NXiu Jianfeng <xiujianfeng@huawei.com>
Signed-off-by: NYang Yingliang <yangyingliang@huawei.com>
上级 3ad0fb1a
...@@ -2366,7 +2366,7 @@ static int remove_net_device(struct hso_device *hso_dev) ...@@ -2366,7 +2366,7 @@ static int remove_net_device(struct hso_device *hso_dev)
} }
/* Frees our network device */ /* Frees our network device */
static void hso_free_net_device(struct hso_device *hso_dev) static void hso_free_net_device(struct hso_device *hso_dev, bool bailout)
{ {
int i; int i;
struct hso_net *hso_net = dev2net(hso_dev); struct hso_net *hso_net = dev2net(hso_dev);
...@@ -2389,7 +2389,7 @@ static void hso_free_net_device(struct hso_device *hso_dev) ...@@ -2389,7 +2389,7 @@ static void hso_free_net_device(struct hso_device *hso_dev)
kfree(hso_net->mux_bulk_tx_buf); kfree(hso_net->mux_bulk_tx_buf);
hso_net->mux_bulk_tx_buf = NULL; hso_net->mux_bulk_tx_buf = NULL;
if (hso_net->net) if (hso_net->net && !bailout)
free_netdev(hso_net->net); free_netdev(hso_net->net);
kfree(hso_dev); kfree(hso_dev);
...@@ -2565,7 +2565,7 @@ static struct hso_device *hso_create_net_device(struct usb_interface *interface, ...@@ -2565,7 +2565,7 @@ static struct hso_device *hso_create_net_device(struct usb_interface *interface,
return hso_dev; return hso_dev;
exit: exit:
hso_free_net_device(hso_dev); hso_free_net_device(hso_dev, true);
return NULL; return NULL;
} }
...@@ -3137,7 +3137,7 @@ static void hso_free_interface(struct usb_interface *interface) ...@@ -3137,7 +3137,7 @@ static void hso_free_interface(struct usb_interface *interface)
rfkill_unregister(rfk); rfkill_unregister(rfk);
rfkill_destroy(rfk); rfkill_destroy(rfk);
} }
hso_free_net_device(network_table[i]); hso_free_net_device(network_table[i], false);
} }
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册