Revert Revert "wpa_supplicant(hidl): Set 'ieee80211w' when PMF required"
This commit reverts I4e72f720eeb311e039c94c5a67ecb49d92969741.
Reason for revert: Wifi connection fails when AP advertize PMF required.
This is bringing back Change id Ie5efcb41bbdd4d88ae28d9665d5fc621535dabbe.
ie,
Global opt 'pmf' determines whether to enable/require PMF by default.
This can be overwrite by the per-network opt 'ieee80211w'.
Now hidl always sets 'ieee80211w' to 'disabled' or 'PMF required',
which makes the global opt 'pmf' not take effect.
Change hidl to set 'ieee80211w' only when PMF required, and in other
cases, PMF is determined by global opt 'pmf'
The IOT issue faced with Ie5efcb41bbdd4d88ae28d9665d5fc621535dabbe is
solved through supplicant workaround
824cb5a530a8fc07666f940f104353458f257612,
which ignores the IGTK configuration errors due to wrong IGTK keyidx.
Bug: 131267738, 140372352
Test: Regression test
Change-Id: I4c120e1f094a7b039837779f58d15cfc7f68d697
Merged-In: I4c120e1f094a7b039837779f58d15cfc7f68d697
diff --git a/wpa_supplicant/hidl/1.2/sta_network.cpp b/wpa_supplicant/hidl/1.2/sta_network.cpp
index 9f4e9d2..57622f8 100644
--- a/wpa_supplicant/hidl/1.2/sta_network.cpp
+++ b/wpa_supplicant/hidl/1.2/sta_network.cpp
@@ -1011,8 +1011,9 @@
SupplicantStatus StaNetwork::setRequirePmfInternal(bool enable)
{
struct wpa_ssid *wpa_ssid = retrieveNetworkPtr();
- wpa_ssid->ieee80211w =
- enable ? MGMT_FRAME_PROTECTION_REQUIRED : NO_MGMT_FRAME_PROTECTION;
+ if (enable) {
+ wpa_ssid->ieee80211w = MGMT_FRAME_PROTECTION_REQUIRED;
+ }
resetInternalStateAfterParamsUpdate();
return {SupplicantStatusCode::SUCCESS, ""};
}