Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 13558
b: refs/heads/master
c: 8400a1c
h: refs/heads/master
v: v3
  • Loading branch information
Liu Hong authored and James Ketrenos committed Nov 7, 2005
1 parent dff8ca2 commit ce2f5d5
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 4 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: d8bad6df045249cd1cff6a0d167c8f1b9caade7e
refs/heads/master: 8400a1ceb445f2ace4b8d3c35c181b2b416a81ce
31 changes: 28 additions & 3 deletions trunk/drivers/net/wireless/ipw2200.c
Original file line number Diff line number Diff line change
Expand Up @@ -8756,6 +8756,7 @@ static int ipw_wx_set_txpow(struct net_device *dev,
union iwreq_data *wrqu, char *extra)
{
struct ipw_priv *priv = ieee80211_priv(dev);
const struct ieee80211_geo *geo = ieee80211_get_geo(priv->ieee);
struct ipw_tx_power tx_power;
int i;

Expand Down Expand Up @@ -8785,10 +8786,15 @@ static int ipw_wx_set_txpow(struct net_device *dev,

/* configure device for 'G' band */
tx_power.ieee_mode = IPW_G_MODE;
tx_power.num_channels = 11;
for (i = 0; i < 11; i++) {
tx_power.num_channels = geo->bg_channels;
for (i = 0; i < geo->bg_channels; i++) {
int max_power = geo->bg[i].max_power;

tx_power.channels_tx_power[i].channel_number = i + 1;
tx_power.channels_tx_power[i].tx_power = priv->tx_power;
if (max_power != 0 && priv->tx_power > max_power)
tx_power.channels_tx_power[i].tx_power = max_power;
else
tx_power.channels_tx_power[i].tx_power = priv->tx_power;
}
if (ipw_send_tx_power(priv, &tx_power))
goto error;
Expand All @@ -8798,6 +8804,25 @@ static int ipw_wx_set_txpow(struct net_device *dev,
if (ipw_send_tx_power(priv, &tx_power))
goto error;

/* configure device to also handle 'A' band */
if (priv->ieee->abg_true) {
tx_power.ieee_mode = IPW_A_MODE;
tx_power.num_channels = geo->a_channels;
for (i = 0; i < geo->a_channels; i++) {
int max_power = geo->a[i].max_power;

tx_power.channels_tx_power[i].channel_number = i + 1;
if (max_power != 0 && priv->tx_power > max_power)
tx_power.channels_tx_power[i].tx_power =
max_power;
else
tx_power.channels_tx_power[i].tx_power =
priv->tx_power;
}
if (ipw_send_tx_power(priv, &tx_power))
goto error;
}

up(&priv->sem);
return 0;

Expand Down

0 comments on commit ce2f5d5

Please sign in to comment.