Commit 4afe2156 authored by Marc Kleine-Budde's avatar Marc Kleine-Budde

can: usb_8dev: unregister netdev before free()ing

The usb_8dev hardware has problems on some xhci USB hosts. The driver fails to
read the firmware revision in the probe function. This leads to the following
Oops:

    [ 3356.635912] kernel BUG at net/core/dev.c:5701!

The driver tries to free the netdev, which has already been registered, without
unregistering it.

This patch fixes the problem by unregistering the netdev in the error path.
Reported-by: default avatarMichael Olbrich <m.olbrich@pengutronix.de>
Reviewed-by: default avatarBernd Krumboeck <krumboeck@universalnet.at>
Signed-off-by: default avatarMarc Kleine-Budde <mkl@pengutronix.de>
parent 33be081a
...@@ -977,7 +977,7 @@ static int usb_8dev_probe(struct usb_interface *intf, ...@@ -977,7 +977,7 @@ static int usb_8dev_probe(struct usb_interface *intf,
err = usb_8dev_cmd_version(priv, &version); err = usb_8dev_cmd_version(priv, &version);
if (err) { if (err) {
netdev_err(netdev, "can't get firmware version\n"); netdev_err(netdev, "can't get firmware version\n");
goto cleanup_cmd_msg_buffer; goto cleanup_unregister_candev;
} else { } else {
netdev_info(netdev, netdev_info(netdev,
"firmware: %d.%d, hardware: %d.%d\n", "firmware: %d.%d, hardware: %d.%d\n",
...@@ -989,6 +989,9 @@ static int usb_8dev_probe(struct usb_interface *intf, ...@@ -989,6 +989,9 @@ static int usb_8dev_probe(struct usb_interface *intf,
return 0; return 0;
cleanup_unregister_candev:
unregister_netdev(priv->netdev);
cleanup_cmd_msg_buffer: cleanup_cmd_msg_buffer:
kfree(priv->cmd_msg_buffer); kfree(priv->cmd_msg_buffer);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment