提交 86067eea 编写于 作者: O Oliver Neukum 提交者: Greg Kroah-Hartman

[PATCH] USB: fix oops in acm disconnect

this fixes an oops with disconnection in acm.
Signed-off-by: NOliver Neukum <oliver@neukum.name>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 8e695cdb
...@@ -1014,8 +1014,13 @@ static void acm_disconnect(struct usb_interface *intf) ...@@ -1014,8 +1014,13 @@ static void acm_disconnect(struct usb_interface *intf)
} }
down(&open_sem); down(&open_sem);
if (!usb_get_intfdata(intf)) {
up(&open_sem);
return;
}
acm->dev = NULL; acm->dev = NULL;
usb_set_intfdata (intf, NULL); usb_set_intfdata(acm->control, NULL);
usb_set_intfdata(acm->data, NULL);
tasklet_disable(&acm->urb_task); tasklet_disable(&acm->urb_task);
...@@ -1036,7 +1041,7 @@ static void acm_disconnect(struct usb_interface *intf) ...@@ -1036,7 +1041,7 @@ static void acm_disconnect(struct usb_interface *intf)
for (i = 0; i < ACM_NRB; i++) for (i = 0; i < ACM_NRB; i++)
usb_buffer_free(usb_dev, acm->readsize, acm->rb[i].base, acm->rb[i].dma); usb_buffer_free(usb_dev, acm->readsize, acm->rb[i].base, acm->rb[i].dma);
usb_driver_release_interface(&acm_driver, acm->data); usb_driver_release_interface(&acm_driver, intf == acm->control ? acm->data : intf);
if (!acm->used) { if (!acm->used) {
acm_tty_unregister(acm); acm_tty_unregister(acm);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册