Commit a23d8a70 authored by Malcolm Priestley's avatar Malcolm Priestley Committed by Greg Kroah-Hartman

staging: vt6656: mac80211 conversion: change vnt_rf_set_txpower

Remove old eScanState code and use.

priv->hw->conf.chandef.chan->hw_value to find current channel

Check hw_value for bounds of vt3226d0_lo_current_table
Signed-off-by: default avatarMalcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent f07e9fb2
...@@ -891,6 +891,8 @@ int vnt_rf_set_txpower(struct vnt_private *priv, u8 power, u32 rate) ...@@ -891,6 +891,8 @@ int vnt_rf_set_txpower(struct vnt_private *priv, u8 power, u32 rate)
return false; return false;
if (rate <= RATE_11M) { if (rate <= RATE_11M) {
u16 hw_value = priv->hw->conf.chandef.chan->hw_value;
power_setting = ((0x3f-priv->byCurPwr) << 20) | power_setting = ((0x3f-priv->byCurPwr) << 20) |
(0xe07 << 8) | (BY_VT3226_REG_LEN << 3) | (0xe07 << 8) | (BY_VT3226_REG_LEN << 3) |
IFREGCTL_REGW; IFREGCTL_REGW;
...@@ -899,21 +901,14 @@ int vnt_rf_set_txpower(struct vnt_private *priv, u8 power, u32 rate) ...@@ -899,21 +901,14 @@ int vnt_rf_set_txpower(struct vnt_private *priv, u8 power, u32 rate)
ret &= vnt_rf_write_embedded(priv, 0x03c6a200 + ret &= vnt_rf_write_embedded(priv, 0x03c6a200 +
(BY_VT3226_REG_LEN<<3)+IFREGCTL_REGW); (BY_VT3226_REG_LEN<<3)+IFREGCTL_REGW);
if (priv->vnt_mgmt.eScanState != WMAC_NO_SCANNING) { dev_dbg(&priv->usb->dev,
dev_dbg(&priv->usb->dev, "%s 11b channel [%d]\n", __func__, hw_value);
"vnt_rf_set_txpower> 11B mode uCurrChannel[%d]\n",
priv->vnt_mgmt.uScanChannel); hw_value--;
ret &= vnt_rf_write_embedded(priv,
vt3226d0_lo_current_table[priv-> if (hw_value < ARRAY_SIZE(vt3226d0_lo_current_table))
vnt_mgmt.uScanChannel - 1]);
} else {
dev_dbg(&priv->usb->dev,
"vnt_rf_set_txpower> 11B mode uCurrChannel[%d]\n",
priv->vnt_mgmt.uCurrChannel);
ret &= vnt_rf_write_embedded(priv, ret &= vnt_rf_write_embedded(priv,
vt3226d0_lo_current_table[priv-> vt3226d0_lo_current_table[hw_value]);
vnt_mgmt.uCurrChannel - 1]);
}
ret &= vnt_rf_write_embedded(priv, 0x015C0800 + ret &= vnt_rf_write_embedded(priv, 0x015C0800 +
(BY_VT3226_REG_LEN<<3)+IFREGCTL_REGW); (BY_VT3226_REG_LEN<<3)+IFREGCTL_REGW);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment