aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDaniel Kim <dekim@broadcom.com>2014-05-12 04:47:32 -0400
committerJohn W. Linville <linville@tuxdriver.com>2014-05-13 15:56:48 -0400
commitb8d2e8783991d5aa693fd0b4bc8dd11422a41950 (patch)
tree2f95b546fa689248c664a1f8b654fa4731127c26
parent3e99b08ab53c039e440f015ff872490fbad30d78 (diff)
brcmfmac: Fix reconnect failure after beacon timeout
The DISASSOC command needs to be sent to firmware when a connection loss is detected by firmware (e.g., beacon timeout). Otherwise the next connect request fails due to a lingering LINK(down) event from firmware. This patch resolves the issue by using brcmf_link_down() handler, instead of the incomplete duplicated codes. Reviewed-by: Arend Van Spriel <arend@broadcom.com> Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com> Reviewed-by: Hante Meuleman <meuleman@broadcom.com> Signed-off-by: Daniel Kim <dekim@broadcom.com> Signed-off-by: Arend van Spriel <arend@broadcom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c11
1 files changed, 0 insertions, 11 deletions
diff --git a/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c b/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c
index a91514ad57b3..e9d7413522b3 100644
--- a/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c
+++ b/drivers/net/wireless/brcm80211/brcmfmac/wl_cfg80211.c
@@ -4687,7 +4687,6 @@ brcmf_notify_connect_status(struct brcmf_if *ifp,
4687 struct brcmf_cfg80211_profile *profile = &ifp->vif->profile; 4687 struct brcmf_cfg80211_profile *profile = &ifp->vif->profile;
4688 struct ieee80211_channel *chan; 4688 struct ieee80211_channel *chan;
4689 s32 err = 0; 4689 s32 err = 0;
4690 u16 reason;
4691 4690
4692 if (brcmf_is_apmode(ifp->vif)) { 4691 if (brcmf_is_apmode(ifp->vif)) {
4693 err = brcmf_notify_connect_status_ap(cfg, ndev, e, data); 4692 err = brcmf_notify_connect_status_ap(cfg, ndev, e, data);
@@ -4708,16 +4707,6 @@ brcmf_notify_connect_status(struct brcmf_if *ifp,
4708 brcmf_dbg(CONN, "Linkdown\n"); 4707 brcmf_dbg(CONN, "Linkdown\n");
4709 if (!brcmf_is_ibssmode(ifp->vif)) { 4708 if (!brcmf_is_ibssmode(ifp->vif)) {
4710 brcmf_bss_connect_done(cfg, ndev, e, false); 4709 brcmf_bss_connect_done(cfg, ndev, e, false);
4711 if (test_and_clear_bit(BRCMF_VIF_STATUS_CONNECTED,
4712 &ifp->vif->sme_state)) {
4713 reason = 0;
4714 if (((e->event_code == BRCMF_E_DEAUTH_IND) ||
4715 (e->event_code == BRCMF_E_DISASSOC_IND)) &&
4716 (e->reason != WLAN_REASON_UNSPECIFIED))
4717 reason = e->reason;
4718 cfg80211_disconnected(ndev, reason, NULL, 0,
4719 GFP_KERNEL);
4720 }
4721 } 4710 }
4722 brcmf_link_down(ifp->vif); 4711 brcmf_link_down(ifp->vif);
4723 brcmf_init_prof(ndev_to_prof(ndev)); 4712 brcmf_init_prof(ndev_to_prof(ndev));