diff options
author | Daniel Kim <dekim@broadcom.com> | 2014-05-12 04:47:32 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2014-05-13 15:56:48 -0400 |
commit | b8d2e8783991d5aa693fd0b4bc8dd11422a41950 (patch) | |
tree | 2f95b546fa689248c664a1f8b654fa4731127c26 | |
parent | 3e99b08ab53c039e440f015ff872490fbad30d78 (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.c | 11 |
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)); |