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>
181 lines
4.5 KiB
C
181 lines
4.5 KiB
C
#ifndef __MAC80211_DEBUG_H
|
|
#define __MAC80211_DEBUG_H
|
|
#include <net/cfg80211.h>
|
|
|
|
#ifdef CONFIG_MAC80211_IBSS_DEBUG
|
|
#define MAC80211_IBSS_DEBUG 1
|
|
#else
|
|
#define MAC80211_IBSS_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_PS_DEBUG
|
|
#define MAC80211_PS_DEBUG 1
|
|
#else
|
|
#define MAC80211_PS_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_HT_DEBUG
|
|
#define MAC80211_HT_DEBUG 1
|
|
#else
|
|
#define MAC80211_HT_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MPL_DEBUG
|
|
#define MAC80211_MPL_DEBUG 1
|
|
#else
|
|
#define MAC80211_MPL_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MPATH_DEBUG
|
|
#define MAC80211_MPATH_DEBUG 1
|
|
#else
|
|
#define MAC80211_MPATH_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MHWMP_DEBUG
|
|
#define MAC80211_MHWMP_DEBUG 1
|
|
#else
|
|
#define MAC80211_MHWMP_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MESH_SYNC_DEBUG
|
|
#define MAC80211_MESH_SYNC_DEBUG 1
|
|
#else
|
|
#define MAC80211_MESH_SYNC_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MESH_PS_DEBUG
|
|
#define MAC80211_MESH_PS_DEBUG 1
|
|
#else
|
|
#define MAC80211_MESH_PS_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_TDLS_DEBUG
|
|
#define MAC80211_TDLS_DEBUG 1
|
|
#else
|
|
#define MAC80211_TDLS_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_STA_DEBUG
|
|
#define MAC80211_STA_DEBUG 1
|
|
#else
|
|
#define MAC80211_STA_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MLME_DEBUG
|
|
#define MAC80211_MLME_DEBUG 1
|
|
#else
|
|
#define MAC80211_MLME_DEBUG 0
|
|
#endif
|
|
|
|
#ifdef CONFIG_MAC80211_MESSAGE_TRACING
|
|
void __sdata_info(const char *fmt, ...) __printf(1, 2);
|
|
void __sdata_dbg(bool print, const char *fmt, ...) __printf(2, 3);
|
|
void __sdata_err(const char *fmt, ...) __printf(1, 2);
|
|
void __wiphy_dbg(struct wiphy *wiphy, bool print, const char *fmt, ...)
|
|
__printf(3, 4);
|
|
|
|
#define _sdata_info(sdata, fmt, ...) \
|
|
__sdata_info("%s: " fmt, (sdata)->name, ##__VA_ARGS__)
|
|
#define _sdata_dbg(print, sdata, fmt, ...) \
|
|
__sdata_dbg(print, "%s: " fmt, (sdata)->name, ##__VA_ARGS__)
|
|
#define _sdata_err(sdata, fmt, ...) \
|
|
__sdata_err("%s: " fmt, (sdata)->name, ##__VA_ARGS__)
|
|
#define _wiphy_dbg(print, wiphy, fmt, ...) \
|
|
__wiphy_dbg(wiphy, print, fmt, ##__VA_ARGS__)
|
|
#else
|
|
#define _sdata_info(sdata, fmt, ...) \
|
|
do { \
|
|
pr_info("%s: " fmt, \
|
|
(sdata)->name, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define _sdata_dbg(print, sdata, fmt, ...) \
|
|
do { \
|
|
if (print) \
|
|
pr_debug("%s: " fmt, \
|
|
(sdata)->name, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define _sdata_err(sdata, fmt, ...) \
|
|
do { \
|
|
pr_err("%s: " fmt, \
|
|
(sdata)->name, ##__VA_ARGS__); \
|
|
} while (0)
|
|
|
|
#define _wiphy_dbg(print, wiphy, fmt, ...) \
|
|
do { \
|
|
if (print) \
|
|
wiphy_dbg((wiphy), fmt, ##__VA_ARGS__); \
|
|
} while (0)
|
|
#endif
|
|
|
|
#define sdata_info(sdata, fmt, ...) \
|
|
_sdata_info(sdata, fmt, ##__VA_ARGS__)
|
|
#define sdata_err(sdata, fmt, ...) \
|
|
_sdata_err(sdata, fmt, ##__VA_ARGS__)
|
|
#define sdata_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(1, sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define ht_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_HT_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define ht_dbg_ratelimited(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_HT_DEBUG && net_ratelimit(), \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define ibss_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_IBSS_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define ps_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_PS_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define ps_dbg_hw(hw, fmt, ...) \
|
|
_wiphy_dbg(MAC80211_PS_DEBUG, \
|
|
(hw)->wiphy, fmt, ##__VA_ARGS__)
|
|
|
|
#define ps_dbg_ratelimited(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_PS_DEBUG && net_ratelimit(), \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mpl_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MPL_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mpath_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MPATH_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mhwmp_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MHWMP_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define msync_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MESH_SYNC_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mps_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MESH_PS_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define tdls_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_TDLS_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define sta_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_STA_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mlme_dbg(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MLME_DEBUG, \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#define mlme_dbg_ratelimited(sdata, fmt, ...) \
|
|
_sdata_dbg(MAC80211_MLME_DEBUG && net_ratelimit(), \
|
|
sdata, fmt, ##__VA_ARGS__)
|
|
|
|
#endif /* __MAC80211_DEBUG_H */
|