forked from Minki/linux
3f52b7e328
Add routines to - maintain a PS mode for each peer and a non-peer PS mode - indicate own PS mode in transmitted frames - track neighbor STAs power modes - buffer frames when neighbors are in PS mode - add TIM and Awake Window IE to beacons - release frames in Mesh Peer Service Periods Add local_pm to sta_info to represent the link-specific power mode at this station towards the remote station. When a peer link is established, use the default power mode stored in mesh config. Update the PS status if the peering status of a neighbor changes. Maintain a mesh power mode for non-peer mesh STAs. Set the non-peer power mode to active mode during peering. Authenticated mesh peering is currently not working when either node is configured to be in power save mode. Indicate the current power mode in transmitted frames. Use QoS Nulls to indicate mesh power mode transitions. For performance reasons, calls to the function setting the frame flags are placed in HWMP routing routines, as there the STA pointer is already available. Add peer_pm to sta_info to represent the peer's link-specific power mode towards the local station. Add nonpeer_pm to represent the peer's power mode towards all non-peer stations. Track power modes based on received frames. Add the ps_data structure to ieee80211_if_mesh (for TIM map, PS neighbor counter and group-addressed frame buffer). Set WLAN_STA_PS flag for STA in PS mode to use the unicast frame buffering routines in the tx path. Update num_sta_ps to buffer and release group-addressed frames after DTIM beacons. Announce the awake window duration in beacons if in light or deep sleep mode towards any peer or non-peer. Create a TIM IE similarly to AP mode and add it to mesh beacons. Parse received Awake Window IEs and check TIM IEs for buffered frames. Release frames towards peers in mesh Peer Service Periods. Use the corresponding trigger frames and monitor the MPSP status. Append a QoS Null as trigger frame if neccessary to properly end the MPSP. Currently, in HT channels MPSPs behave imperfectly and show large delay spikes and frame losses. Signed-off-by: Marco Porsch <marco@cozybit.com> Signed-off-by: Ivan Bezyazychnyy <ivan.bezyazychnyy@gmail.com> Signed-off-by: Mike Krinkin <krinkin.m.u@gmail.com> Signed-off-by: Max Filippov <jcmvbkbc@gmail.com> Signed-off-by: Johannes Berg <johannes.berg@intel.com>
294 lines
8.6 KiB
Plaintext
294 lines
8.6 KiB
Plaintext
config MAC80211
|
|
tristate "Generic IEEE 802.11 Networking Stack (mac80211)"
|
|
depends on CFG80211
|
|
select CRYPTO
|
|
select CRYPTO_ARC4
|
|
select CRYPTO_AES
|
|
select CRC32
|
|
select AVERAGE
|
|
---help---
|
|
This option enables the hardware independent IEEE 802.11
|
|
networking stack.
|
|
|
|
comment "CFG80211 needs to be enabled for MAC80211"
|
|
depends on CFG80211=n
|
|
|
|
if MAC80211 != n
|
|
|
|
config MAC80211_HAS_RC
|
|
bool
|
|
|
|
config MAC80211_RC_PID
|
|
bool "PID controller based rate control algorithm" if EXPERT
|
|
select MAC80211_HAS_RC
|
|
---help---
|
|
This option enables a TX rate control algorithm for
|
|
mac80211 that uses a PID controller to select the TX
|
|
rate.
|
|
|
|
config MAC80211_RC_MINSTREL
|
|
bool "Minstrel" if EXPERT
|
|
select MAC80211_HAS_RC
|
|
default y
|
|
---help---
|
|
This option enables the 'minstrel' TX rate control algorithm
|
|
|
|
config MAC80211_RC_MINSTREL_HT
|
|
bool "Minstrel 802.11n support" if EXPERT
|
|
depends on MAC80211_RC_MINSTREL
|
|
default y
|
|
---help---
|
|
This option enables the 'minstrel_ht' TX rate control algorithm
|
|
|
|
choice
|
|
prompt "Default rate control algorithm"
|
|
depends on MAC80211_HAS_RC
|
|
default MAC80211_RC_DEFAULT_MINSTREL
|
|
---help---
|
|
This option selects the default rate control algorithm
|
|
mac80211 will use. Note that this default can still be
|
|
overridden through the ieee80211_default_rc_algo module
|
|
parameter if different algorithms are available.
|
|
|
|
config MAC80211_RC_DEFAULT_PID
|
|
bool "PID controller based rate control algorithm"
|
|
depends on MAC80211_RC_PID
|
|
---help---
|
|
Select the PID controller based rate control as the
|
|
default rate control algorithm. You should choose
|
|
this unless you know what you are doing.
|
|
|
|
config MAC80211_RC_DEFAULT_MINSTREL
|
|
bool "Minstrel"
|
|
depends on MAC80211_RC_MINSTREL
|
|
---help---
|
|
Select Minstrel as the default rate control algorithm.
|
|
|
|
|
|
endchoice
|
|
|
|
config MAC80211_RC_DEFAULT
|
|
string
|
|
default "minstrel_ht" if MAC80211_RC_DEFAULT_MINSTREL && MAC80211_RC_MINSTREL_HT
|
|
default "minstrel" if MAC80211_RC_DEFAULT_MINSTREL
|
|
default "pid" if MAC80211_RC_DEFAULT_PID
|
|
default ""
|
|
|
|
endif
|
|
|
|
comment "Some wireless drivers require a rate control algorithm"
|
|
depends on MAC80211 && MAC80211_HAS_RC=n
|
|
|
|
config MAC80211_MESH
|
|
bool "Enable mac80211 mesh networking (pre-802.11s) support"
|
|
depends on MAC80211 && EXPERIMENTAL
|
|
---help---
|
|
This options enables support of Draft 802.11s mesh networking.
|
|
The implementation is based on Draft 2.08 of the Mesh Networking
|
|
amendment. However, no compliance with that draft is claimed or even
|
|
possible, as drafts leave a number of identifiers to be defined after
|
|
ratification. For more information visit http://o11s.org/.
|
|
|
|
config MAC80211_LEDS
|
|
bool "Enable LED triggers"
|
|
depends on MAC80211
|
|
depends on LEDS_CLASS
|
|
select LEDS_TRIGGERS
|
|
---help---
|
|
This option enables a few LED triggers for different
|
|
packet receive/transmit events.
|
|
|
|
config MAC80211_DEBUGFS
|
|
bool "Export mac80211 internals in DebugFS"
|
|
depends on MAC80211 && DEBUG_FS
|
|
---help---
|
|
Select this to see extensive information about
|
|
the internal state of mac80211 in debugfs.
|
|
|
|
Say N unless you know you need this.
|
|
|
|
config MAC80211_MESSAGE_TRACING
|
|
bool "Trace all mac80211 debug messages"
|
|
depends on MAC80211
|
|
---help---
|
|
Select this option to have mac80211 register the
|
|
mac80211_msg trace subsystem with tracepoints to
|
|
collect all debugging messages, independent of
|
|
printing them into the kernel log.
|
|
|
|
The overhead in this option is that all the messages
|
|
need to be present in the binary and formatted at
|
|
runtime for tracing.
|
|
|
|
menuconfig MAC80211_DEBUG_MENU
|
|
bool "Select mac80211 debugging features"
|
|
depends on MAC80211
|
|
---help---
|
|
This option collects various mac80211 debug settings.
|
|
|
|
config MAC80211_NOINLINE
|
|
bool "Do not inline TX/RX handlers"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
This option affects code generation in mac80211, when
|
|
selected some functions are marked "noinline" to allow
|
|
easier debugging of problems in the transmit and receive
|
|
paths.
|
|
|
|
This option increases code size a bit and inserts a lot
|
|
of function calls in the code, but is otherwise safe to
|
|
enable.
|
|
|
|
If unsure, say N unless you expect to be finding problems
|
|
in mac80211.
|
|
|
|
config MAC80211_VERBOSE_DEBUG
|
|
bool "Verbose debugging output"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out
|
|
many debugging messages. It should not be selected
|
|
on production systems as some of the messages are
|
|
remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MLME_DEBUG
|
|
bool "Verbose managed MLME output"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out
|
|
debugging messages for the managed-mode MLME. It
|
|
should not be selected on production systems as some
|
|
of the messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_STA_DEBUG
|
|
bool "Verbose station debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out
|
|
debugging messages for station addition/removal.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_HT_DEBUG
|
|
bool "Verbose HT debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
This option enables 802.11n High Throughput features
|
|
debug tracing output.
|
|
|
|
It should not be selected on production systems as some
|
|
of the messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_IBSS_DEBUG
|
|
bool "Verbose IBSS debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out
|
|
very verbose IBSS debugging messages. It should not
|
|
be selected on production systems as those messages
|
|
are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_PS_DEBUG
|
|
bool "Verbose powersave mode debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very
|
|
verbose power save mode debugging messages (when mac80211
|
|
is an AP and has power saving stations.)
|
|
It should not be selected on production systems as those
|
|
messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MPL_DEBUG
|
|
bool "Verbose mesh peer link debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_MESH
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very
|
|
verbose mesh peer link debugging messages (when mac80211
|
|
is taking part in a mesh network).
|
|
It should not be selected on production systems as those
|
|
messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MPATH_DEBUG
|
|
bool "Verbose mesh path debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_MESH
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very
|
|
verbose mesh path selection debugging messages (when mac80211
|
|
is taking part in a mesh network).
|
|
It should not be selected on production systems as those
|
|
messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MHWMP_DEBUG
|
|
bool "Verbose mesh HWMP routing debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_MESH
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very
|
|
verbose mesh routing (HWMP) debugging messages (when mac80211
|
|
is taking part in a mesh network).
|
|
It should not be selected on production systems as those
|
|
messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MESH_SYNC_DEBUG
|
|
bool "Verbose mesh synchronization debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_MESH
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very verbose mesh
|
|
synchronization debugging messages (when mac80211 is taking part in a
|
|
mesh network).
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_MESH_PS_DEBUG
|
|
bool "Verbose mesh powersave debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_MESH
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very verbose mesh
|
|
powersave debugging messages (when mac80211 is taking part in a
|
|
mesh network).
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_TDLS_DEBUG
|
|
bool "Verbose TDLS debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
---help---
|
|
Selecting this option causes mac80211 to print out very
|
|
verbose TDLS selection debugging messages (when mac80211
|
|
is a TDLS STA).
|
|
It should not be selected on production systems as those
|
|
messages are remotely triggerable.
|
|
|
|
Do not select this option.
|
|
|
|
config MAC80211_DEBUG_COUNTERS
|
|
bool "Extra statistics for TX/RX debugging"
|
|
depends on MAC80211_DEBUG_MENU
|
|
depends on MAC80211_DEBUGFS
|
|
---help---
|
|
Selecting this option causes mac80211 to keep additional
|
|
and very verbose statistics about TX and RX handler use
|
|
and show them in debugfs.
|
|
|
|
If unsure, say N.
|