Skip to content

Commit

Permalink
[PATCH] libertas: fix error handling of card initialization
Browse files Browse the repository at this point in the history
Subject says it all.

Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
  • Loading branch information
Marcelo Tosatti authored and John W. Linville committed Jun 11, 2007
1 parent 51d84f5 commit 6a81215
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 2 deletions.
10 changes: 8 additions & 2 deletions drivers/net/wireless/libertas/if_usb.c
Original file line number Diff line number Diff line change
Expand Up @@ -198,10 +198,10 @@ static int if_usb_probe(struct usb_interface *intf,
goto dealloc;

if (wlan_add_mesh(priv))
goto dealloc;
goto err_add_mesh;

if (libertas_activate_card(priv))
goto dealloc;
goto err_activate_card;

if (libertas_found < MAX_DEVS) {
libertas_devs[libertas_found] = priv->wlan_dev.netdev;
Expand All @@ -218,6 +218,12 @@ static int if_usb_probe(struct usb_interface *intf,
*/
return 0;

err_activate_card:
unregister_netdev(priv->mesh_dev);
free_netdev(priv->mesh_dev);
err_add_mesh:
free_netdev(priv->wlan_dev.netdev);
kfree(priv->adapter);
dealloc:
if_usb_free(usb_cardp);

Expand Down
1 change: 1 addition & 0 deletions drivers/net/wireless/libertas/main.c
Original file line number Diff line number Diff line change
Expand Up @@ -823,6 +823,7 @@ wlan_private *wlan_add_card(void *card)

err_kzalloc:
free_netdev(dev);
priv = NULL;
done:
lbs_deb_leave_args(LBS_DEB_NET, "priv %p", priv);
return priv;
Expand Down

0 comments on commit 6a81215

Please sign in to comment.