Contents
cfg80211
- make nl80211/cfg80211 (and mac80211 where it is involved) have generation numbers for all dumps so that userspace can tell whether it got a proper snapshot dump or not
- use 802.11 MLME SAP interface where appropriate
- validate channel setting vs. all virtual interfaces
Implement new regulatory interpretation rules as discussed in this thread. In summary, using the notation outlined for mathematical intervals:
0) for all 1 <= k < n : MAX_k <= MIN_{k+1} 1) each rule in the regdomain covers the frequency range (MIN_1, MAX_1] 2) given C = union (over all k = 1 .. n) of (MIN_k, MAX_k] it must be true that (CENTER - BW/2, CENTER + BW/2) is a subset of C 3) it must be true for all 1 <= k <= n: if CENTER in (MIN_k, MAX_k] : BW <= BW_k 4) This is easier to formulate algorithmically: USE_FLAGS = 0 for k = 1 .. n if (CENTER - BW/2, CENTER + BW/2) intersects (MIN_k, MAX_k]: USE_FLAGS |= FLAGS_k
mac80211
important
when we detect beacon loss we send a probe request, but may never receive the answer because we're in PS – we need to turn off PS for the time we probe
when we detect beacon loss we send a probe request, but if then we receive beacons we still wait for the probe response even though we are receiving beacons, so if the probe response is lost we still disassoc – change this to reset the probe-response-required flag when receiving beacons again
- somehow integrate rfkill (maybe cfg80211?)
- explain rate[i].retry in TX status with examples
AP support
- fix the PS filtering code: document that hardware may never unset the filter for a station unless instructed to, use the pending queue, remove ieee80211_remove_tx_extra
- injected frames need to be tied to another virtual interface to get the software sequence number and keys (only relevant for 11w) right
- internal bridge setting (separated STAs in the BSS)
- Radar detection (AP DFS or 802.11h)
Long term
- hide (or get rid of) master dev
Issues
- handle reassociation when the AP is out of range for a moment and then comes back
- Need to stop TX/RX when a radar is detected for the duration of scan for a new channel. [reported by Jouni Malinen]
power saving
u-APSD support. Intel has old AP u-APSD patches (incomplete, buffering is done in their firmware)
- 11v support (eventually)
Roaming
mac80211 drivers use wpa_supplicant for help with Roaming. This is done by specifying ap_scan=1, which lets wpa_supplicant select the BSS based on scan results. This works but it could use some more enhancements.
To have better roaming we need to enhance background scanning. We can either enhance the kernel mac80211 STA MLME or userspace MLME. A quicker/temporary solution can be to have wpa_supplicant request scans periodically.
Misc
- Add dormant state support.
- Export more hardware capabilities as wiphy attribute via nl80211 (is anything missing now?)
- Kicking DMA on the last fragment only (?) [suggested by Ivo van Doorn]
- Try to switch from sw crypto to hw when there was no more room for STA keys in the hardware and one STA disassociates (so there is possibly room now). [suggested by Johannes and Michael]
Optimizations
- ieee80211_get_hdrlen and ieee80211_is_eapol are called very often.
- Recognition of device incoming frame belongs to can be made much smarter and faster.
- think about handling probe responses in firmware like b43 can. This requires telling hostapd that it shouldn't be replying to probe requests and having it give the appropriate info to the kernel [Johannes/Michael]
Wishlist
- Add #ifdef's for not compiling AP stuff. [suggested by Jouni Malinen]
- keep track of stations per virtual interface, helps with the optimisation asked for above