|
@@ -1774,7 +1774,10 @@ static int iwl4965_scan_initiate(struct iwl_priv *priv)
|
|
|
}
|
|
|
|
|
|
IWL_DEBUG_INFO("Starting scan...\n");
|
|
|
- priv->scan_bands = 2;
|
|
|
+ if (priv->cfg->sku & IWL_SKU_G)
|
|
|
+ priv->scan_bands |= BIT(IEEE80211_BAND_2GHZ);
|
|
|
+ if (priv->cfg->sku & IWL_SKU_A)
|
|
|
+ priv->scan_bands |= BIT(IEEE80211_BAND_5GHZ);
|
|
|
set_bit(STATUS_SCANNING, &priv->status);
|
|
|
priv->scan_start = jiffies;
|
|
|
priv->scan_pass_start = priv->scan_start;
|
|
@@ -3023,8 +3026,9 @@ static void iwl4965_rx_reply_tx(struct iwl_priv *priv,
|
|
|
|
|
|
IWL_DEBUG_TX_REPLY("Tx queue reclaim %d\n", index);
|
|
|
if (index != -1) {
|
|
|
- int freed = iwl4965_tx_queue_reclaim(priv, txq_id, index);
|
|
|
#ifdef CONFIG_IWL4965_HT
|
|
|
+ int freed = iwl4965_tx_queue_reclaim(priv, txq_id, index);
|
|
|
+
|
|
|
if (tid != MAX_TID_COUNT)
|
|
|
priv->stations[sta_id].tid[tid].tfds_in_queue -= freed;
|
|
|
if (iwl4965_queue_space(&txq->q) > txq->q.low_mark &&
|
|
@@ -3276,13 +3280,18 @@ static void iwl4965_rx_scan_complete_notif(struct iwl_priv *priv,
|
|
|
cancel_delayed_work(&priv->scan_check);
|
|
|
|
|
|
IWL_DEBUG_INFO("Scan pass on %sGHz took %dms\n",
|
|
|
- (priv->scan_bands == 2) ? "2.4" : "5.2",
|
|
|
+ (priv->scan_bands & BIT(IEEE80211_BAND_2GHZ)) ?
|
|
|
+ "2.4" : "5.2",
|
|
|
jiffies_to_msecs(elapsed_jiffies
|
|
|
(priv->scan_pass_start, jiffies)));
|
|
|
|
|
|
- /* Remove this scanned band from the list
|
|
|
- * of pending bands to scan */
|
|
|
- priv->scan_bands--;
|
|
|
+ /* Remove this scanned band from the list of pending
|
|
|
+ * bands to scan, band G precedes A in order of scanning
|
|
|
+ * as seen in iwl_bg_request_scan */
|
|
|
+ if (priv->scan_bands & BIT(IEEE80211_BAND_2GHZ))
|
|
|
+ priv->scan_bands &= ~BIT(IEEE80211_BAND_2GHZ);
|
|
|
+ else if (priv->scan_bands & BIT(IEEE80211_BAND_5GHZ))
|
|
|
+ priv->scan_bands &= ~BIT(IEEE80211_BAND_5GHZ);
|
|
|
|
|
|
/* If a request to abort was given, or the scan did not succeed
|
|
|
* then we reset the scan state machine and terminate,
|
|
@@ -3292,7 +3301,7 @@ static void iwl4965_rx_scan_complete_notif(struct iwl_priv *priv,
|
|
|
clear_bit(STATUS_SCAN_ABORTING, &priv->status);
|
|
|
} else {
|
|
|
/* If there are more bands on this scan pass reschedule */
|
|
|
- if (priv->scan_bands > 0)
|
|
|
+ if (priv->scan_bands)
|
|
|
goto reschedule;
|
|
|
}
|
|
|
|
|
@@ -4635,10 +4644,9 @@ static int iwl4965_get_channels_for_scan(struct iwl_priv *priv,
|
|
|
|
|
|
scan_ch->channel = ieee80211_frequency_to_channel(channels[i].center_freq);
|
|
|
|
|
|
- ch_info = iwl_get_channel_info(priv, band,
|
|
|
- scan_ch->channel);
|
|
|
+ ch_info = iwl_get_channel_info(priv, band, scan_ch->channel);
|
|
|
if (!is_channel_valid(ch_info)) {
|
|
|
- IWL_DEBUG_SCAN("Channel %d is INVALID for this SKU.\n",
|
|
|
+ IWL_DEBUG_SCAN("Channel %d is INVALID for this band.\n",
|
|
|
scan_ch->channel);
|
|
|
continue;
|
|
|
}
|
|
@@ -5830,8 +5838,7 @@ static void iwl4965_bg_request_scan(struct work_struct *data)
|
|
|
scan->tx_cmd.stop_time.life_time = TX_CMD_LIFE_TIME_INFINITE;
|
|
|
|
|
|
|
|
|
- switch (priv->scan_bands) {
|
|
|
- case 2:
|
|
|
+ if (priv->scan_bands & BIT(IEEE80211_BAND_2GHZ)) {
|
|
|
scan->flags = RXON_FLG_BAND_24G_MSK | RXON_FLG_AUTO_DETECT_MSK;
|
|
|
scan->tx_cmd.rate_n_flags =
|
|
|
iwl4965_hw_set_rate_n_flags(IWL_RATE_1M_PLCP,
|
|
@@ -5839,17 +5846,13 @@ static void iwl4965_bg_request_scan(struct work_struct *data)
|
|
|
|
|
|
scan->good_CRC_th = 0;
|
|
|
band = IEEE80211_BAND_2GHZ;
|
|
|
- break;
|
|
|
-
|
|
|
- case 1:
|
|
|
+ } else if (priv->scan_bands & BIT(IEEE80211_BAND_5GHZ)) {
|
|
|
scan->tx_cmd.rate_n_flags =
|
|
|
iwl4965_hw_set_rate_n_flags(IWL_RATE_6M_PLCP,
|
|
|
RATE_MCS_ANT_B_MSK);
|
|
|
scan->good_CRC_th = IWL_GOOD_CRC_TH;
|
|
|
band = IEEE80211_BAND_5GHZ;
|
|
|
- break;
|
|
|
-
|
|
|
- default:
|
|
|
+ } else {
|
|
|
IWL_WARNING("Invalid scan band count\n");
|
|
|
goto done;
|
|
|
}
|