aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac80211/mlme.c
diff options
context:
space:
mode:
authorJuuso Oikarinen <juuso.oikarinen@nokia.com>2010-03-23 03:02:34 -0400
committerJohn W. Linville <linville@tuxdriver.com>2010-03-24 16:04:33 -0400
commita97c13c34509be460dea23c86f31c02daa2428b5 (patch)
treeeb5d2860af9d6f3121254f2ef262e197b10bed34 /net/mac80211/mlme.c
parentd6dc1a386358979e12366d1f35eeb68fc181e101 (diff)
mac80211: Add support for connection quality monitoring
Add support for the set_cqm_config op. This op function configures the requested connection quality monitor rssi threshold and rssi hysteresis values to the hardware if the hardware supports IEEE80211_HW_SUPPORTS_CQM. For unsupported hardware, currently -EOPNOTSUPP is returned, so the mac80211 is currently not doing connection quality monitoring on the host. This could be added later, if needed. Signed-off-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Reviewed-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/mac80211/mlme.c')
-rw-r--r--net/mac80211/mlme.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 865ea1cfb7bb..65eafda5738a 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -750,6 +750,11 @@ static void ieee80211_set_associated(struct ieee80211_sub_if_data *sdata,
750 /* And the BSSID changed - we're associated now */ 750 /* And the BSSID changed - we're associated now */
751 bss_info_changed |= BSS_CHANGED_BSSID; 751 bss_info_changed |= BSS_CHANGED_BSSID;
752 752
753 /* Tell the driver to monitor connection quality (if supported) */
754 if ((local->hw.flags & IEEE80211_HW_SUPPORTS_CQM_RSSI) &&
755 sdata->vif.bss_conf.cqm_rssi_thold)
756 bss_info_changed |= BSS_CHANGED_CQM;
757
753 ieee80211_bss_info_change_notify(sdata, bss_info_changed); 758 ieee80211_bss_info_change_notify(sdata, bss_info_changed);
754 759
755 mutex_lock(&local->iflist_mtx); 760 mutex_lock(&local->iflist_mtx);
@@ -2182,3 +2187,13 @@ int ieee80211_mgd_action(struct ieee80211_sub_if_data *sdata,
2182 *cookie = (unsigned long) skb; 2187 *cookie = (unsigned long) skb;
2183 return 0; 2188 return 0;
2184} 2189}
2190
2191void ieee80211_cqm_rssi_notify(struct ieee80211_vif *vif,
2192 enum nl80211_cqm_rssi_threshold_event rssi_event,
2193 gfp_t gfp)
2194{
2195 struct ieee80211_sub_if_data *sdata = vif_to_sdata(vif);
2196
2197 cfg80211_cqm_rssi_notify(sdata->dev, rssi_event, gfp);
2198}
2199EXPORT_SYMBOL(ieee80211_cqm_rssi_notify);