|
@@ -160,6 +160,7 @@ int iwl_legacy_init_geos(struct iwl_priv *priv)
|
|
|
struct ieee80211_channel *geo_ch;
|
|
|
struct ieee80211_rate *rates;
|
|
|
int i = 0;
|
|
|
+ s8 max_tx_power = 0;
|
|
|
|
|
|
if (priv->bands[IEEE80211_BAND_2GHZ].n_bitrates ||
|
|
|
priv->bands[IEEE80211_BAND_5GHZ].n_bitrates) {
|
|
@@ -235,8 +236,8 @@ int iwl_legacy_init_geos(struct iwl_priv *priv)
|
|
|
|
|
|
geo_ch->flags |= ch->ht40_extension_channel;
|
|
|
|
|
|
- if (ch->max_power_avg > priv->tx_power_device_lmt)
|
|
|
- priv->tx_power_device_lmt = ch->max_power_avg;
|
|
|
+ if (ch->max_power_avg > max_tx_power)
|
|
|
+ max_tx_power = ch->max_power_avg;
|
|
|
} else {
|
|
|
geo_ch->flags |= IEEE80211_CHAN_DISABLED;
|
|
|
}
|
|
@@ -249,6 +250,10 @@ int iwl_legacy_init_geos(struct iwl_priv *priv)
|
|
|
geo_ch->flags);
|
|
|
}
|
|
|
|
|
|
+ priv->tx_power_device_lmt = max_tx_power;
|
|
|
+ priv->tx_power_user_lmt = max_tx_power;
|
|
|
+ priv->tx_power_next = max_tx_power;
|
|
|
+
|
|
|
if ((priv->bands[IEEE80211_BAND_5GHZ].n_channels == 0) &&
|
|
|
priv->cfg->sku & IWL_SKU_A) {
|
|
|
IWL_INFO(priv, "Incorrectly detected BG card as ABG. "
|
|
@@ -1124,11 +1129,11 @@ int iwl_legacy_set_tx_power(struct iwl_priv *priv, s8 tx_power, bool force)
|
|
|
if (!priv->cfg->ops->lib->send_tx_power)
|
|
|
return -EOPNOTSUPP;
|
|
|
|
|
|
- if (tx_power < IWL4965_TX_POWER_TARGET_POWER_MIN) {
|
|
|
+ /* 0 dBm mean 1 milliwatt */
|
|
|
+ if (tx_power < 0) {
|
|
|
IWL_WARN(priv,
|
|
|
- "Requested user TXPOWER %d below lower limit %d.\n",
|
|
|
- tx_power,
|
|
|
- IWL4965_TX_POWER_TARGET_POWER_MIN);
|
|
|
+ "Requested user TXPOWER %d below 1 mW.\n",
|
|
|
+ tx_power);
|
|
|
return -EINVAL;
|
|
|
}
|
|
|
|