|
@@ -124,12 +124,16 @@ uint8_t ccp_rsn_oui_11[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x11};
|
|
|
uint8_t ccp_rsn_oui_12[HDD_RSN_OUI_SIZE] = {0x50, 0x6F, 0x9A, 0x02};
|
|
|
uint8_t ccp_rsn_oui_0b[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x0B};
|
|
|
uint8_t ccp_rsn_oui_0c[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x0C};
|
|
|
+/* FT-SUITE-B AKM */
|
|
|
+uint8_t ccp_rsn_oui_0d[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x0D};
|
|
|
|
|
|
/* OWE https://tools.ietf.org/html/rfc8110 */
|
|
|
uint8_t ccp_rsn_oui_18[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x12};
|
|
|
|
|
|
#ifdef WLAN_FEATURE_SAE
|
|
|
+/* SAE AKM */
|
|
|
uint8_t ccp_rsn_oui_80[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x08};
|
|
|
+/* FT SAE AKM */
|
|
|
uint8_t ccp_rsn_oui_90[HDD_RSN_OUI_SIZE] = {0x00, 0x0F, 0xAC, 0x09};
|
|
|
#endif
|
|
|
static const
|
|
@@ -1387,6 +1391,10 @@ static void hdd_send_association_event(struct net_device *dev,
|
|
|
eCSR_AUTH_TYPE_FT_RSN_PSK)
|
|
|
|| (roam_profile->AuthType.authType[0] ==
|
|
|
eCSR_AUTH_TYPE_FT_RSN)
|
|
|
+ || (roam_profile->AuthType.authType[0] ==
|
|
|
+ eCSR_AUTH_TYPE_FT_SAE)
|
|
|
+ || (roam_profile->AuthType.authType[0] ==
|
|
|
+ eCSR_AUTH_TYPE_FT_SUITEB_EAP_SHA384)
|
|
|
#ifdef FEATURE_WLAN_ESE
|
|
|
|| (roam_profile->AuthType.authType[0] ==
|
|
|
eCSR_AUTH_TYPE_CCKM_RSN)
|
|
@@ -3051,10 +3059,14 @@ hdd_association_completion_handler(struct hdd_adapter *adapter,
|
|
|
assocReqlen = 0;
|
|
|
}
|
|
|
|
|
|
- if (roam_info->u.pConnectedProfile->AuthType ==
|
|
|
- eCSR_AUTH_TYPE_FT_RSN
|
|
|
- || roam_info->u.pConnectedProfile->AuthType ==
|
|
|
- eCSR_AUTH_TYPE_FT_RSN_PSK) {
|
|
|
+ if ((roam_info->u.pConnectedProfile->AuthType ==
|
|
|
+ eCSR_AUTH_TYPE_FT_RSN) ||
|
|
|
+ (roam_info->u.pConnectedProfile->AuthType ==
|
|
|
+ eCSR_AUTH_TYPE_FT_RSN_PSK) ||
|
|
|
+ (roam_info->u.pConnectedProfile->AuthType ==
|
|
|
+ eCSR_AUTH_TYPE_FT_SAE) ||
|
|
|
+ (roam_info->u.pConnectedProfile->AuthType ==
|
|
|
+ eCSR_AUTH_TYPE_FT_SUITEB_EAP_SHA384)) {
|
|
|
if (ft_carrier_on) {
|
|
|
if (!hddDisconInProgress &&
|
|
|
roam_info->pBssDesc) {
|
|
@@ -5029,6 +5041,9 @@ static void hdd_translate_sae_rsn_to_csr_auth(int8_t auth_suite[4],
|
|
|
{
|
|
|
if (qdf_mem_cmp(auth_suite, ccp_rsn_oui_80, 4) == 0)
|
|
|
*auth_type = eCSR_AUTH_TYPE_SAE;
|
|
|
+ else if (qdf_mem_cmp(auth_suite, ccp_rsn_oui_90, 4) == 0)
|
|
|
+ *auth_type = eCSR_AUTH_TYPE_FT_SAE;
|
|
|
+
|
|
|
}
|
|
|
#else
|
|
|
static inline void hdd_translate_sae_rsn_to_csr_auth(int8_t auth_suite[4],
|
|
@@ -5080,6 +5095,9 @@ eCsrAuthType hdd_translate_rsn_to_csr_auth_type(uint8_t auth_suite[4])
|
|
|
} else if (memcmp(auth_suite, ccp_rsn_oui_0c, 4) == 0) {
|
|
|
/* Check for Suite B EAP 384 */
|
|
|
auth_type = eCSR_AUTH_TYPE_SUITEB_EAP_SHA384;
|
|
|
+ } else if (memcmp(auth_suite, ccp_rsn_oui_0d, 4) == 0) {
|
|
|
+ /* Check for FT Suite B EAP 384 */
|
|
|
+ auth_type = eCSR_AUTH_TYPE_FT_SUITEB_EAP_SHA384;
|
|
|
} else if (memcmp(auth_suite, ccp_rsn_oui_13, 4) == 0) {
|
|
|
auth_type = eCSR_AUTH_TYPE_OSEN;
|
|
|
} else {
|
|
@@ -5648,8 +5666,21 @@ int hdd_set_csr_auth_type(struct hdd_adapter *adapter,
|
|
|
/* Suite B EAP SHA 384 */
|
|
|
roam_profile->AuthType.authType[0] =
|
|
|
eCSR_AUTH_TYPE_SUITEB_EAP_SHA384;
|
|
|
+ } else if ((RSNAuthType == eCSR_AUTH_TYPE_FT_SAE) &&
|
|
|
+ ((key_mgmt & HDD_AUTH_KEY_MGMT_802_1X) ==
|
|
|
+ HDD_AUTH_KEY_MGMT_802_1X)) {
|
|
|
+ roam_profile->AuthType.authType[0] =
|
|
|
+ eCSR_AUTH_TYPE_FT_SAE;
|
|
|
+ } else if ((RSNAuthType ==
|
|
|
+ eCSR_AUTH_TYPE_FT_SUITEB_EAP_SHA384) &&
|
|
|
+ ((key_mgmt & HDD_AUTH_KEY_MGMT_802_1X)
|
|
|
+ == HDD_AUTH_KEY_MGMT_802_1X)) {
|
|
|
+ /* FT Suite-B EAP SHA 384 */
|
|
|
+ roam_profile->AuthType.authType[0] =
|
|
|
+ eCSR_AUTH_TYPE_FT_SUITEB_EAP_SHA384;
|
|
|
+
|
|
|
} else if ((key_mgmt & HDD_AUTH_KEY_MGMT_802_1X)
|
|
|
- == HDD_AUTH_KEY_MGMT_802_1X) {
|
|
|
+ == HDD_AUTH_KEY_MGMT_802_1X) {
|
|
|
roam_profile->AuthType.authType[0] =
|
|
|
eCSR_AUTH_TYPE_RSN;
|
|
|
} else
|
|
@@ -5670,7 +5701,12 @@ int hdd_set_csr_auth_type(struct hdd_adapter *adapter,
|
|
|
break;
|
|
|
|
|
|
case eCSR_AUTH_TYPE_SAE:
|
|
|
- roam_profile->AuthType.authType[0] = eCSR_AUTH_TYPE_SAE;
|
|
|
+
|
|
|
+ if (RSNAuthType == eCSR_AUTH_TYPE_FT_SAE)
|
|
|
+ roam_profile->AuthType.authType[0] =
|
|
|
+ eCSR_AUTH_TYPE_FT_SAE;
|
|
|
+ else
|
|
|
+ roam_profile->AuthType.authType[0] = eCSR_AUTH_TYPE_SAE;
|
|
|
break;
|
|
|
|
|
|
default:
|