Commit 9390ace9 authored by Arend van Spriel's avatar Arend van Spriel Committed by John W. Linville

brcmfmac: free net device when registration fails

When registration fails the net device is no longer needed. Free
the net device and remove reference to private data from the
driver.
Reviewed-by: default avatarHante Meuleman <meuleman@broadcom.com>
Signed-off-by: default avatarArend van Spriel <arend@broadcom.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 24e28bee
...@@ -656,7 +656,9 @@ int brcmf_net_attach(struct brcmf_if *ifp, bool rtnl_locked) ...@@ -656,7 +656,9 @@ int brcmf_net_attach(struct brcmf_if *ifp, bool rtnl_locked)
return 0; return 0;
fail: fail:
drvr->iflist[ifp->bssidx] = NULL;
ndev->netdev_ops = NULL; ndev->netdev_ops = NULL;
free_netdev(ndev);
return -EBADE; return -EBADE;
} }
...@@ -720,6 +722,9 @@ static int brcmf_net_p2p_attach(struct brcmf_if *ifp) ...@@ -720,6 +722,9 @@ static int brcmf_net_p2p_attach(struct brcmf_if *ifp)
return 0; return 0;
fail: fail:
ifp->drvr->iflist[ifp->bssidx] = NULL;
ndev->netdev_ops = NULL;
free_netdev(ndev);
return -EBADE; return -EBADE;
} }
...@@ -925,8 +930,6 @@ int brcmf_bus_start(struct device *dev) ...@@ -925,8 +930,6 @@ int brcmf_bus_start(struct device *dev)
brcmf_fws_del_interface(ifp); brcmf_fws_del_interface(ifp);
brcmf_fws_deinit(drvr); brcmf_fws_deinit(drvr);
} }
free_netdev(ifp->ndev);
drvr->iflist[0] = NULL;
if (p2p_ifp) { if (p2p_ifp) {
free_netdev(p2p_ifp->ndev); free_netdev(p2p_ifp->ndev);
drvr->iflist[1] = NULL; drvr->iflist[1] = NULL;
...@@ -934,7 +937,8 @@ int brcmf_bus_start(struct device *dev) ...@@ -934,7 +937,8 @@ int brcmf_bus_start(struct device *dev)
return ret; return ret;
} }
if ((brcmf_p2p_enable) && (p2p_ifp)) if ((brcmf_p2p_enable) && (p2p_ifp))
brcmf_net_p2p_attach(p2p_ifp); if (brcmf_net_p2p_attach(p2p_ifp) < 0)
brcmf_p2p_enable = 0;
return 0; return 0;
} }
......
...@@ -202,7 +202,8 @@ static void brcmf_fweh_handle_if_event(struct brcmf_pub *drvr, ...@@ -202,7 +202,8 @@ static void brcmf_fweh_handle_if_event(struct brcmf_pub *drvr,
return; return;
brcmf_fws_add_interface(ifp); brcmf_fws_add_interface(ifp);
if (!drvr->fweh.evt_handler[BRCMF_E_IF]) if (!drvr->fweh.evt_handler[BRCMF_E_IF])
err = brcmf_net_attach(ifp, false); if (brcmf_net_attach(ifp, false) < 0)
return;
} }
if (ifevent->action == BRCMF_E_IF_CHANGE) if (ifevent->action == BRCMF_E_IF_CHANGE)
......
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