mirror of
git://projects.qi-hardware.com/openwrt-xburst.git
synced 2025-01-13 20:01:05 +02:00
090f16f6fb
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@12948 3c298f89-4303-0410-b956-a3cf2f4a3e73
1428 lines
53 KiB
Diff
1428 lines
53 KiB
Diff
Subject: 802.11: clean up/fix HT support
|
|
|
|
This patch cleans up a number of things:
|
|
* the unusable definition of the HT capabilities/HT information
|
|
information elements
|
|
* variable names that are hard to understand
|
|
* mac80211: move ieee80211_handle_ht to ht.c and remove the unused
|
|
enable_ht parameter
|
|
* mac80211: fix bug with MCS rate 32 in ieee80211_handle_ht
|
|
* mac80211: fix bug with casting the result of ieee80211_bss_get_ie
|
|
to an information element _contents_ rather than the
|
|
whole element, add size checking (another out-of-bounds
|
|
access bug fixed!)
|
|
* mac80211: remove some unused return values in favour of BUG_ON
|
|
checking
|
|
* a few minor other things
|
|
|
|
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
|
|
---
|
|
drivers/net/wireless/ath9k/main.c | 57 +++++------
|
|
drivers/net/wireless/ath9k/rc.c | 10 -
|
|
drivers/net/wireless/ath9k/rc.h | 1
|
|
drivers/net/wireless/ath9k/recv.c | 2
|
|
drivers/net/wireless/ath9k/xmit.c | 2
|
|
drivers/net/wireless/iwlwifi/iwl-agn-rs.c | 18 +--
|
|
drivers/net/wireless/iwlwifi/iwl-agn.c | 20 +--
|
|
drivers/net/wireless/iwlwifi/iwl-core.c | 71 +++++++-------
|
|
drivers/net/wireless/iwlwifi/iwl-core.h | 2
|
|
drivers/net/wireless/iwlwifi/iwl-dev.h | 4
|
|
drivers/net/wireless/iwlwifi/iwl-scan.c | 12 +-
|
|
drivers/net/wireless/iwlwifi/iwl-sta.c | 6 -
|
|
drivers/net/wireless/mac80211_hwsim.c | 19 +--
|
|
include/linux/ieee80211.h | 133 ++++++++++++++++++--------
|
|
include/net/mac80211.h | 12 +-
|
|
include/net/wireless.h | 15 +-
|
|
net/mac80211/cfg.c | 7 -
|
|
net/mac80211/ht.c | 151 +++++++++++++++++++++++++-----
|
|
net/mac80211/ieee80211_i.h | 16 +--
|
|
net/mac80211/main.c | 94 ------------------
|
|
net/mac80211/mlme.c | 45 ++++----
|
|
net/mac80211/util.c | 4
|
|
net/mac80211/wext.c | 4
|
|
23 files changed, 386 insertions(+), 319 deletions(-)
|
|
|
|
--- everything.orig/include/linux/ieee80211.h 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/include/linux/ieee80211.h 2008-10-09 02:16:21.000000000 +0200
|
|
@@ -685,28 +685,88 @@ struct ieee80211_bar {
|
|
#define IEEE80211_BAR_CTRL_ACK_POLICY_NORMAL 0x0000
|
|
#define IEEE80211_BAR_CTRL_CBMTID_COMPRESSED_BA 0x0004
|
|
|
|
+
|
|
+#define IEEE80211_HT_MCS_MASK_LEN 10
|
|
+
|
|
+/**
|
|
+ * struct ieee80211_mcs_info - MCS information
|
|
+ * @rx_mask: RX mask
|
|
+ * @rx_highest: highest supported RX rate
|
|
+ * @tx_params: TX parameters
|
|
+ */
|
|
+struct ieee80211_mcs_info {
|
|
+ u8 rx_mask[IEEE80211_HT_MCS_MASK_LEN];
|
|
+ __le16 rx_highest;
|
|
+ u8 tx_params;
|
|
+ u8 reserved[3];
|
|
+} __attribute__((packed));
|
|
+
|
|
+/* 802.11n HT capability MSC set */
|
|
+#define IEEE80211_HT_MCS_RX_HIGHEST_MASK 0x3ff
|
|
+#define IEEE80211_HT_MCS_TX_DEFINED 0x01
|
|
+#define IEEE80211_HT_MCS_TX_RX_DIFF 0x02
|
|
+/* value 0 == 1 stream etc */
|
|
+#define IEEE80211_HT_MCS_TX_MAX_STREAMS_MASK 0x0C
|
|
+#define IEEE80211_HT_MCS_TX_MAX_STREAMS_SHIFT 2
|
|
+#define IEEE80211_HT_MCS_TX_MAX_STREAMS 4
|
|
+#define IEEE80211_HT_MCS_TX_UNEQUAL_MODULATION 0x10
|
|
+
|
|
+/*
|
|
+ * 802.11n D5.0 20.3.5 / 20.6 says:
|
|
+ * - indices 0 to 7 and 32 are single spatial stream
|
|
+ * - 8 to 31 are multiple spatial streams using equal modulation
|
|
+ * [8..15 for two streams, 16..23 for three and 24..31 for four]
|
|
+ * - remainder are multiple spatial streams using unequal modulation
|
|
+ */
|
|
+#define IEEE80211_HT_MCS_UNEQUAL_MODULATION_START 33
|
|
+#define IEEE80211_HT_MCS_UNEQUAL_MODULATION_START_BYTE \
|
|
+ (IEEE80211_HT_MCS_UNEQUAL_MODULATION_START / 8)
|
|
+
|
|
/**
|
|
* struct ieee80211_ht_cap - HT capabilities
|
|
*
|
|
- * This structure refers to "HT capabilities element" as
|
|
- * described in 802.11n draft section 7.3.2.52
|
|
+ * This structure is the "HT capabilities element" as
|
|
+ * described in 802.11n D5.0 7.3.2.57
|
|
*/
|
|
struct ieee80211_ht_cap {
|
|
__le16 cap_info;
|
|
u8 ampdu_params_info;
|
|
- u8 supp_mcs_set[16];
|
|
+
|
|
+ /* 16 bytes MCS information */
|
|
+ struct ieee80211_mcs_info mcs;
|
|
+
|
|
__le16 extended_ht_cap_info;
|
|
__le32 tx_BF_cap_info;
|
|
u8 antenna_selection_info;
|
|
} __attribute__ ((packed));
|
|
|
|
+/* 802.11n HT capabilities masks (for cap_info) */
|
|
+#define IEEE80211_HT_CAP_LDPC_CODING 0x0001
|
|
+#define IEEE80211_HT_CAP_SUP_WIDTH_20_40 0x0002
|
|
+#define IEEE80211_HT_CAP_SM_PS 0x000C
|
|
+#define IEEE80211_HT_CAP_GRN_FLD 0x0010
|
|
+#define IEEE80211_HT_CAP_SGI_20 0x0020
|
|
+#define IEEE80211_HT_CAP_SGI_40 0x0040
|
|
+#define IEEE80211_HT_CAP_TX_STBC 0x0080
|
|
+#define IEEE80211_HT_CAP_RX_STBC 0x0300
|
|
+#define IEEE80211_HT_CAP_DELAY_BA 0x0400
|
|
+#define IEEE80211_HT_CAP_MAX_AMSDU 0x0800
|
|
+#define IEEE80211_HT_CAP_DSSSCCK40 0x1000
|
|
+#define IEEE80211_HT_CAP_PSMP_SUPPORT 0x2000
|
|
+#define IEEE80211_HT_CAP_40MHZ_INTOLERANT 0x4000
|
|
+#define IEEE80211_HT_CAP_LSIG_TXOP_PROT 0x8000
|
|
+
|
|
+/* 802.11n HT capability AMPDU settings (for ampdu_params_info) */
|
|
+#define IEEE80211_HT_AMPDU_PARM_FACTOR 0x03
|
|
+#define IEEE80211_HT_AMPDU_PARM_DENSITY 0x1C
|
|
+
|
|
/**
|
|
- * struct ieee80211_ht_cap - HT additional information
|
|
+ * struct ieee80211_ht_info - HT information
|
|
*
|
|
- * This structure refers to "HT information element" as
|
|
- * described in 802.11n draft section 7.3.2.53
|
|
+ * This structure is the "HT information element" as
|
|
+ * described in 802.11n D5.0 7.3.2.58
|
|
*/
|
|
-struct ieee80211_ht_addt_info {
|
|
+struct ieee80211_ht_info {
|
|
u8 control_chan;
|
|
u8 ht_param;
|
|
__le16 operation_mode;
|
|
@@ -714,36 +774,33 @@ struct ieee80211_ht_addt_info {
|
|
u8 basic_set[16];
|
|
} __attribute__ ((packed));
|
|
|
|
-/* 802.11n HT capabilities masks */
|
|
-#define IEEE80211_HT_CAP_SUP_WIDTH 0x0002
|
|
-#define IEEE80211_HT_CAP_SM_PS 0x000C
|
|
-#define IEEE80211_HT_CAP_GRN_FLD 0x0010
|
|
-#define IEEE80211_HT_CAP_SGI_20 0x0020
|
|
-#define IEEE80211_HT_CAP_SGI_40 0x0040
|
|
-#define IEEE80211_HT_CAP_DELAY_BA 0x0400
|
|
-#define IEEE80211_HT_CAP_MAX_AMSDU 0x0800
|
|
-#define IEEE80211_HT_CAP_DSSSCCK40 0x1000
|
|
-/* 802.11n HT capability AMPDU settings */
|
|
-#define IEEE80211_HT_CAP_AMPDU_FACTOR 0x03
|
|
-#define IEEE80211_HT_CAP_AMPDU_DENSITY 0x1C
|
|
-/* 802.11n HT capability MSC set */
|
|
-#define IEEE80211_SUPP_MCS_SET_UEQM 4
|
|
-#define IEEE80211_HT_CAP_MAX_STREAMS 4
|
|
-#define IEEE80211_SUPP_MCS_SET_LEN 10
|
|
-/* maximum streams the spec allows */
|
|
-#define IEEE80211_HT_CAP_MCS_TX_DEFINED 0x01
|
|
-#define IEEE80211_HT_CAP_MCS_TX_RX_DIFF 0x02
|
|
-#define IEEE80211_HT_CAP_MCS_TX_STREAMS 0x0C
|
|
-#define IEEE80211_HT_CAP_MCS_TX_UEQM 0x10
|
|
-/* 802.11n HT IE masks */
|
|
-#define IEEE80211_HT_IE_CHA_SEC_OFFSET 0x03
|
|
-#define IEEE80211_HT_IE_CHA_SEC_NONE 0x00
|
|
-#define IEEE80211_HT_IE_CHA_SEC_ABOVE 0x01
|
|
-#define IEEE80211_HT_IE_CHA_SEC_BELOW 0x03
|
|
-#define IEEE80211_HT_IE_CHA_WIDTH 0x04
|
|
-#define IEEE80211_HT_IE_HT_PROTECTION 0x0003
|
|
-#define IEEE80211_HT_IE_NON_GF_STA_PRSNT 0x0004
|
|
-#define IEEE80211_HT_IE_NON_HT_STA_PRSNT 0x0010
|
|
+/* for ht_param */
|
|
+#define IEEE80211_HT_PARAM_CHA_SEC_OFFSET 0x03
|
|
+#define IEEE80211_HT_PARAM_CHA_SEC_NONE 0x00
|
|
+#define IEEE80211_HT_PARAM_CHA_SEC_ABOVE 0x01
|
|
+#define IEEE80211_HT_PARAM_CHA_SEC_BELOW 0x03
|
|
+#define IEEE80211_HT_PARAM_CHAN_WIDTH_ANY 0x04
|
|
+#define IEEE80211_HT_PARAM_RIFS_MODE 0x08
|
|
+#define IEEE80211_HT_PARAM_SPSMP_SUPPORT 0x10
|
|
+#define IEEE80211_HT_PARAM_SERV_INTERVAL_GRAN 0xE0
|
|
+
|
|
+/* for operation_mode */
|
|
+#define IEEE80211_HT_OP_MODE_PROTECTION 0x0003
|
|
+#define IEEE80211_HT_OP_MODE_PROTECTION_NONE 0
|
|
+#define IEEE80211_HT_OP_MODE_PROTECTION_NONMEMBER 1
|
|
+#define IEEE80211_HT_OP_MODE_PROTECTION_20MHZ 2
|
|
+#define IEEE80211_HT_OP_MODE_PROTECTION_NONHT_MIXED 3
|
|
+#define IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT 0x0004
|
|
+#define IEEE80211_HT_OP_MODE_NON_HT_STA_PRSNT 0x0010
|
|
+
|
|
+/* for stbc_param */
|
|
+#define IEEE80211_HT_STBC_PARAM_DUAL_BEACON 0x0040
|
|
+#define IEEE80211_HT_STBC_PARAM_DUAL_CTS_PROT 0x0080
|
|
+#define IEEE80211_HT_STBC_PARAM_STBC_BEACON 0x0100
|
|
+#define IEEE80211_HT_STBC_PARAM_LSIG_TXOP_FULLPROT 0x0200
|
|
+#define IEEE80211_HT_STBC_PARAM_PCO_ACTIVE 0x0400
|
|
+#define IEEE80211_HT_STBC_PARAM_PCO_PHASE 0x0800
|
|
+
|
|
|
|
/* block-ack parameters */
|
|
#define IEEE80211_ADDBA_PARAM_POLICY_MASK 0x0002
|
|
@@ -949,7 +1006,7 @@ enum ieee80211_eid {
|
|
WLAN_EID_EXT_SUPP_RATES = 50,
|
|
/* 802.11n */
|
|
WLAN_EID_HT_CAPABILITY = 45,
|
|
- WLAN_EID_HT_EXTRA_INFO = 61,
|
|
+ WLAN_EID_HT_INFORMATION = 61,
|
|
/* 802.11i */
|
|
WLAN_EID_RSN = 48,
|
|
WLAN_EID_WPA = 221,
|
|
--- everything.orig/include/net/wireless.h 2008-10-08 20:44:46.000000000 +0200
|
|
+++ everything/include/net/wireless.h 2008-10-09 02:16:20.000000000 +0200
|
|
@@ -10,6 +10,7 @@
|
|
#include <linux/netdevice.h>
|
|
#include <linux/debugfs.h>
|
|
#include <linux/list.h>
|
|
+#include <linux/ieee80211.h>
|
|
#include <net/cfg80211.h>
|
|
|
|
/**
|
|
@@ -133,23 +134,23 @@ struct ieee80211_rate {
|
|
};
|
|
|
|
/**
|
|
- * struct ieee80211_ht_info - describing STA's HT capabilities
|
|
+ * struct ieee80211_sta_ht_cap - STA's HT capabilities
|
|
*
|
|
* This structure describes most essential parameters needed
|
|
* to describe 802.11n HT capabilities for an STA.
|
|
*
|
|
- * @ht_supported: is HT supported by STA, 0: no, 1: yes
|
|
+ * @ht_supported: is HT supported by the STA
|
|
* @cap: HT capabilities map as described in 802.11n spec
|
|
* @ampdu_factor: Maximum A-MPDU length factor
|
|
* @ampdu_density: Minimum A-MPDU spacing
|
|
- * @supp_mcs_set: Supported MCS set as described in 802.11n spec
|
|
+ * @mcs: Supported MCS rates
|
|
*/
|
|
-struct ieee80211_ht_info {
|
|
+struct ieee80211_sta_ht_cap {
|
|
u16 cap; /* use IEEE80211_HT_CAP_ */
|
|
- u8 ht_supported;
|
|
+ bool ht_supported;
|
|
u8 ampdu_factor;
|
|
u8 ampdu_density;
|
|
- u8 supp_mcs_set[16];
|
|
+ struct ieee80211_mcs_info mcs;
|
|
};
|
|
|
|
/**
|
|
@@ -173,7 +174,7 @@ struct ieee80211_supported_band {
|
|
enum ieee80211_band band;
|
|
int n_channels;
|
|
int n_bitrates;
|
|
- struct ieee80211_ht_info ht_info;
|
|
+ struct ieee80211_sta_ht_cap ht_cap;
|
|
};
|
|
|
|
/**
|
|
--- everything.orig/net/mac80211/main.c 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/main.c 2008-10-09 02:16:29.000000000 +0200
|
|
@@ -232,100 +232,6 @@ int ieee80211_hw_config(struct ieee80211
|
|
return ret;
|
|
}
|
|
|
|
-/**
|
|
- * ieee80211_handle_ht should be used only after legacy configuration
|
|
- * has been determined namely band, as ht configuration depends upon
|
|
- * the hardware's HT abilities for a _specific_ band.
|
|
- */
|
|
-u32 ieee80211_handle_ht(struct ieee80211_local *local, int enable_ht,
|
|
- struct ieee80211_ht_info *req_ht_cap,
|
|
- struct ieee80211_ht_bss_info *req_bss_cap)
|
|
-{
|
|
- struct ieee80211_conf *conf = &local->hw.conf;
|
|
- struct ieee80211_supported_band *sband;
|
|
- struct ieee80211_ht_info ht_conf;
|
|
- struct ieee80211_ht_bss_info ht_bss_conf;
|
|
- u32 changed = 0;
|
|
- int i;
|
|
- u8 max_tx_streams = IEEE80211_HT_CAP_MAX_STREAMS;
|
|
- u8 tx_mcs_set_cap;
|
|
-
|
|
- sband = local->hw.wiphy->bands[conf->channel->band];
|
|
-
|
|
- memset(&ht_conf, 0, sizeof(struct ieee80211_ht_info));
|
|
- memset(&ht_bss_conf, 0, sizeof(struct ieee80211_ht_bss_info));
|
|
-
|
|
- /* HT is not supported */
|
|
- if (!sband->ht_info.ht_supported) {
|
|
- conf->flags &= ~IEEE80211_CONF_SUPPORT_HT_MODE;
|
|
- goto out;
|
|
- }
|
|
-
|
|
- /* disable HT */
|
|
- if (!enable_ht) {
|
|
- if (conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE)
|
|
- changed |= BSS_CHANGED_HT;
|
|
- conf->flags &= ~IEEE80211_CONF_SUPPORT_HT_MODE;
|
|
- conf->ht_conf.ht_supported = 0;
|
|
- goto out;
|
|
- }
|
|
-
|
|
-
|
|
- if (!(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE))
|
|
- changed |= BSS_CHANGED_HT;
|
|
-
|
|
- conf->flags |= IEEE80211_CONF_SUPPORT_HT_MODE;
|
|
- ht_conf.ht_supported = 1;
|
|
-
|
|
- ht_conf.cap = req_ht_cap->cap & sband->ht_info.cap;
|
|
- ht_conf.cap &= ~(IEEE80211_HT_CAP_SM_PS);
|
|
- ht_conf.cap |= sband->ht_info.cap & IEEE80211_HT_CAP_SM_PS;
|
|
- ht_bss_conf.primary_channel = req_bss_cap->primary_channel;
|
|
- ht_bss_conf.bss_cap = req_bss_cap->bss_cap;
|
|
- ht_bss_conf.bss_op_mode = req_bss_cap->bss_op_mode;
|
|
-
|
|
- ht_conf.ampdu_factor = req_ht_cap->ampdu_factor;
|
|
- ht_conf.ampdu_density = req_ht_cap->ampdu_density;
|
|
-
|
|
- /* Bits 96-100 */
|
|
- tx_mcs_set_cap = sband->ht_info.supp_mcs_set[12];
|
|
-
|
|
- /* configure suppoerted Tx MCS according to requested MCS
|
|
- * (based in most cases on Rx capabilities of peer) and self
|
|
- * Tx MCS capabilities (as defined by low level driver HW
|
|
- * Tx capabilities) */
|
|
- if (!(tx_mcs_set_cap & IEEE80211_HT_CAP_MCS_TX_DEFINED))
|
|
- goto check_changed;
|
|
-
|
|
- /* Counting from 0 therfore + 1 */
|
|
- if (tx_mcs_set_cap & IEEE80211_HT_CAP_MCS_TX_RX_DIFF)
|
|
- max_tx_streams = ((tx_mcs_set_cap &
|
|
- IEEE80211_HT_CAP_MCS_TX_STREAMS) >> 2) + 1;
|
|
-
|
|
- for (i = 0; i < max_tx_streams; i++)
|
|
- ht_conf.supp_mcs_set[i] =
|
|
- sband->ht_info.supp_mcs_set[i] &
|
|
- req_ht_cap->supp_mcs_set[i];
|
|
-
|
|
- if (tx_mcs_set_cap & IEEE80211_HT_CAP_MCS_TX_UEQM)
|
|
- for (i = IEEE80211_SUPP_MCS_SET_UEQM;
|
|
- i < IEEE80211_SUPP_MCS_SET_LEN; i++)
|
|
- ht_conf.supp_mcs_set[i] =
|
|
- sband->ht_info.supp_mcs_set[i] &
|
|
- req_ht_cap->supp_mcs_set[i];
|
|
-
|
|
-check_changed:
|
|
- /* if bss configuration changed store the new one */
|
|
- if (memcmp(&conf->ht_conf, &ht_conf, sizeof(ht_conf)) ||
|
|
- memcmp(&conf->ht_bss_conf, &ht_bss_conf, sizeof(ht_bss_conf))) {
|
|
- changed |= BSS_CHANGED_HT;
|
|
- memcpy(&conf->ht_conf, &ht_conf, sizeof(ht_conf));
|
|
- memcpy(&conf->ht_bss_conf, &ht_bss_conf, sizeof(ht_bss_conf));
|
|
- }
|
|
-out:
|
|
- return changed;
|
|
-}
|
|
-
|
|
void ieee80211_bss_info_change_notify(struct ieee80211_sub_if_data *sdata,
|
|
u32 changed)
|
|
{
|
|
--- everything.orig/include/net/mac80211.h 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/include/net/mac80211.h 2008-10-09 02:16:30.000000000 +0200
|
|
@@ -191,7 +191,7 @@ enum ieee80211_bss_change {
|
|
* @beacon_int: beacon interval
|
|
* @assoc_capability: capabilities taken from assoc resp
|
|
* @assoc_ht: association in HT mode
|
|
- * @ht_conf: ht capabilities
|
|
+ * @ht_cap: ht capabilities
|
|
* @ht_bss_conf: ht extended capabilities
|
|
* @basic_rates: bitmap of basic rates, each bit stands for an
|
|
* index into the rate table configured by the driver in
|
|
@@ -212,7 +212,7 @@ struct ieee80211_bss_conf {
|
|
u64 basic_rates;
|
|
/* ht related data */
|
|
bool assoc_ht;
|
|
- struct ieee80211_ht_info *ht_conf;
|
|
+ struct ieee80211_sta_ht_cap *ht_cap;
|
|
struct ieee80211_ht_bss_info *ht_bss_conf;
|
|
};
|
|
|
|
@@ -477,7 +477,7 @@ static inline int __deprecated __IEEE802
|
|
* @antenna_sel_tx: transmit antenna selection, 0: default/diversity,
|
|
* 1/2: antenna 0/1
|
|
* @antenna_sel_rx: receive antenna selection, like @antenna_sel_tx
|
|
- * @ht_conf: describes current self configuration of 802.11n HT capabilies
|
|
+ * @ht_cap: describes current self configuration of 802.11n HT capabilities
|
|
* @ht_bss_conf: describes current BSS configuration of 802.11n HT parameters
|
|
* @channel: the channel to tune to
|
|
*/
|
|
@@ -493,7 +493,7 @@ struct ieee80211_conf {
|
|
|
|
struct ieee80211_channel *channel;
|
|
|
|
- struct ieee80211_ht_info ht_conf;
|
|
+ struct ieee80211_sta_ht_cap ht_cap;
|
|
struct ieee80211_ht_bss_info ht_bss_conf;
|
|
};
|
|
|
|
@@ -686,7 +686,7 @@ enum set_key_cmd {
|
|
* @addr: MAC address
|
|
* @aid: AID we assigned to the station if we're an AP
|
|
* @supp_rates: Bitmap of supported rates (per band)
|
|
- * @ht_info: HT capabilities of this STA
|
|
+ * @ht_cap: HT capabilities of this STA
|
|
* @drv_priv: data area for driver use, will always be aligned to
|
|
* sizeof(void *), size is determined in hw information.
|
|
*/
|
|
@@ -694,7 +694,7 @@ struct ieee80211_sta {
|
|
u64 supp_rates[IEEE80211_NUM_BANDS];
|
|
u8 addr[ETH_ALEN];
|
|
u16 aid;
|
|
- struct ieee80211_ht_info ht_info;
|
|
+ struct ieee80211_sta_ht_cap ht_cap;
|
|
|
|
/* must be last */
|
|
u8 drv_priv[0] __attribute__((__aligned__(sizeof(void *))));
|
|
--- everything.orig/net/mac80211/ieee80211_i.h 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/ieee80211_i.h 2008-10-09 02:16:30.000000000 +0200
|
|
@@ -817,7 +817,7 @@ struct ieee802_11_elems {
|
|
u8 *wmm_info;
|
|
u8 *wmm_param;
|
|
struct ieee80211_ht_cap *ht_cap_elem;
|
|
- struct ieee80211_ht_addt_info *ht_info_elem;
|
|
+ struct ieee80211_ht_info *ht_info_elem;
|
|
u8 *mesh_config;
|
|
u8 *mesh_id;
|
|
u8 *peer_link;
|
|
@@ -885,9 +885,6 @@ static inline int ieee80211_bssid_match(
|
|
int ieee80211_hw_config(struct ieee80211_local *local);
|
|
int ieee80211_if_config(struct ieee80211_sub_if_data *sdata, u32 changed);
|
|
void ieee80211_tx_set_protected(struct ieee80211_tx_data *tx);
|
|
-u32 ieee80211_handle_ht(struct ieee80211_local *local, int enable_ht,
|
|
- struct ieee80211_ht_info *req_ht_cap,
|
|
- struct ieee80211_ht_bss_info *req_bss_cap);
|
|
void ieee80211_bss_info_change_notify(struct ieee80211_sub_if_data *sdata,
|
|
u32 changed);
|
|
void ieee80211_configure_filter(struct ieee80211_local *local);
|
|
@@ -968,11 +965,14 @@ int ieee80211_monitor_start_xmit(struct
|
|
int ieee80211_subif_start_xmit(struct sk_buff *skb, struct net_device *dev);
|
|
|
|
/* HT */
|
|
-int ieee80211_ht_cap_ie_to_ht_info(struct ieee80211_ht_cap *ht_cap_ie,
|
|
- struct ieee80211_ht_info *ht_info);
|
|
-int ieee80211_ht_addt_info_ie_to_ht_bss_info(
|
|
- struct ieee80211_ht_addt_info *ht_add_info_ie,
|
|
+void ieee80211_ht_cap_ie_to_sta_ht_cap(struct ieee80211_ht_cap *ht_cap_ie,
|
|
+ struct ieee80211_sta_ht_cap *ht_cap);
|
|
+void ieee80211_ht_info_ie_to_ht_bss_info(
|
|
+ struct ieee80211_ht_info *ht_add_info_ie,
|
|
struct ieee80211_ht_bss_info *bss_info);
|
|
+u32 ieee80211_handle_ht(struct ieee80211_local *local,
|
|
+ struct ieee80211_sta_ht_cap *req_ht_cap,
|
|
+ struct ieee80211_ht_bss_info *req_bss_cap);
|
|
void ieee80211_send_bar(struct ieee80211_sub_if_data *sdata, u8 *ra, u16 tid, u16 ssn);
|
|
|
|
void ieee80211_sta_stop_rx_ba_session(struct ieee80211_sub_if_data *sdata, u8 *da,
|
|
--- everything.orig/net/mac80211/wext.c 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/wext.c 2008-10-09 02:16:28.000000000 +0200
|
|
@@ -147,7 +147,7 @@ static int ieee80211_ioctl_giwname(struc
|
|
sband = local->hw.wiphy->bands[IEEE80211_BAND_5GHZ];
|
|
if (sband) {
|
|
is_a = 1;
|
|
- is_ht |= sband->ht_info.ht_supported;
|
|
+ is_ht |= sband->ht_cap.ht_supported;
|
|
}
|
|
|
|
sband = local->hw.wiphy->bands[IEEE80211_BAND_2GHZ];
|
|
@@ -160,7 +160,7 @@ static int ieee80211_ioctl_giwname(struc
|
|
if (sband->bitrates[i].bitrate == 60)
|
|
is_g = 1;
|
|
}
|
|
- is_ht |= sband->ht_info.ht_supported;
|
|
+ is_ht |= sband->ht_cap.ht_supported;
|
|
}
|
|
|
|
strcpy(name, "IEEE 802.11");
|
|
--- everything.orig/net/mac80211/ht.c 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/net/mac80211/ht.c 2008-10-09 02:16:26.000000000 +0200
|
|
@@ -20,37 +20,33 @@
|
|
#include "sta_info.h"
|
|
#include "wme.h"
|
|
|
|
-int ieee80211_ht_cap_ie_to_ht_info(struct ieee80211_ht_cap *ht_cap_ie,
|
|
- struct ieee80211_ht_info *ht_info)
|
|
+void ieee80211_ht_cap_ie_to_sta_ht_cap(struct ieee80211_ht_cap *ht_cap_ie,
|
|
+ struct ieee80211_sta_ht_cap *ht_cap)
|
|
{
|
|
|
|
- if (ht_info == NULL)
|
|
- return -EINVAL;
|
|
+ BUG_ON(!ht_cap);
|
|
|
|
- memset(ht_info, 0, sizeof(*ht_info));
|
|
+ memset(ht_cap, 0, sizeof(*ht_cap));
|
|
|
|
if (ht_cap_ie) {
|
|
u8 ampdu_info = ht_cap_ie->ampdu_params_info;
|
|
|
|
- ht_info->ht_supported = 1;
|
|
- ht_info->cap = le16_to_cpu(ht_cap_ie->cap_info);
|
|
- ht_info->ampdu_factor =
|
|
- ampdu_info & IEEE80211_HT_CAP_AMPDU_FACTOR;
|
|
- ht_info->ampdu_density =
|
|
- (ampdu_info & IEEE80211_HT_CAP_AMPDU_DENSITY) >> 2;
|
|
- memcpy(ht_info->supp_mcs_set, ht_cap_ie->supp_mcs_set, 16);
|
|
+ ht_cap->ht_supported = true;
|
|
+ ht_cap->cap = le16_to_cpu(ht_cap_ie->cap_info);
|
|
+ ht_cap->ampdu_factor =
|
|
+ ampdu_info & IEEE80211_HT_AMPDU_PARM_FACTOR;
|
|
+ ht_cap->ampdu_density =
|
|
+ (ampdu_info & IEEE80211_HT_AMPDU_PARM_DENSITY) >> 2;
|
|
+ memcpy(&ht_cap->mcs, &ht_cap_ie->mcs, sizeof(ht_cap->mcs));
|
|
} else
|
|
- ht_info->ht_supported = 0;
|
|
-
|
|
- return 0;
|
|
+ ht_cap->ht_supported = false;
|
|
}
|
|
|
|
-int ieee80211_ht_addt_info_ie_to_ht_bss_info(
|
|
- struct ieee80211_ht_addt_info *ht_add_info_ie,
|
|
+void ieee80211_ht_info_ie_to_ht_bss_info(
|
|
+ struct ieee80211_ht_info *ht_add_info_ie,
|
|
struct ieee80211_ht_bss_info *bss_info)
|
|
{
|
|
- if (bss_info == NULL)
|
|
- return -EINVAL;
|
|
+ BUG_ON(!bss_info);
|
|
|
|
memset(bss_info, 0, sizeof(*bss_info));
|
|
|
|
@@ -62,8 +58,119 @@ int ieee80211_ht_addt_info_ie_to_ht_bss_
|
|
bss_info->bss_cap = ht_add_info_ie->ht_param;
|
|
bss_info->bss_op_mode = (u8)(op_mode & 0xff);
|
|
}
|
|
+}
|
|
+
|
|
+/*
|
|
+ * ieee80211_handle_ht should be called only after the operating band
|
|
+ * has been determined as ht configuration depends on the hw's
|
|
+ * HT abilities for a specific band.
|
|
+ */
|
|
+u32 ieee80211_handle_ht(struct ieee80211_local *local,
|
|
+ struct ieee80211_sta_ht_cap *req_ht_cap,
|
|
+ struct ieee80211_ht_bss_info *req_bss_cap)
|
|
+{
|
|
+ struct ieee80211_conf *conf = &local->hw.conf;
|
|
+ struct ieee80211_supported_band *sband;
|
|
+ struct ieee80211_sta_ht_cap ht_cap;
|
|
+ struct ieee80211_ht_bss_info ht_bss_conf;
|
|
+ u32 changed = 0;
|
|
+ int i;
|
|
+ u8 max_tx_streams;
|
|
+ u8 tx_mcs_set_cap;
|
|
+ bool enable_ht = true;
|
|
+
|
|
+ sband = local->hw.wiphy->bands[conf->channel->band];
|
|
+
|
|
+ memset(&ht_cap, 0, sizeof(ht_cap));
|
|
+ memset(&ht_bss_conf, 0, sizeof(struct ieee80211_ht_bss_info));
|
|
+
|
|
+ /* HT is not supported */
|
|
+ if (!sband->ht_cap.ht_supported)
|
|
+ enable_ht = false;
|
|
+
|
|
+ /* disable HT */
|
|
+ if (!enable_ht) {
|
|
+ if (conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE)
|
|
+ changed |= BSS_CHANGED_HT;
|
|
+ conf->flags &= ~IEEE80211_CONF_SUPPORT_HT_MODE;
|
|
+ conf->ht_cap.ht_supported = false;
|
|
+ return changed;
|
|
+ }
|
|
+
|
|
+
|
|
+ if (!(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE))
|
|
+ changed |= BSS_CHANGED_HT;
|
|
+
|
|
+ conf->flags |= IEEE80211_CONF_SUPPORT_HT_MODE;
|
|
+ ht_cap.ht_supported = true;
|
|
+
|
|
+ ht_cap.cap = req_ht_cap->cap & sband->ht_cap.cap;
|
|
+ ht_cap.cap &= ~IEEE80211_HT_CAP_SM_PS;
|
|
+ ht_cap.cap |= sband->ht_cap.cap & IEEE80211_HT_CAP_SM_PS;
|
|
+
|
|
+ ht_bss_conf.primary_channel = req_bss_cap->primary_channel;
|
|
+ ht_bss_conf.bss_cap = req_bss_cap->bss_cap;
|
|
+ ht_bss_conf.bss_op_mode = req_bss_cap->bss_op_mode;
|
|
+
|
|
+ ht_cap.ampdu_factor = req_ht_cap->ampdu_factor;
|
|
+ ht_cap.ampdu_density = req_ht_cap->ampdu_density;
|
|
+
|
|
+ /* own MCS TX capabilities */
|
|
+ tx_mcs_set_cap = sband->ht_cap.mcs.tx_params;
|
|
+
|
|
+ /*
|
|
+ * configure supported Tx MCS according to requested MCS
|
|
+ * (based in most cases on Rx capabilities of peer) and self
|
|
+ * Tx MCS capabilities (as defined by low level driver HW
|
|
+ * Tx capabilities)
|
|
+ */
|
|
+
|
|
+ /* can we TX with MCS rates? */
|
|
+ if (!(tx_mcs_set_cap & IEEE80211_HT_MCS_TX_DEFINED))
|
|
+ goto check_changed;
|
|
+
|
|
+ /* Counting from 0, therefore +1 */
|
|
+ if (tx_mcs_set_cap & IEEE80211_HT_MCS_TX_RX_DIFF)
|
|
+ max_tx_streams =
|
|
+ ((tx_mcs_set_cap & IEEE80211_HT_MCS_TX_MAX_STREAMS_MASK)
|
|
+ >> IEEE80211_HT_MCS_TX_MAX_STREAMS_SHIFT) + 1;
|
|
+ else
|
|
+ max_tx_streams = IEEE80211_HT_MCS_TX_MAX_STREAMS;
|
|
+
|
|
+ /*
|
|
+ * 802.11n D5.0 20.3.5 / 20.6 says:
|
|
+ * - indices 0 to 7 and 32 are single spatial stream
|
|
+ * - 8 to 31 are multiple spatial streams using equal modulation
|
|
+ * [8..15 for two streams, 16..23 for three and 24..31 for four]
|
|
+ * - remainder are multiple spatial streams using unequal modulation
|
|
+ */
|
|
+ for (i = 0; i < max_tx_streams; i++)
|
|
+ ht_cap.mcs.rx_mask[i] =
|
|
+ sband->ht_cap.mcs.rx_mask[i] &
|
|
+ req_ht_cap->mcs.rx_mask[i];
|
|
+
|
|
+ if (tx_mcs_set_cap & IEEE80211_HT_MCS_TX_UNEQUAL_MODULATION)
|
|
+ for (i = IEEE80211_HT_MCS_UNEQUAL_MODULATION_START_BYTE;
|
|
+ i < IEEE80211_HT_MCS_MASK_LEN; i++)
|
|
+ ht_cap.mcs.rx_mask[i] =
|
|
+ sband->ht_cap.mcs.rx_mask[i] &
|
|
+ req_ht_cap->mcs.rx_mask[i];
|
|
+
|
|
+ /* handle MCS rate 32 too */
|
|
+ if (sband->ht_cap.mcs.rx_mask[32/8] &
|
|
+ req_ht_cap->mcs.rx_mask[32/8] & 1)
|
|
+ ht_cap.mcs.rx_mask[32/8] |= 1;
|
|
+
|
|
+ check_changed:
|
|
+ /* if bss configuration changed store the new one */
|
|
+ if (memcmp(&conf->ht_cap, &ht_cap, sizeof(ht_cap)) ||
|
|
+ memcmp(&conf->ht_bss_conf, &ht_bss_conf, sizeof(ht_bss_conf))) {
|
|
+ changed |= BSS_CHANGED_HT;
|
|
+ memcpy(&conf->ht_cap, &ht_cap, sizeof(ht_cap));
|
|
+ memcpy(&conf->ht_bss_conf, &ht_bss_conf, sizeof(ht_bss_conf));
|
|
+ }
|
|
|
|
- return 0;
|
|
+ return changed;
|
|
}
|
|
|
|
static void ieee80211_send_addba_request(struct ieee80211_sub_if_data *sdata,
|
|
@@ -802,7 +909,7 @@ void ieee80211_process_addba_request(str
|
|
* check if configuration can support the BA policy
|
|
* and if buffer size does not exceeds max value */
|
|
if (((ba_policy != 1)
|
|
- && (!(conf->ht_conf.cap & IEEE80211_HT_CAP_DELAY_BA)))
|
|
+ && (!(conf->ht_cap.cap & IEEE80211_HT_CAP_DELAY_BA)))
|
|
|| (buf_size > IEEE80211_MAX_AMPDU_BUF)) {
|
|
status = WLAN_STATUS_INVALID_QOS_PARAM;
|
|
#ifdef CONFIG_MAC80211_HT_DEBUG
|
|
@@ -820,7 +927,7 @@ void ieee80211_process_addba_request(str
|
|
|
|
sband = local->hw.wiphy->bands[conf->channel->band];
|
|
buf_size = IEEE80211_MIN_AMPDU_BUF;
|
|
- buf_size = buf_size << sband->ht_info.ampdu_factor;
|
|
+ buf_size = buf_size << sband->ht_cap.ampdu_factor;
|
|
}
|
|
|
|
|
|
--- everything.orig/net/mac80211/mlme.c 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/mlme.c 2008-10-09 02:16:26.000000000 +0200
|
|
@@ -236,7 +236,7 @@ static void ieee80211_send_assoc(struct
|
|
struct ieee80211_local *local = sdata->local;
|
|
struct sk_buff *skb;
|
|
struct ieee80211_mgmt *mgmt;
|
|
- u8 *pos, *ies, *ht_add_ie;
|
|
+ u8 *pos, *ies, *ht_ie;
|
|
int i, len, count, rates_len, supp_rates_len;
|
|
u16 capab;
|
|
struct ieee80211_bss *bss;
|
|
@@ -393,24 +393,25 @@ static void ieee80211_send_assoc(struct
|
|
|
|
/* wmm support is a must to HT */
|
|
if (wmm && (ifsta->flags & IEEE80211_STA_WMM_ENABLED) &&
|
|
- sband->ht_info.ht_supported &&
|
|
- (ht_add_ie = ieee80211_bss_get_ie(bss, WLAN_EID_HT_EXTRA_INFO))) {
|
|
- struct ieee80211_ht_addt_info *ht_add_info =
|
|
- (struct ieee80211_ht_addt_info *)ht_add_ie;
|
|
- u16 cap = sband->ht_info.cap;
|
|
+ sband->ht_cap.ht_supported &&
|
|
+ (ht_ie = ieee80211_bss_get_ie(bss, WLAN_EID_HT_INFORMATION)) &&
|
|
+ ht_ie[1] >= sizeof(struct ieee80211_ht_info)) {
|
|
+ struct ieee80211_ht_info *ht_info =
|
|
+ (struct ieee80211_ht_info *)(ht_ie + 2);
|
|
+ u16 cap = sband->ht_cap.cap;
|
|
__le16 tmp;
|
|
u32 flags = local->hw.conf.channel->flags;
|
|
|
|
- switch (ht_add_info->ht_param & IEEE80211_HT_IE_CHA_SEC_OFFSET) {
|
|
- case IEEE80211_HT_IE_CHA_SEC_ABOVE:
|
|
+ switch (ht_info->ht_param & IEEE80211_HT_PARAM_CHA_SEC_OFFSET) {
|
|
+ case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
|
|
if (flags & IEEE80211_CHAN_NO_FAT_ABOVE) {
|
|
- cap &= ~IEEE80211_HT_CAP_SUP_WIDTH;
|
|
+ cap &= ~IEEE80211_HT_CAP_SUP_WIDTH_20_40;
|
|
cap &= ~IEEE80211_HT_CAP_SGI_40;
|
|
}
|
|
break;
|
|
- case IEEE80211_HT_IE_CHA_SEC_BELOW:
|
|
+ case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
|
|
if (flags & IEEE80211_CHAN_NO_FAT_BELOW) {
|
|
- cap &= ~IEEE80211_HT_CAP_SUP_WIDTH;
|
|
+ cap &= ~IEEE80211_HT_CAP_SUP_WIDTH_20_40;
|
|
cap &= ~IEEE80211_HT_CAP_SGI_40;
|
|
}
|
|
break;
|
|
@@ -424,9 +425,9 @@ static void ieee80211_send_assoc(struct
|
|
memcpy(pos, &tmp, sizeof(u16));
|
|
pos += sizeof(u16);
|
|
/* TODO: needs a define here for << 2 */
|
|
- *pos++ = sband->ht_info.ampdu_factor |
|
|
- (sband->ht_info.ampdu_density << 2);
|
|
- memcpy(pos, sband->ht_info.supp_mcs_set, 16);
|
|
+ *pos++ = sband->ht_cap.ampdu_factor |
|
|
+ (sband->ht_cap.ampdu_density << 2);
|
|
+ memcpy(pos, &sband->ht_cap.mcs, sizeof(sband->ht_cap.mcs));
|
|
}
|
|
|
|
kfree(ifsta->assocreq_ies);
|
|
@@ -732,7 +733,7 @@ static void ieee80211_set_associated(str
|
|
if (conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) {
|
|
changed |= BSS_CHANGED_HT;
|
|
sdata->bss_conf.assoc_ht = 1;
|
|
- sdata->bss_conf.ht_conf = &conf->ht_conf;
|
|
+ sdata->bss_conf.ht_cap = &conf->ht_cap;
|
|
sdata->bss_conf.ht_bss_conf = &conf->ht_bss_conf;
|
|
}
|
|
|
|
@@ -856,7 +857,7 @@ static void ieee80211_set_disassoc(struc
|
|
changed |= BSS_CHANGED_HT;
|
|
|
|
sdata->bss_conf.assoc_ht = 0;
|
|
- sdata->bss_conf.ht_conf = NULL;
|
|
+ sdata->bss_conf.ht_cap = NULL;
|
|
sdata->bss_conf.ht_bss_conf = NULL;
|
|
|
|
ieee80211_led_assoc(local, 0);
|
|
@@ -1348,11 +1349,11 @@ static void ieee80211_rx_mgmt_assoc_resp
|
|
if (elems.ht_cap_elem && elems.ht_info_elem && elems.wmm_param &&
|
|
(ifsta->flags & IEEE80211_STA_WMM_ENABLED)) {
|
|
struct ieee80211_ht_bss_info bss_info;
|
|
- ieee80211_ht_cap_ie_to_ht_info(
|
|
- elems.ht_cap_elem, &sta->sta.ht_info);
|
|
- ieee80211_ht_addt_info_ie_to_ht_bss_info(
|
|
+ ieee80211_ht_cap_ie_to_sta_ht_cap(
|
|
+ elems.ht_cap_elem, &sta->sta.ht_cap);
|
|
+ ieee80211_ht_info_ie_to_ht_bss_info(
|
|
elems.ht_info_elem, &bss_info);
|
|
- ieee80211_handle_ht(local, 1, &sta->sta.ht_info, &bss_info);
|
|
+ ieee80211_handle_ht(local, &sta->sta.ht_cap, &bss_info);
|
|
}
|
|
|
|
rate_control_rate_init(sta);
|
|
@@ -1712,9 +1713,9 @@ static void ieee80211_rx_mgmt_beacon(str
|
|
elems.wmm_param && conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) {
|
|
struct ieee80211_ht_bss_info bss_info;
|
|
|
|
- ieee80211_ht_addt_info_ie_to_ht_bss_info(
|
|
+ ieee80211_ht_info_ie_to_ht_bss_info(
|
|
elems.ht_info_elem, &bss_info);
|
|
- changed |= ieee80211_handle_ht(local, 1, &conf->ht_conf,
|
|
+ changed |= ieee80211_handle_ht(local, &conf->ht_cap,
|
|
&bss_info);
|
|
}
|
|
|
|
--- everything.orig/net/mac80211/util.c 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/util.c 2008-10-09 02:16:28.000000000 +0200
|
|
@@ -532,8 +532,8 @@ void ieee802_11_parse_elems(u8 *start, s
|
|
if (elen >= sizeof(struct ieee80211_ht_cap))
|
|
elems->ht_cap_elem = (void *)pos;
|
|
break;
|
|
- case WLAN_EID_HT_EXTRA_INFO:
|
|
- if (elen >= sizeof(struct ieee80211_ht_addt_info))
|
|
+ case WLAN_EID_HT_INFORMATION:
|
|
+ if (elen >= sizeof(struct ieee80211_ht_info))
|
|
elems->ht_info_elem = (void *)pos;
|
|
break;
|
|
case WLAN_EID_MESH_ID:
|
|
--- everything.orig/net/mac80211/cfg.c 2008-10-08 20:45:06.000000000 +0200
|
|
+++ everything/net/mac80211/cfg.c 2008-10-09 02:16:29.000000000 +0200
|
|
@@ -635,10 +635,9 @@ static void sta_apply_parameters(struct
|
|
sta->sta.supp_rates[local->oper_channel->band] = rates;
|
|
}
|
|
|
|
- if (params->ht_capa) {
|
|
- ieee80211_ht_cap_ie_to_ht_info(params->ht_capa,
|
|
- &sta->sta.ht_info);
|
|
- }
|
|
+ if (params->ht_capa)
|
|
+ ieee80211_ht_cap_ie_to_sta_ht_cap(params->ht_capa,
|
|
+ &sta->sta.ht_cap);
|
|
|
|
if (ieee80211_vif_is_mesh(&sdata->vif) && params->plink_action) {
|
|
switch (params->plink_action) {
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-agn-rs.c 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-agn-rs.c 2008-10-09 02:16:27.000000000 +0200
|
|
@@ -1136,10 +1136,10 @@ static int rs_switch_to_mimo2(struct iwl
|
|
s8 is_green = lq_sta->is_green;
|
|
|
|
if (!(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) ||
|
|
- !sta->ht_info.ht_supported)
|
|
+ !sta->ht_cap.ht_supported)
|
|
return -1;
|
|
|
|
- if (((sta->ht_info.cap & IEEE80211_HT_CAP_SM_PS) >> 2)
|
|
+ if (((sta->ht_cap.cap & IEEE80211_HT_CAP_SM_PS) >> 2)
|
|
== WLAN_HT_CAP_SM_PS_STATIC)
|
|
return -1;
|
|
|
|
@@ -1204,7 +1204,7 @@ static int rs_switch_to_siso(struct iwl_
|
|
s32 rate;
|
|
|
|
if (!(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) ||
|
|
- !sta->ht_info.ht_supported)
|
|
+ !sta->ht_cap.ht_supported)
|
|
return -1;
|
|
|
|
IWL_DEBUG_RATE("LQ: try to switch to SISO\n");
|
|
@@ -2244,19 +2244,19 @@ static void rs_rate_init(void *priv_r, s
|
|
* active_siso_rate mask includes 9 MBits (bit 5), and CCK (bits 0-3),
|
|
* supp_rates[] does not; shift to convert format, force 9 MBits off.
|
|
*/
|
|
- lq_sta->active_siso_rate = conf->ht_conf.supp_mcs_set[0] << 1;
|
|
- lq_sta->active_siso_rate |= conf->ht_conf.supp_mcs_set[0] & 0x1;
|
|
+ lq_sta->active_siso_rate = conf->ht_cap.mcs.rx_mask[0] << 1;
|
|
+ lq_sta->active_siso_rate |= conf->ht_cap.mcs.rx_mask[0] & 0x1;
|
|
lq_sta->active_siso_rate &= ~((u16)0x2);
|
|
lq_sta->active_siso_rate <<= IWL_FIRST_OFDM_RATE;
|
|
|
|
/* Same here */
|
|
- lq_sta->active_mimo2_rate = conf->ht_conf.supp_mcs_set[1] << 1;
|
|
- lq_sta->active_mimo2_rate |= conf->ht_conf.supp_mcs_set[1] & 0x1;
|
|
+ lq_sta->active_mimo2_rate = conf->ht_cap.mcs.rx_mask[1] << 1;
|
|
+ lq_sta->active_mimo2_rate |= conf->ht_cap.mcs.rx_mask[1] & 0x1;
|
|
lq_sta->active_mimo2_rate &= ~((u16)0x2);
|
|
lq_sta->active_mimo2_rate <<= IWL_FIRST_OFDM_RATE;
|
|
|
|
- lq_sta->active_mimo3_rate = conf->ht_conf.supp_mcs_set[2] << 1;
|
|
- lq_sta->active_mimo3_rate |= conf->ht_conf.supp_mcs_set[2] & 0x1;
|
|
+ lq_sta->active_mimo3_rate = conf->ht_cap.mcs.rx_mask[2] << 1;
|
|
+ lq_sta->active_mimo3_rate |= conf->ht_cap.mcs.rx_mask[2] & 0x1;
|
|
lq_sta->active_mimo3_rate &= ~((u16)0x2);
|
|
lq_sta->active_mimo3_rate <<= IWL_FIRST_OFDM_RATE;
|
|
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-agn.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-agn.c 2008-10-09 02:16:29.000000000 +0200
|
|
@@ -553,7 +553,7 @@ static int iwl4965_send_beacon_cmd(struc
|
|
static void iwl4965_ht_conf(struct iwl_priv *priv,
|
|
struct ieee80211_bss_conf *bss_conf)
|
|
{
|
|
- struct ieee80211_ht_info *ht_conf = bss_conf->ht_conf;
|
|
+ struct ieee80211_sta_ht_cap *ht_conf = bss_conf->ht_cap;
|
|
struct ieee80211_ht_bss_info *ht_bss_conf = bss_conf->ht_bss_conf;
|
|
struct iwl_ht_info *iwl_conf = &priv->current_ht_config;
|
|
|
|
@@ -574,27 +574,27 @@ static void iwl4965_ht_conf(struct iwl_p
|
|
!!(ht_conf->cap & IEEE80211_HT_CAP_MAX_AMSDU);
|
|
|
|
iwl_conf->supported_chan_width =
|
|
- !!(ht_conf->cap & IEEE80211_HT_CAP_SUP_WIDTH);
|
|
+ !!(ht_conf->cap & IEEE80211_HT_CAP_SUP_WIDTH_20_40);
|
|
iwl_conf->extension_chan_offset =
|
|
- ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_SEC_OFFSET;
|
|
+ ht_bss_conf->bss_cap & IEEE80211_HT_PARAM_CHA_SEC_OFFSET;
|
|
/* If no above or below channel supplied disable FAT channel */
|
|
- if (iwl_conf->extension_chan_offset != IEEE80211_HT_IE_CHA_SEC_ABOVE &&
|
|
- iwl_conf->extension_chan_offset != IEEE80211_HT_IE_CHA_SEC_BELOW) {
|
|
- iwl_conf->extension_chan_offset = IEEE80211_HT_IE_CHA_SEC_NONE;
|
|
+ if (iwl_conf->extension_chan_offset != IEEE80211_HT_PARAM_CHA_SEC_ABOVE &&
|
|
+ iwl_conf->extension_chan_offset != IEEE80211_HT_PARAM_CHA_SEC_BELOW) {
|
|
+ iwl_conf->extension_chan_offset = IEEE80211_HT_PARAM_CHA_SEC_NONE;
|
|
iwl_conf->supported_chan_width = 0;
|
|
}
|
|
|
|
iwl_conf->sm_ps = (u8)((ht_conf->cap & IEEE80211_HT_CAP_SM_PS) >> 2);
|
|
|
|
- memcpy(iwl_conf->supp_mcs_set, ht_conf->supp_mcs_set, 16);
|
|
+ memcpy(&iwl_conf->mcs, &ht_conf->mcs, 16);
|
|
|
|
iwl_conf->control_channel = ht_bss_conf->primary_channel;
|
|
iwl_conf->tx_chan_width =
|
|
- !!(ht_bss_conf->bss_cap & IEEE80211_HT_IE_CHA_WIDTH);
|
|
+ !!(ht_bss_conf->bss_cap & IEEE80211_HT_PARAM_CHAN_WIDTH_ANY);
|
|
iwl_conf->ht_protection =
|
|
- ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_HT_PROTECTION;
|
|
+ ht_bss_conf->bss_op_mode & IEEE80211_HT_OP_MODE_PROTECTION;
|
|
iwl_conf->non_GF_STA_present =
|
|
- !!(ht_bss_conf->bss_op_mode & IEEE80211_HT_IE_NON_GF_STA_PRSNT);
|
|
+ !!(ht_bss_conf->bss_op_mode & IEEE80211_HT_OP_MODE_NON_GF_STA_PRSNT);
|
|
|
|
IWL_DEBUG_MAC80211("control channel %d\n", iwl_conf->control_channel);
|
|
IWL_DEBUG_MAC80211("leave\n");
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-core.c 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-core.c 2008-10-09 02:16:26.000000000 +0200
|
|
@@ -382,10 +382,10 @@ void iwl_reset_qos(struct iwl_priv *priv
|
|
}
|
|
EXPORT_SYMBOL(iwl_reset_qos);
|
|
|
|
-#define MAX_BIT_RATE_40_MHZ 0x96 /* 150 Mbps */
|
|
-#define MAX_BIT_RATE_20_MHZ 0x48 /* 72 Mbps */
|
|
+#define MAX_BIT_RATE_40_MHZ 150 /* Mbps */
|
|
+#define MAX_BIT_RATE_20_MHZ 72 /* Mbps */
|
|
static void iwlcore_init_ht_hw_capab(const struct iwl_priv *priv,
|
|
- struct ieee80211_ht_info *ht_info,
|
|
+ struct ieee80211_sta_ht_cap *ht_info,
|
|
enum ieee80211_band band)
|
|
{
|
|
u16 max_bit_rate = 0;
|
|
@@ -393,45 +393,46 @@ static void iwlcore_init_ht_hw_capab(con
|
|
u8 tx_chains_num = priv->hw_params.tx_chains_num;
|
|
|
|
ht_info->cap = 0;
|
|
- memset(ht_info->supp_mcs_set, 0, 16);
|
|
+ memset(&ht_info->mcs, 0, sizeof(ht_info->mcs));
|
|
|
|
- ht_info->ht_supported = 1;
|
|
+ ht_info->ht_supported = true;
|
|
|
|
- ht_info->cap |= (u16)IEEE80211_HT_CAP_GRN_FLD;
|
|
- ht_info->cap |= (u16)IEEE80211_HT_CAP_SGI_20;
|
|
- ht_info->cap |= (u16)(IEEE80211_HT_CAP_SM_PS &
|
|
+ ht_info->cap |= IEEE80211_HT_CAP_GRN_FLD;
|
|
+ ht_info->cap |= IEEE80211_HT_CAP_SGI_20;
|
|
+ ht_info->cap |= (IEEE80211_HT_CAP_SM_PS &
|
|
(WLAN_HT_CAP_SM_PS_DISABLED << 2));
|
|
|
|
max_bit_rate = MAX_BIT_RATE_20_MHZ;
|
|
if (priv->hw_params.fat_channel & BIT(band)) {
|
|
- ht_info->cap |= (u16)IEEE80211_HT_CAP_SUP_WIDTH;
|
|
- ht_info->cap |= (u16)IEEE80211_HT_CAP_SGI_40;
|
|
- ht_info->supp_mcs_set[4] = 0x01;
|
|
+ ht_info->cap |= IEEE80211_HT_CAP_SUP_WIDTH_20_40;
|
|
+ ht_info->cap |= IEEE80211_HT_CAP_SGI_40;
|
|
+ ht_info->mcs.rx_mask[4] = 0x01;
|
|
max_bit_rate = MAX_BIT_RATE_40_MHZ;
|
|
}
|
|
|
|
if (priv->cfg->mod_params->amsdu_size_8K)
|
|
- ht_info->cap |= (u16)IEEE80211_HT_CAP_MAX_AMSDU;
|
|
+ ht_info->cap |= IEEE80211_HT_CAP_MAX_AMSDU;
|
|
|
|
ht_info->ampdu_factor = CFG_HT_RX_AMPDU_FACTOR_DEF;
|
|
ht_info->ampdu_density = CFG_HT_MPDU_DENSITY_DEF;
|
|
|
|
- ht_info->supp_mcs_set[0] = 0xFF;
|
|
+ ht_info->mcs.rx_mask[0] = 0xFF;
|
|
if (rx_chains_num >= 2)
|
|
- ht_info->supp_mcs_set[1] = 0xFF;
|
|
+ ht_info->mcs.rx_mask[1] = 0xFF;
|
|
if (rx_chains_num >= 3)
|
|
- ht_info->supp_mcs_set[2] = 0xFF;
|
|
+ ht_info->mcs.rx_mask[2] = 0xFF;
|
|
|
|
/* Highest supported Rx data rate */
|
|
max_bit_rate *= rx_chains_num;
|
|
- ht_info->supp_mcs_set[10] = (u8)(max_bit_rate & 0x00FF);
|
|
- ht_info->supp_mcs_set[11] = (u8)((max_bit_rate & 0xFF00) >> 8);
|
|
+ WARN_ON(max_bit_rate & ~IEEE80211_HT_MCS_RX_HIGHEST_MASK);
|
|
+ ht_info->mcs.rx_highest = cpu_to_le16(max_bit_rate);
|
|
|
|
/* Tx MCS capabilities */
|
|
- ht_info->supp_mcs_set[12] = IEEE80211_HT_CAP_MCS_TX_DEFINED;
|
|
+ ht_info->mcs.tx_params = IEEE80211_HT_MCS_TX_DEFINED;
|
|
if (tx_chains_num != rx_chains_num) {
|
|
- ht_info->supp_mcs_set[12] |= IEEE80211_HT_CAP_MCS_TX_RX_DIFF;
|
|
- ht_info->supp_mcs_set[12] |= ((tx_chains_num - 1) << 2);
|
|
+ ht_info->mcs.tx_params |= IEEE80211_HT_MCS_TX_RX_DIFF;
|
|
+ ht_info->mcs.tx_params |= ((tx_chains_num - 1) <<
|
|
+ IEEE80211_HT_MCS_TX_MAX_STREAMS_SHIFT);
|
|
}
|
|
}
|
|
|
|
@@ -495,7 +496,7 @@ static int iwlcore_init_geos(struct iwl_
|
|
sband->n_bitrates = IWL_RATE_COUNT - IWL_FIRST_OFDM_RATE;
|
|
|
|
if (priv->cfg->sku & IWL_SKU_N)
|
|
- iwlcore_init_ht_hw_capab(priv, &sband->ht_info,
|
|
+ iwlcore_init_ht_hw_capab(priv, &sband->ht_cap,
|
|
IEEE80211_BAND_5GHZ);
|
|
|
|
sband = &priv->bands[IEEE80211_BAND_2GHZ];
|
|
@@ -505,7 +506,7 @@ static int iwlcore_init_geos(struct iwl_
|
|
sband->n_bitrates = IWL_RATE_COUNT;
|
|
|
|
if (priv->cfg->sku & IWL_SKU_N)
|
|
- iwlcore_init_ht_hw_capab(priv, &sband->ht_info,
|
|
+ iwlcore_init_ht_hw_capab(priv, &sband->ht_cap,
|
|
IEEE80211_BAND_2GHZ);
|
|
|
|
priv->ieee_channels = channels;
|
|
@@ -595,8 +596,8 @@ static void iwlcore_free_geos(struct iwl
|
|
static bool is_single_rx_stream(struct iwl_priv *priv)
|
|
{
|
|
return !priv->current_ht_config.is_ht ||
|
|
- ((priv->current_ht_config.supp_mcs_set[1] == 0) &&
|
|
- (priv->current_ht_config.supp_mcs_set[2] == 0));
|
|
+ ((priv->current_ht_config.mcs.rx_mask[1] == 0) &&
|
|
+ (priv->current_ht_config.mcs.rx_mask[2] == 0));
|
|
}
|
|
|
|
static u8 iwl_is_channel_extension(struct iwl_priv *priv,
|
|
@@ -609,10 +610,10 @@ static u8 iwl_is_channel_extension(struc
|
|
if (!is_channel_valid(ch_info))
|
|
return 0;
|
|
|
|
- if (extension_chan_offset == IEEE80211_HT_IE_CHA_SEC_ABOVE)
|
|
+ if (extension_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_ABOVE)
|
|
return !(ch_info->fat_extension_channel &
|
|
IEEE80211_CHAN_NO_FAT_ABOVE);
|
|
- else if (extension_chan_offset == IEEE80211_HT_IE_CHA_SEC_BELOW)
|
|
+ else if (extension_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_BELOW)
|
|
return !(ch_info->fat_extension_channel &
|
|
IEEE80211_CHAN_NO_FAT_BELOW);
|
|
|
|
@@ -620,18 +621,18 @@ static u8 iwl_is_channel_extension(struc
|
|
}
|
|
|
|
u8 iwl_is_fat_tx_allowed(struct iwl_priv *priv,
|
|
- struct ieee80211_ht_info *sta_ht_inf)
|
|
+ struct ieee80211_sta_ht_cap *sta_ht_inf)
|
|
{
|
|
struct iwl_ht_info *iwl_ht_conf = &priv->current_ht_config;
|
|
|
|
if ((!iwl_ht_conf->is_ht) ||
|
|
(iwl_ht_conf->supported_chan_width != IWL_CHANNEL_WIDTH_40MHZ) ||
|
|
- (iwl_ht_conf->extension_chan_offset == IEEE80211_HT_IE_CHA_SEC_NONE))
|
|
+ (iwl_ht_conf->extension_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_NONE))
|
|
return 0;
|
|
|
|
if (sta_ht_inf) {
|
|
if ((!sta_ht_inf->ht_supported) ||
|
|
- (!(sta_ht_inf->cap & IEEE80211_HT_CAP_SUP_WIDTH)))
|
|
+ (!(sta_ht_inf->cap & IEEE80211_HT_CAP_SUP_WIDTH_20_40)))
|
|
return 0;
|
|
}
|
|
|
|
@@ -671,13 +672,13 @@ void iwl_set_rxon_ht(struct iwl_priv *pr
|
|
|
|
/* Note: control channel is opposite of extension channel */
|
|
switch (ht_info->extension_chan_offset) {
|
|
- case IEEE80211_HT_IE_CHA_SEC_ABOVE:
|
|
+ case IEEE80211_HT_PARAM_CHA_SEC_ABOVE:
|
|
rxon->flags &= ~(RXON_FLG_CTRL_CHANNEL_LOC_HI_MSK);
|
|
break;
|
|
- case IEEE80211_HT_IE_CHA_SEC_BELOW:
|
|
+ case IEEE80211_HT_PARAM_CHA_SEC_BELOW:
|
|
rxon->flags |= RXON_FLG_CTRL_CHANNEL_LOC_HI_MSK;
|
|
break;
|
|
- case IEEE80211_HT_IE_CHA_SEC_NONE:
|
|
+ case IEEE80211_HT_PARAM_CHA_SEC_NONE:
|
|
default:
|
|
rxon->flags &= ~RXON_FLG_CHANNEL_MODE_MIXED_MSK;
|
|
break;
|
|
@@ -693,9 +694,9 @@ void iwl_set_rxon_ht(struct iwl_priv *pr
|
|
"rxon flags 0x%X operation mode :0x%X "
|
|
"extension channel offset 0x%x "
|
|
"control chan %d\n",
|
|
- ht_info->supp_mcs_set[0],
|
|
- ht_info->supp_mcs_set[1],
|
|
- ht_info->supp_mcs_set[2],
|
|
+ ht_info->mcs.rx_mask[0],
|
|
+ ht_info->mcs.rx_mask[1],
|
|
+ ht_info->mcs.rx_mask[2],
|
|
le32_to_cpu(rxon->flags), ht_info->ht_protection,
|
|
ht_info->extension_chan_offset,
|
|
ht_info->control_channel);
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-core.h 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-core.h 2008-10-08 20:45:06.000000000 +0200
|
|
@@ -190,7 +190,7 @@ void iwl_set_rxon_chain(struct iwl_priv
|
|
int iwl_set_rxon_channel(struct iwl_priv *priv, struct ieee80211_channel *ch);
|
|
void iwl_set_rxon_ht(struct iwl_priv *priv, struct iwl_ht_info *ht_info);
|
|
u8 iwl_is_fat_tx_allowed(struct iwl_priv *priv,
|
|
- struct ieee80211_ht_info *sta_ht_inf);
|
|
+ struct ieee80211_sta_ht_cap *sta_ht_inf);
|
|
int iwl_hw_nic_init(struct iwl_priv *priv);
|
|
int iwl_setup_mac(struct iwl_priv *priv);
|
|
int iwl_set_hw_params(struct iwl_priv *priv);
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-dev.h 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-dev.h 2008-10-09 02:16:27.000000000 +0200
|
|
@@ -412,7 +412,7 @@ struct iwl_ht_info {
|
|
u8 max_amsdu_size;
|
|
u8 ampdu_factor;
|
|
u8 mpdu_density;
|
|
- u8 supp_mcs_set[16];
|
|
+ struct ieee80211_mcs_info mcs;
|
|
/* BSS related data */
|
|
u8 control_channel;
|
|
u8 extension_chan_offset;
|
|
@@ -584,7 +584,7 @@ struct iwl_addsta_cmd;
|
|
extern int iwl_send_add_sta(struct iwl_priv *priv,
|
|
struct iwl_addsta_cmd *sta, u8 flags);
|
|
extern u8 iwl_add_station_flags(struct iwl_priv *priv, const u8 *addr,
|
|
- int is_ap, u8 flags, struct ieee80211_ht_info *ht_info);
|
|
+ int is_ap, u8 flags, struct ieee80211_sta_ht_cap *ht_info);
|
|
extern void iwl4965_update_chain_flags(struct iwl_priv *priv);
|
|
extern int iwl4965_set_pwr_src(struct iwl_priv *priv, enum iwl_pwr_src src);
|
|
extern const u8 iwl_bcast_addr[ETH_ALEN];
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-sta.c 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-sta.c 2008-10-09 02:16:29.000000000 +0200
|
|
@@ -183,7 +183,7 @@ int iwl_send_add_sta(struct iwl_priv *pr
|
|
EXPORT_SYMBOL(iwl_send_add_sta);
|
|
|
|
static void iwl_set_ht_add_station(struct iwl_priv *priv, u8 index,
|
|
- struct ieee80211_ht_info *sta_ht_inf)
|
|
+ struct ieee80211_sta_ht_cap *sta_ht_inf)
|
|
{
|
|
__le32 sta_flags;
|
|
u8 mimo_ps_mode;
|
|
@@ -231,7 +231,7 @@ static void iwl_set_ht_add_station(struc
|
|
* iwl_add_station_flags - Add station to tables in driver and device
|
|
*/
|
|
u8 iwl_add_station_flags(struct iwl_priv *priv, const u8 *addr, int is_ap,
|
|
- u8 flags, struct ieee80211_ht_info *ht_info)
|
|
+ u8 flags, struct ieee80211_sta_ht_cap *ht_info)
|
|
{
|
|
int i;
|
|
int sta_id = IWL_INVALID_STATION;
|
|
@@ -900,7 +900,7 @@ int iwl_rxon_add_station(struct iwl_priv
|
|
|
|
/* Add station to device's station table */
|
|
struct ieee80211_conf *conf = &priv->hw->conf;
|
|
- struct ieee80211_ht_info *cur_ht_config = &conf->ht_conf;
|
|
+ struct ieee80211_sta_ht_cap *cur_ht_config = &conf->ht_cap;
|
|
|
|
if ((is_ap) &&
|
|
(conf->flags & IEEE80211_CONF_SUPPORT_HT_MODE) &&
|
|
--- everything.orig/drivers/net/wireless/iwlwifi/iwl-scan.c 2008-10-08 20:44:47.000000000 +0200
|
|
+++ everything/drivers/net/wireless/iwlwifi/iwl-scan.c 2008-10-08 20:45:06.000000000 +0200
|
|
@@ -550,7 +550,7 @@ static void iwl_ht_cap_to_ie(const struc
|
|
{
|
|
struct ieee80211_ht_cap *ht_cap;
|
|
|
|
- if (!sband || !sband->ht_info.ht_supported)
|
|
+ if (!sband || !sband->ht_cap.ht_supported)
|
|
return;
|
|
|
|
if (*left < sizeof(struct ieee80211_ht_cap))
|
|
@@ -559,12 +559,12 @@ static void iwl_ht_cap_to_ie(const struc
|
|
*pos++ = sizeof(struct ieee80211_ht_cap);
|
|
ht_cap = (struct ieee80211_ht_cap *) pos;
|
|
|
|
- ht_cap->cap_info = cpu_to_le16(sband->ht_info.cap);
|
|
- memcpy(ht_cap->supp_mcs_set, sband->ht_info.supp_mcs_set, 16);
|
|
+ ht_cap->cap_info = cpu_to_le16(sband->ht_cap.cap);
|
|
+ memcpy(&ht_cap->mcs, &sband->ht_cap.mcs, 16);
|
|
ht_cap->ampdu_params_info =
|
|
- (sband->ht_info.ampdu_factor & IEEE80211_HT_CAP_AMPDU_FACTOR) |
|
|
- ((sband->ht_info.ampdu_density << 2) &
|
|
- IEEE80211_HT_CAP_AMPDU_DENSITY);
|
|
+ (sband->ht_cap.ampdu_factor & IEEE80211_HT_AMPDU_PARM_FACTOR) |
|
|
+ ((sband->ht_cap.ampdu_density << 2) &
|
|
+ IEEE80211_HT_AMPDU_PARM_DENSITY);
|
|
*left -= sizeof(struct ieee80211_ht_cap);
|
|
}
|
|
|
|
--- everything.orig/drivers/net/wireless/ath9k/main.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/ath9k/main.c 2008-10-09 02:16:30.000000000 +0200
|
|
@@ -61,24 +61,24 @@ static u32 ath_get_extchanmode(struct at
|
|
|
|
switch (chan->band) {
|
|
case IEEE80211_BAND_2GHZ:
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_NONE) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_NONE) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_20))
|
|
chanmode = CHANNEL_G_HT20;
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_ABOVE) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_ABOVE) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_2040))
|
|
chanmode = CHANNEL_G_HT40PLUS;
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_BELOW) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_BELOW) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_2040))
|
|
chanmode = CHANNEL_G_HT40MINUS;
|
|
break;
|
|
case IEEE80211_BAND_5GHZ:
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_NONE) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_NONE) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_20))
|
|
chanmode = CHANNEL_A_HT20;
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_ABOVE) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_ABOVE) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_2040))
|
|
chanmode = CHANNEL_A_HT40PLUS;
|
|
- if ((ext_chan_offset == IEEE80211_HT_IE_CHA_SEC_BELOW) &&
|
|
+ if ((ext_chan_offset == IEEE80211_HT_PARAM_CHA_SEC_BELOW) &&
|
|
(tx_chan_width == ATH9K_HT_MACMODE_2040))
|
|
chanmode = CHANNEL_A_HT40MINUS;
|
|
break;
|
|
@@ -215,24 +215,24 @@ static void ath_key_delete(struct ath_so
|
|
ath_key_reset(sc, key->keyidx, freeslot);
|
|
}
|
|
|
|
-static void setup_ht_cap(struct ieee80211_ht_info *ht_info)
|
|
+static void setup_ht_cap(struct ieee80211_sta_ht_cap *ht_info)
|
|
{
|
|
#define ATH9K_HT_CAP_MAXRXAMPDU_65536 0x3 /* 2 ^ 16 */
|
|
#define ATH9K_HT_CAP_MPDUDENSITY_8 0x6 /* 8 usec */
|
|
|
|
- ht_info->ht_supported = 1;
|
|
- ht_info->cap = (u16)IEEE80211_HT_CAP_SUP_WIDTH
|
|
- |(u16)IEEE80211_HT_CAP_SM_PS
|
|
- |(u16)IEEE80211_HT_CAP_SGI_40
|
|
- |(u16)IEEE80211_HT_CAP_DSSSCCK40;
|
|
+ ht_info->ht_supported = true;
|
|
+ ht_info->cap = IEEE80211_HT_CAP_SUP_WIDTH_20_40 |
|
|
+ IEEE80211_HT_CAP_SM_PS |
|
|
+ IEEE80211_HT_CAP_SGI_40 |
|
|
+ IEEE80211_HT_CAP_DSSSCCK40;
|
|
|
|
ht_info->ampdu_factor = ATH9K_HT_CAP_MAXRXAMPDU_65536;
|
|
ht_info->ampdu_density = ATH9K_HT_CAP_MPDUDENSITY_8;
|
|
- /* setup supported mcs set */
|
|
- memset(ht_info->supp_mcs_set, 0, 16);
|
|
- ht_info->supp_mcs_set[0] = 0xff;
|
|
- ht_info->supp_mcs_set[1] = 0xff;
|
|
- ht_info->supp_mcs_set[12] = IEEE80211_HT_CAP_MCS_TX_DEFINED;
|
|
+ /* set up supported mcs set */
|
|
+ memset(&ht_info->mcs, 0, sizeof(ht_info->mcs));
|
|
+ ht_info->mcs.rx_mask[0] = 0xff;
|
|
+ ht_info->mcs.rx_mask[1] = 0xff;
|
|
+ ht_info->mcs.tx_params = IEEE80211_HT_MCS_TX_DEFINED;
|
|
}
|
|
|
|
static int ath_rate2idx(struct ath_softc *sc, int rate)
|
|
@@ -328,31 +328,28 @@ static u8 parse_mpdudensity(u8 mpdudensi
|
|
static void ath9k_ht_conf(struct ath_softc *sc,
|
|
struct ieee80211_bss_conf *bss_conf)
|
|
{
|
|
-#define IEEE80211_HT_CAP_40MHZ_INTOLERANT BIT(14)
|
|
struct ath_ht_info *ht_info = &sc->sc_ht_info;
|
|
|
|
if (bss_conf->assoc_ht) {
|
|
ht_info->ext_chan_offset =
|
|
bss_conf->ht_bss_conf->bss_cap &
|
|
- IEEE80211_HT_IE_CHA_SEC_OFFSET;
|
|
+ IEEE80211_HT_PARAM_CHA_SEC_OFFSET;
|
|
|
|
- if (!(bss_conf->ht_conf->cap &
|
|
+ if (!(bss_conf->ht_cap->cap &
|
|
IEEE80211_HT_CAP_40MHZ_INTOLERANT) &&
|
|
(bss_conf->ht_bss_conf->bss_cap &
|
|
- IEEE80211_HT_IE_CHA_WIDTH))
|
|
+ IEEE80211_HT_PARAM_CHAN_WIDTH_ANY))
|
|
ht_info->tx_chan_width = ATH9K_HT_MACMODE_2040;
|
|
else
|
|
ht_info->tx_chan_width = ATH9K_HT_MACMODE_20;
|
|
|
|
ath9k_hw_set11nmac2040(sc->sc_ah, ht_info->tx_chan_width);
|
|
ht_info->maxampdu = 1 << (IEEE80211_HTCAP_MAXRXAMPDU_FACTOR +
|
|
- bss_conf->ht_conf->ampdu_factor);
|
|
+ bss_conf->ht_cap->ampdu_factor);
|
|
ht_info->mpdudensity =
|
|
- parse_mpdudensity(bss_conf->ht_conf->ampdu_density);
|
|
+ parse_mpdudensity(bss_conf->ht_cap->ampdu_density);
|
|
|
|
}
|
|
-
|
|
-#undef IEEE80211_HT_CAP_40MHZ_INTOLERANT
|
|
}
|
|
|
|
static void ath9k_bss_assoc_info(struct ath_softc *sc,
|
|
@@ -412,7 +409,7 @@ static void ath9k_bss_assoc_info(struct
|
|
return;
|
|
}
|
|
|
|
- if (hw->conf.ht_conf.ht_supported)
|
|
+ if (hw->conf.ht_cap.ht_supported)
|
|
sc->sc_ah->ah_channels[pos].chanmode =
|
|
ath_get_extchanmode(sc, curchan);
|
|
else
|
|
@@ -535,7 +532,7 @@ int _ath_rx_indicate(struct ath_softc *s
|
|
|
|
if (an) {
|
|
ath_rx_input(sc, an,
|
|
- hw->conf.ht_conf.ht_supported,
|
|
+ hw->conf.ht_cap.ht_supported,
|
|
skb, status, &st);
|
|
}
|
|
if (!an || (st != ATH_RX_CONSUMED))
|
|
@@ -944,7 +941,7 @@ static int ath_attach(u16 devid,
|
|
|
|
if (sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT)
|
|
/* Setup HT capabilities for 2.4Ghz*/
|
|
- setup_ht_cap(&sc->sbands[IEEE80211_BAND_2GHZ].ht_info);
|
|
+ setup_ht_cap(&sc->sbands[IEEE80211_BAND_2GHZ].ht_cap);
|
|
|
|
hw->wiphy->bands[IEEE80211_BAND_2GHZ] =
|
|
&sc->sbands[IEEE80211_BAND_2GHZ];
|
|
@@ -959,7 +956,7 @@ static int ath_attach(u16 devid,
|
|
|
|
if (sc->sc_ah->ah_caps.hw_caps & ATH9K_HW_CAP_HT)
|
|
/* Setup HT capabilities for 5Ghz*/
|
|
- setup_ht_cap(&sc->sbands[IEEE80211_BAND_5GHZ].ht_info);
|
|
+ setup_ht_cap(&sc->sbands[IEEE80211_BAND_5GHZ].ht_cap);
|
|
|
|
hw->wiphy->bands[IEEE80211_BAND_5GHZ] =
|
|
&sc->sbands[IEEE80211_BAND_5GHZ];
|
|
@@ -1255,7 +1252,7 @@ static int ath9k_config(struct ieee80211
|
|
(curchan->band == IEEE80211_BAND_2GHZ) ?
|
|
CHANNEL_G : CHANNEL_A;
|
|
|
|
- if (sc->sc_curaid && hw->conf.ht_conf.ht_supported)
|
|
+ if (sc->sc_curaid && hw->conf.ht_cap.ht_supported)
|
|
sc->sc_ah->ah_channels[pos].chanmode =
|
|
ath_get_extchanmode(sc, curchan);
|
|
|
|
--- everything.orig/drivers/net/wireless/ath9k/rc.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/ath9k/rc.c 2008-10-09 02:16:27.000000000 +0200
|
|
@@ -1838,7 +1838,7 @@ void ath_rc_node_update(struct ieee80211
|
|
struct ath_softc *sc = hw->priv;
|
|
u32 capflag = 0;
|
|
|
|
- if (hw->conf.ht_conf.ht_supported) {
|
|
+ if (hw->conf.ht_cap.ht_supported) {
|
|
capflag |= ATH_RC_HT_FLAG | ATH_RC_DS_FLAG;
|
|
if (sc->sc_ht_info.tx_chan_width == ATH9K_HT_MACMODE_2040)
|
|
capflag |= ATH_RC_CW40_FLAG;
|
|
@@ -1910,7 +1910,7 @@ static void ath_tx_aggr_resp(struct ath_
|
|
*/
|
|
si = container_of(sta, struct sta_info, sta);
|
|
buffersize = IEEE80211_MIN_AMPDU_BUF <<
|
|
- sband->ht_info.ampdu_factor; /* FIXME */
|
|
+ sband->ht_cap.ampdu_factor; /* FIXME */
|
|
state = si->ampdu_mlme.tid_state_tx[tidno];
|
|
|
|
if (state & HT_ADDBA_RECEIVED_MSK) {
|
|
@@ -1980,7 +1980,7 @@ static void ath_get_rate(void *priv, str
|
|
|
|
/* Check if aggregation has to be enabled for this tid */
|
|
|
|
- if (hw->conf.ht_conf.ht_supported) {
|
|
+ if (hw->conf.ht_cap.ht_supported) {
|
|
if (ieee80211_is_data_qos(fc)) {
|
|
qc = ieee80211_get_qos_ctl(hdr);
|
|
tid = qc[0] & 0xf;
|
|
@@ -2028,8 +2028,8 @@ static void ath_rate_init(void *priv, st
|
|
|
|
ath_setup_rates(sc, sband, sta, ath_rc_priv);
|
|
if (sc->hw->conf.flags & IEEE80211_CONF_SUPPORT_HT_MODE) {
|
|
- for (i = 0; i < MCS_SET_SIZE; i++) {
|
|
- if (sc->hw->conf.ht_conf.supp_mcs_set[i/8] & (1<<(i%8)))
|
|
+ for (i = 0; i < 77; i++) {
|
|
+ if (sc->hw->conf.ht_cap.mcs.rx_mask[i/8] & (1<<(i%8)))
|
|
ath_rc_priv->neg_ht_rates.rs_rates[j++] = i;
|
|
if (j == ATH_RATE_MAX)
|
|
break;
|
|
--- everything.orig/drivers/net/wireless/ath9k/recv.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/ath9k/recv.c 2008-10-09 02:16:27.000000000 +0200
|
|
@@ -1119,7 +1119,7 @@ int ath_rx_aggr_start(struct ath_softc *
|
|
|
|
sband = hw->wiphy->bands[hw->conf.channel->band];
|
|
buffersize = IEEE80211_MIN_AMPDU_BUF <<
|
|
- sband->ht_info.ampdu_factor; /* FIXME */
|
|
+ sband->ht_cap.ampdu_factor; /* FIXME */
|
|
|
|
rxtid = &an->an_aggr.rx.tid[tid];
|
|
|
|
--- everything.orig/drivers/net/wireless/ath9k/xmit.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/ath9k/xmit.c 2008-10-09 02:16:27.000000000 +0200
|
|
@@ -300,7 +300,7 @@ static int ath_tx_prepare(struct ath_sof
|
|
if (ieee80211_is_data(fc) && !txctl->use_minrate) {
|
|
|
|
/* Enable HT only for DATA frames and not for EAPOL */
|
|
- txctl->ht = (hw->conf.ht_conf.ht_supported &&
|
|
+ txctl->ht = (hw->conf.ht_cap.ht_supported &&
|
|
(tx_info->flags & IEEE80211_TX_CTL_AMPDU));
|
|
|
|
if (is_multicast_ether_addr(hdr->addr1)) {
|
|
--- everything.orig/drivers/net/wireless/ath9k/rc.h 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/ath9k/rc.h 2008-10-08 20:45:06.000000000 +0200
|
|
@@ -59,7 +59,6 @@ struct ath_softc;
|
|
#define FALSE 0
|
|
|
|
#define ATH_RATE_MAX 30
|
|
-#define MCS_SET_SIZE 128
|
|
|
|
enum ieee80211_fixed_rate_mode {
|
|
IEEE80211_FIXED_RATE_NONE = 0,
|
|
--- everything.orig/drivers/net/wireless/mac80211_hwsim.c 2008-10-08 20:44:48.000000000 +0200
|
|
+++ everything/drivers/net/wireless/mac80211_hwsim.c 2008-10-09 02:16:30.000000000 +0200
|
|
@@ -566,19 +566,18 @@ static int __init init_mac80211_hwsim(vo
|
|
data->band.n_channels = ARRAY_SIZE(hwsim_channels);
|
|
data->band.bitrates = data->rates;
|
|
data->band.n_bitrates = ARRAY_SIZE(hwsim_rates);
|
|
- data->band.ht_info.ht_supported = 1;
|
|
- data->band.ht_info.cap = IEEE80211_HT_CAP_SUP_WIDTH |
|
|
+ data->band.ht_cap.ht_supported = true;
|
|
+ data->band.ht_cap.cap = IEEE80211_HT_CAP_SUP_WIDTH_20_40 |
|
|
IEEE80211_HT_CAP_GRN_FLD |
|
|
IEEE80211_HT_CAP_SGI_40 |
|
|
IEEE80211_HT_CAP_DSSSCCK40;
|
|
- data->band.ht_info.ampdu_factor = 0x3;
|
|
- data->band.ht_info.ampdu_density = 0x6;
|
|
- memset(data->band.ht_info.supp_mcs_set, 0,
|
|
- sizeof(data->band.ht_info.supp_mcs_set));
|
|
- data->band.ht_info.supp_mcs_set[0] = 0xff;
|
|
- data->band.ht_info.supp_mcs_set[1] = 0xff;
|
|
- data->band.ht_info.supp_mcs_set[12] =
|
|
- IEEE80211_HT_CAP_MCS_TX_DEFINED;
|
|
+ data->band.ht_cap.ampdu_factor = 0x3;
|
|
+ data->band.ht_cap.ampdu_density = 0x6;
|
|
+ memset(&data->band.ht_cap.mcs, 0,
|
|
+ sizeof(data->band.ht_cap.mcs));
|
|
+ data->band.ht_cap.mcs.rx_mask[0] = 0xff;
|
|
+ data->band.ht_cap.mcs.rx_mask[1] = 0xff;
|
|
+ data->band.ht_cap.mcs.tx_params = IEEE80211_HT_MCS_TX_DEFINED;
|
|
hw->wiphy->bands[IEEE80211_BAND_2GHZ] = &data->band;
|
|
|
|
err = ieee80211_register_hw(hw);
|