diff options
author | Juuso Oikarinen <juuso.oikarinen@nokia.com> | 2010-03-23 03:02:34 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2010-03-24 16:04:33 -0400 |
commit | a97c13c34509be460dea23c86f31c02daa2428b5 (patch) | |
tree | eb5d2860af9d6f3121254f2ef262e197b10bed34 /net/mac80211/mlme.c | |
parent | d6dc1a386358979e12366d1f35eeb68fc181e101 (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.c | 15 |
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 | |||
2191 | void 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 | } | ||
2199 | EXPORT_SYMBOL(ieee80211_cqm_rssi_notify); | ||