FT with WPA3-SAE has been working well since I implemented the advice from your post here:
By the way all, is:
option reassociation_deadline '20000'
still recommended? Presumably that's the only extra setting that might be warranted.
FT with WPA3-SAE has been working well since I implemented the advice from your post here:
By the way all, is:
option reassociation_deadline '20000'
still recommended? Presumably that's the only extra setting that might be warranted.
With the latest master, it works too for sae-mixed, without needing to configure keys or similar. I was waiting for the fix a lot of time!
TLDR: I don't know if really helps.
This has always been debatable. I first learned it as advice to Apple device owners, IIRC, from some Cisco recommendation or a default value of theirs.
I add it to my routers because I have Apple devices around, and I haven't heard of it interfering with anything. However, I can't really pinpoint any measurable improvement that would justify changing the OpenWrt default.
I moved from SAE to 802.1x, and Apple devices still give me some trouble, often showing no Wi-Fi icon, while successfully pinging the router, regardless of the setting. This is the opposite of what I had with SAE-FT: Wi-Fi icon, but no connectivity. At least now, it returns to normal without having to turn the Wi-Fi off and on again.
I noticed that Apple devices roam a lot more than Windows or Android, so they may stress the APs more than other devices. Here are some numbers from 9 APs showing STAs with more than 100 FT authentications over a period of 1 week. There are a couple of Android devices in the mix, but none reach the century mark. 5c:cd is a Windows notebook that stays in an area with poor signal coming from 5 different APs, so it roams a lot without moving; the rest are all iPhones and Apple Watches. The watches don't roam nearly as much as the iPhones. I think it is because they stick to 2.4G more than the phones--here 2e:37... and 8a:6b... are an iPhone/Apple Watch pair that should be close together most of the time:
$ sed -n -e '/EAPOL-4WAY-HS-COMPLETED\|start 4-way\|CTRL-EVENT-EAP-SUCCESS\|skip.*EAP/{s/.*STA //;s/.*\(EAPOL-4WAY-HS-COMPLETED\|CTRL-EVENT-EAP-SUCCESS2\) \(.*\)$/\2 \1/;s/\(..:..\):..:..:..:\(..\)/\1:xx:xx:xx:\2/;p}' hostapd.log-20240225 | sort | uniq -c | grep -B3 '^....[0-9].*4-way'
102 0e:8c:xx:xx:xx:5a CTRL-EVENT-EAP-SUCCESS2
97 0e:8c:xx:xx:xx:5a EAPOL-4WAY-HS-COMPLETED
939 0e:8c:xx:xx:xx:5a IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
939 0e:8c:xx:xx:xx:5a WPA: FT authentication already completed - do not start 4-way handshake
--
1418 2e:37:xx:xx:xx:cf CTRL-EVENT-EAP-SUCCESS2
1197 2e:37:xx:xx:xx:cf EAPOL-4WAY-HS-COMPLETED
11348 2e:37:xx:xx:xx:cf IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
11336 2e:37:xx:xx:xx:cf WPA: FT authentication already completed - do not start 4-way handshake
--
548 32:1d:xx:xx:xx:a3 CTRL-EVENT-EAP-SUCCESS2
471 32:1d:xx:xx:xx:a3 EAPOL-4WAY-HS-COMPLETED
5632 32:1d:xx:xx:xx:a3 IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
5630 32:1d:xx:xx:xx:a3 WPA: FT authentication already completed - do not start 4-way handshake
--
999 56:b0:xx:xx:xx:6b CTRL-EVENT-EAP-SUCCESS2
888 56:b0:xx:xx:xx:6b EAPOL-4WAY-HS-COMPLETED
5075 56:b0:xx:xx:xx:6b IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
5071 56:b0:xx:xx:xx:6b WPA: FT authentication already completed - do not start 4-way handshake
--
98 5c:cd:xx:xx:xx:3a CTRL-EVENT-EAP-SUCCESS2
23 5c:cd:xx:xx:xx:3a EAPOL-4WAY-HS-COMPLETED
197 5c:cd:xx:xx:xx:3a IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
197 5c:cd:xx:xx:xx:3a WPA: FT authentication already completed - do not start 4-way handshake
--
901 62:96:xx:xx:xx:11 CTRL-EVENT-EAP-SUCCESS2
788 62:96:xx:xx:xx:11 EAPOL-4WAY-HS-COMPLETED
11225 62:96:xx:xx:xx:11 IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
11217 62:96:xx:xx:xx:11 WPA: FT authentication already completed - do not start 4-way handshake
--
135 8a:6b:xx:xx:xx:4f CTRL-EVENT-EAP-SUCCESS2
134 8a:6b:xx:xx:xx:4f EAPOL-4WAY-HS-COMPLETED
1223 8a:6b:xx:xx:xx:4f IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
1222 8a:6b:xx:xx:xx:4f WPA: FT authentication already completed - do not start 4-way handshake
--
735 da:5f:xx:xx:xx:fe CTRL-EVENT-EAP-SUCCESS2
650 da:5f:xx:xx:xx:fe EAPOL-4WAY-HS-COMPLETED
3337 da:5f:xx:xx:xx:fe IEEE 802.1X: PMK from FT - skip IEEE 802.1X/EAP
3337 da:5f:xx:xx:xx:fe WPA: FT authentication already completed - do not start 4-way handshake
Sorry for the necro, but this seems like the most appropriate thread still.
Tested a Pixel7 and 802.11r with mixed wpa2/wpa3 by just disabling "Generate PMK locally" and got:
FT: Missing required pairwise in pull response
WPA: pairwise key handshake completed (RSN)
Then additionally set Reassociation Deadline to 20000, switched to FT over DS, and enabled PMK R1 Push, and it appears to be working now:
nl80211: kernel reports: key addition failed
IEEE 802.11: associated (aid 5)
AP-STA-CONNECTED auth_alg=ft
I'm assuming it was the FT over DS that did it, but the other settings seem sound to keep regardless. Will need to test how other devices behave, but this is more or less the only one that would be roaming.
Am noticing that the previous AP doesn't disassociate until about 5.5min after for timer DEAUTH/REMOVE (station inactivity limit at default 300s/6m, disassociate on low ack enabled).
Sounds like the best move is probably to just stick with wpa2 only for now.
edit: just saw for pmk r1 push: Warning: If WPA3 (SAE) is enabled, setting this will break fast BSS transition (802.11r).
Either way, I downgraded to wpa2-psk, switched on generate pmk locally, and put things back to defaults (ft ota) except reasso deadline at 20k for a textbook implementation. Seems to be working well.
Should disasso on low ack be disabled?
Not sure why the recommended ft ota + disable generate - r1 push local didn't work when I was doing wpa2+wpa3