brcmfmac: send port authorized event for FT-802.1X
authorChung-Hsien Hsu <stanley.hsu@cypress.com>
Thu, 9 May 2019 09:48:26 +0000 (09:48 +0000)
committerKalle Valo <kvalo@codeaurora.org>
Tue, 1 Oct 2019 09:10:53 +0000 (12:10 +0300)
With FT-802.1X, driver should send a port authorized event right after
sending a roamed event. It is used to indicate that a new AP is already
authorized so 802.1X is not required.

Acked-by: Arend van Spriel <arend.vanspriel@broadcom.com>
Signed-off-by: Chung-Hsien Hsu <stanley.hsu@cypress.com>
Signed-off-by: Chi-Hsien Lin <chi-hsien.lin@cypress.com>
Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.h

index e3ebb7abbdaedcb6df4d06485c2c2f01f36eea3f..0cf4c795e62ef6494fa08406ebc178de374f0864 100644 (file)
@@ -1647,6 +1647,7 @@ brcmf_set_key_mgmt(struct net_device *ndev, struct cfg80211_connect_params *sme)
        u16 count;
 
        profile->use_fwsup = BRCMF_PROFILE_FWSUP_NONE;
+       profile->is_ft = false;
 
        if (!sme->crypto.n_akm_suites)
                return 0;
@@ -1691,11 +1692,13 @@ brcmf_set_key_mgmt(struct net_device *ndev, struct cfg80211_connect_params *sme)
                        break;
                case WLAN_AKM_SUITE_FT_8021X:
                        val = WPA2_AUTH_UNSPECIFIED | WPA2_AUTH_FT;
+                       profile->is_ft = true;
                        if (sme->want_1x)
                                profile->use_fwsup = BRCMF_PROFILE_FWSUP_1X;
                        break;
                case WLAN_AKM_SUITE_FT_PSK:
                        val = WPA2_AUTH_PSK | WPA2_AUTH_FT;
+                       profile->is_ft = true;
                        break;
                default:
                        bphy_err(drvr, "invalid cipher group (%d)\n",
@@ -5554,6 +5557,11 @@ done:
        cfg80211_roamed(ndev, &roam_info, GFP_KERNEL);
        brcmf_dbg(CONN, "Report roaming result\n");
 
+       if (profile->use_fwsup == BRCMF_PROFILE_FWSUP_1X && profile->is_ft) {
+               cfg80211_port_authorized(ndev, profile->bssid, GFP_KERNEL);
+               brcmf_dbg(CONN, "Report port authorized\n");
+       }
+
        set_bit(BRCMF_VIF_STATUS_CONNECTED, &ifp->vif->sme_state);
        brcmf_dbg(TRACE, "Exit\n");
        return err;
index 14d5bbad1db13fea211da8d4dc985213132c6688..e29846b1954bc46d32565e3d5ab299e869a1f544 100644 (file)
@@ -122,6 +122,7 @@ struct brcmf_cfg80211_profile {
        struct brcmf_cfg80211_security sec;
        struct brcmf_wsec_key key[BRCMF_MAX_DEFAULT_KEYS];
        enum brcmf_profile_fwsup use_fwsup;
+       bool is_ft;
 };
 
 /**