diff options
author | Johannes Berg <johannes.berg@intel.com> | 2011-10-10 10:26:54 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2011-10-14 14:48:10 -0400 |
commit | c079166e1bb5d8e8ee9ee25f5a2ea3ff457ead65 (patch) | |
tree | 159b5a3fd40b9f89d2c0e46d29a8188c897bebe3 /drivers/net/wireless/iwlwifi/iwl-agn-sta.c | |
parent | 164ae97eb5be612b58b2b1b395bb8287f555c661 (diff) |
iwlagn: send simple LQ command for WoWLAN
For some reason, WoWLAN doesn't always seem to
be happy with more advanced LQ commands. Since
we don't need them as we're not going to send
a lot of data, simply program the station with
the very simple default LQ command.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Wey-Yi Guy <wey-yi.w.guy@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/iwlwifi/iwl-agn-sta.c')
-rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn-sta.c | 27 |
1 files changed, 18 insertions, 9 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-sta.c b/drivers/net/wireless/iwlwifi/iwl-agn-sta.c index 8f0b86de1863..8e7177b38e87 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn-sta.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn-sta.c | |||
@@ -35,22 +35,17 @@ | |||
35 | #include "iwl-agn.h" | 35 | #include "iwl-agn.h" |
36 | #include "iwl-trans.h" | 36 | #include "iwl-trans.h" |
37 | 37 | ||
38 | static struct iwl_link_quality_cmd * | 38 | void iwl_sta_fill_lq(struct iwl_priv *priv, struct iwl_rxon_context *ctx, |
39 | iwl_sta_alloc_lq(struct iwl_priv *priv, struct iwl_rxon_context *ctx, u8 sta_id) | 39 | u8 sta_id, struct iwl_link_quality_cmd *link_cmd) |
40 | { | 40 | { |
41 | int i, r; | 41 | int i, r; |
42 | struct iwl_link_quality_cmd *link_cmd; | ||
43 | u32 rate_flags = 0; | 42 | u32 rate_flags = 0; |
44 | __le32 rate_n_flags; | 43 | __le32 rate_n_flags; |
45 | 44 | ||
46 | link_cmd = kzalloc(sizeof(struct iwl_link_quality_cmd), GFP_KERNEL); | ||
47 | if (!link_cmd) { | ||
48 | IWL_ERR(priv, "Unable to allocate memory for LQ cmd.\n"); | ||
49 | return NULL; | ||
50 | } | ||
51 | |||
52 | lockdep_assert_held(&priv->shrd->mutex); | 45 | lockdep_assert_held(&priv->shrd->mutex); |
53 | 46 | ||
47 | memset(link_cmd, 0, sizeof(*link_cmd)); | ||
48 | |||
54 | /* Set up the rate scaling to start at selected rate, fall back | 49 | /* Set up the rate scaling to start at selected rate, fall back |
55 | * all the way down to 1M in IEEE order, and then spin on 1M */ | 50 | * all the way down to 1M in IEEE order, and then spin on 1M */ |
56 | if (priv->band == IEEE80211_BAND_5GHZ) | 51 | if (priv->band == IEEE80211_BAND_5GHZ) |
@@ -87,6 +82,20 @@ iwl_sta_alloc_lq(struct iwl_priv *priv, struct iwl_rxon_context *ctx, u8 sta_id) | |||
87 | cpu_to_le16(LINK_QUAL_AGG_TIME_LIMIT_DEF); | 82 | cpu_to_le16(LINK_QUAL_AGG_TIME_LIMIT_DEF); |
88 | 83 | ||
89 | link_cmd->sta_id = sta_id; | 84 | link_cmd->sta_id = sta_id; |
85 | } | ||
86 | |||
87 | static struct iwl_link_quality_cmd * | ||
88 | iwl_sta_alloc_lq(struct iwl_priv *priv, struct iwl_rxon_context *ctx, u8 sta_id) | ||
89 | { | ||
90 | struct iwl_link_quality_cmd *link_cmd; | ||
91 | |||
92 | link_cmd = kzalloc(sizeof(struct iwl_link_quality_cmd), GFP_KERNEL); | ||
93 | if (!link_cmd) { | ||
94 | IWL_ERR(priv, "Unable to allocate memory for LQ cmd.\n"); | ||
95 | return NULL; | ||
96 | } | ||
97 | |||
98 | iwl_sta_fill_lq(priv, ctx, sta_id, link_cmd); | ||
90 | 99 | ||
91 | return link_cmd; | 100 | return link_cmd; |
92 | } | 101 | } |