diff options
| -rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-3945-rs.c | 14 | ||||
| -rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-agn-rs.c | 14 |
2 files changed, 23 insertions, 5 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-3945-rs.c b/drivers/net/wireless/iwlwifi/iwl-3945-rs.c index 9b60a0c5de5f..21c841847d88 100644 --- a/drivers/net/wireless/iwlwifi/iwl-3945-rs.c +++ b/drivers/net/wireless/iwlwifi/iwl-3945-rs.c | |||
| @@ -638,12 +638,16 @@ static void rs_get_rate(void *priv_r, struct ieee80211_sta *sta, | |||
| 638 | s8 scale_action = 0; | 638 | s8 scale_action = 0; |
| 639 | unsigned long flags; | 639 | unsigned long flags; |
| 640 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; | 640 | struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data; |
| 641 | u16 fc, rate_mask; | 641 | u16 fc; |
| 642 | u16 rate_mask = 0; | ||
| 642 | struct iwl3945_priv *priv = (struct iwl3945_priv *)priv_r; | 643 | struct iwl3945_priv *priv = (struct iwl3945_priv *)priv_r; |
| 643 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); | 644 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); |
| 644 | 645 | ||
| 645 | IWL_DEBUG_RATE("enter\n"); | 646 | IWL_DEBUG_RATE("enter\n"); |
| 646 | 647 | ||
| 648 | if (sta) | ||
| 649 | rate_mask = sta->supp_rates[sband->band]; | ||
| 650 | |||
| 647 | /* Send management frames and broadcast/multicast data using lowest | 651 | /* Send management frames and broadcast/multicast data using lowest |
| 648 | * rate. */ | 652 | * rate. */ |
| 649 | fc = le16_to_cpu(hdr->frame_control); | 653 | fc = le16_to_cpu(hdr->frame_control); |
| @@ -651,11 +655,15 @@ static void rs_get_rate(void *priv_r, struct ieee80211_sta *sta, | |||
| 651 | is_multicast_ether_addr(hdr->addr1) || | 655 | is_multicast_ether_addr(hdr->addr1) || |
| 652 | !sta || !priv_sta) { | 656 | !sta || !priv_sta) { |
| 653 | IWL_DEBUG_RATE("leave: No STA priv data to update!\n"); | 657 | IWL_DEBUG_RATE("leave: No STA priv data to update!\n"); |
| 654 | info->control.rates[0].idx = rate_lowest_index(sband, sta); | 658 | if (!rate_mask) |
| 659 | info->control.rates[0].idx = | ||
| 660 | rate_lowest_index(sband, NULL); | ||
| 661 | else | ||
| 662 | info->control.rates[0].idx = | ||
| 663 | rate_lowest_index(sband, sta); | ||
| 655 | return; | 664 | return; |
| 656 | } | 665 | } |
| 657 | 666 | ||
| 658 | rate_mask = sta->supp_rates[sband->band]; | ||
| 659 | index = min(rs_sta->last_txrate_idx & 0xffff, IWL_RATE_COUNT - 1); | 667 | index = min(rs_sta->last_txrate_idx & 0xffff, IWL_RATE_COUNT - 1); |
| 660 | 668 | ||
| 661 | if (sband->band == IEEE80211_BAND_5GHZ) | 669 | if (sband->band == IEEE80211_BAND_5GHZ) |
diff --git a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c index f3f17929ca0b..27f50471aed8 100644 --- a/drivers/net/wireless/iwlwifi/iwl-agn-rs.c +++ b/drivers/net/wireless/iwlwifi/iwl-agn-rs.c | |||
| @@ -944,7 +944,8 @@ static void rs_tx_status(void *priv_r, struct ieee80211_supported_band *sband, | |||
| 944 | } | 944 | } |
| 945 | 945 | ||
| 946 | /* See if there's a better rate or modulation mode to try. */ | 946 | /* See if there's a better rate or modulation mode to try. */ |
| 947 | rs_rate_scale_perform(priv, hdr, sta, lq_sta); | 947 | if (sta && sta->supp_rates[sband->band]) |
| 948 | rs_rate_scale_perform(priv, hdr, sta, lq_sta); | ||
| 948 | out: | 949 | out: |
| 949 | return; | 950 | return; |
| 950 | } | 951 | } |
| @@ -2101,14 +2102,23 @@ static void rs_get_rate(void *priv_r, struct ieee80211_sta *sta, void *priv_sta, | |||
| 2101 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); | 2102 | struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb); |
| 2102 | struct iwl_lq_sta *lq_sta = priv_sta; | 2103 | struct iwl_lq_sta *lq_sta = priv_sta; |
| 2103 | int rate_idx; | 2104 | int rate_idx; |
| 2105 | u64 mask_bit = 0; | ||
| 2104 | 2106 | ||
| 2105 | IWL_DEBUG_RATE_LIMIT("rate scale calculate new rate for skb\n"); | 2107 | IWL_DEBUG_RATE_LIMIT("rate scale calculate new rate for skb\n"); |
| 2106 | 2108 | ||
| 2109 | if (sta) | ||
| 2110 | mask_bit = sta->supp_rates[sband->band]; | ||
| 2111 | |||
| 2107 | /* Send management frames and broadcast/multicast data using lowest | 2112 | /* Send management frames and broadcast/multicast data using lowest |
| 2108 | * rate. */ | 2113 | * rate. */ |
| 2109 | if (!ieee80211_is_data(hdr->frame_control) || | 2114 | if (!ieee80211_is_data(hdr->frame_control) || |
| 2110 | is_multicast_ether_addr(hdr->addr1) || !sta || !lq_sta) { | 2115 | is_multicast_ether_addr(hdr->addr1) || !sta || !lq_sta) { |
| 2111 | info->control.rates[0].idx = rate_lowest_index(sband, sta); | 2116 | if (!mask_bit) |
| 2117 | info->control.rates[0].idx = | ||
| 2118 | rate_lowest_index(sband, NULL); | ||
| 2119 | else | ||
| 2120 | info->control.rates[0].idx = | ||
| 2121 | rate_lowest_index(sband, sta); | ||
| 2112 | return; | 2122 | return; |
| 2113 | } | 2123 | } |
| 2114 | 2124 | ||
