Commit 21c0cbe7 authored by Tomas Winkler's avatar Tomas Winkler Committed by John W. Linville

mac80211: add association capabilty and timing info into bss_conf

This patch adds assocation capability, timestamp (tsf) and beacon interval
to bss_conf. This is required for successful assocation of iwlwifi drivers
Signed-off-by: default avatarTomas Winkler <tomas.winkler@intel.com>
Signed-off-by: default avatarGregory Greenman <gregory.greenman@intel.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent 98952d5d
...@@ -197,6 +197,9 @@ enum ieee80211_bss_change { ...@@ -197,6 +197,9 @@ enum ieee80211_bss_change {
* @aid: association ID number, valid only when @assoc is true * @aid: association ID number, valid only when @assoc is true
* @use_cts_prot: use CTS protection * @use_cts_prot: use CTS protection
* @use_short_preamble: use 802.11b short preamble * @use_short_preamble: use 802.11b short preamble
* @timestamp: beacon timestamp
* @beacon_int: beacon interval
* @assoc_capability: capabbilities taken from assoc resp
* @assoc_ht: association in HT mode * @assoc_ht: association in HT mode
* @ht_conf: ht capabilities * @ht_conf: ht capabilities
* @ht_bss_conf: ht extended capabilities * @ht_bss_conf: ht extended capabilities
...@@ -208,6 +211,9 @@ struct ieee80211_bss_conf { ...@@ -208,6 +211,9 @@ struct ieee80211_bss_conf {
/* erp related data */ /* erp related data */
bool use_cts_prot; bool use_cts_prot;
bool use_short_preamble; bool use_short_preamble;
u16 beacon_int;
u16 assoc_capability;
u64 timestamp;
/* ht related data */ /* ht related data */
bool assoc_ht; bool assoc_ht;
struct ieee80211_ht_info *ht_conf; struct ieee80211_ht_info *ht_conf;
......
...@@ -509,9 +509,14 @@ static void ieee80211_set_associated(struct net_device *dev, ...@@ -509,9 +509,14 @@ static void ieee80211_set_associated(struct net_device *dev,
conf->channel->center_freq, conf->channel->center_freq,
ifsta->ssid, ifsta->ssid_len); ifsta->ssid, ifsta->ssid_len);
if (bss) { if (bss) {
/* set timing information */
sdata->bss_conf.beacon_int = bss->beacon_int;
sdata->bss_conf.timestamp = bss->timestamp;
if (bss->has_erp_value) if (bss->has_erp_value)
changed |= ieee80211_handle_erp_ie( changed |= ieee80211_handle_erp_ie(
sdata, bss->erp_value); sdata, bss->erp_value);
ieee80211_rx_bss_put(dev, bss); ieee80211_rx_bss_put(dev, bss);
} }
...@@ -2033,8 +2038,10 @@ static void ieee80211_rx_mgmt_assoc_resp(struct ieee80211_sub_if_data *sdata, ...@@ -2033,8 +2038,10 @@ static void ieee80211_rx_mgmt_assoc_resp(struct ieee80211_sub_if_data *sdata,
} else } else
rcu_read_unlock(); rcu_read_unlock();
/* set AID, ieee80211_set_associated() will tell the driver */ /* set AID and assoc capability,
* ieee80211_set_associated() will tell the driver */
bss_conf->aid = aid; bss_conf->aid = aid;
bss_conf->assoc_capability = capab_info;
ieee80211_set_associated(dev, ifsta, 1); ieee80211_set_associated(dev, ifsta, 1);
ieee80211_associated(dev, ifsta); ieee80211_associated(dev, ifsta);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment