diff options
Diffstat (limited to 'package/kernel/mac80211/patches/323-v4.13-0001-brcmfmac-remove-setting-IBSS-mode-when-stopping-AP.patch')
-rw-r--r-- | package/kernel/mac80211/patches/323-v4.13-0001-brcmfmac-remove-setting-IBSS-mode-when-stopping-AP.patch | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/package/kernel/mac80211/patches/323-v4.13-0001-brcmfmac-remove-setting-IBSS-mode-when-stopping-AP.patch b/package/kernel/mac80211/patches/323-v4.13-0001-brcmfmac-remove-setting-IBSS-mode-when-stopping-AP.patch new file mode 100644 index 0000000000..0539014a58 --- /dev/null +++ b/package/kernel/mac80211/patches/323-v4.13-0001-brcmfmac-remove-setting-IBSS-mode-when-stopping-AP.patch @@ -0,0 +1,34 @@ +From 9029679f66d976f8c720eb03c4898274803c9923 Mon Sep 17 00:00:00 2001 +From: Chi-hsien Lin <Chi-Hsien.Lin@cypress.com> +Date: Thu, 18 May 2017 17:22:19 +0800 +Subject: [PATCH] brcmfmac: remove setting IBSS mode when stopping AP + +Upon stopping an AP interface the driver disable INFRA mode effectively +setting the interface in IBSS mode. However, this may affect other +interfaces running in INFRA mode. For instance, if user creates and stops +hostap daemon on virtual interface, then association cannot work on +primary interface because default BSS has been set to IBSS mode in +firmware side. The IBSS mode should be set when cfg80211 changes the +interface. + +Reviewed-by: Wright Feng <wright.feng@cypress.com> +Signed-off-by: Chi-hsien Lin <Chi-Hsien.Lin@cypress.com> +[kvalo@codeaurora.org: rephased commit log based on discussion] +Signed-off-by: Wright Feng <wright.feng@cypress.com> +Signed-off-by: Kalle Valo <kvalo@codeaurora.org> +--- + drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c | 3 --- + 1 file changed, 3 deletions(-) + +--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c ++++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c +@@ -4676,9 +4676,6 @@ static int brcmf_cfg80211_stop_ap(struct + err = brcmf_fil_cmd_int_set(ifp, BRCMF_C_SET_AP, 0); + if (err < 0) + brcmf_err("setting AP mode failed %d\n", err); +- err = brcmf_fil_cmd_int_set(ifp, BRCMF_C_SET_INFRA, 0); +- if (err < 0) +- brcmf_err("setting INFRA mode failed %d\n", err); + if (brcmf_feat_is_enabled(ifp, BRCMF_FEAT_MBSS)) + brcmf_fil_iovar_int_set(ifp, "mbss", 0); + brcmf_fil_cmd_int_set(ifp, BRCMF_C_SET_REGULATORY, |