aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/rt2x00/rt2500usb.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt2500usb.c')
-rw-r--r--drivers/net/wireless/rt2x00/rt2500usb.c39
1 files changed, 26 insertions, 13 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2500usb.c b/drivers/net/wireless/rt2x00/rt2500usb.c
index cd5af656932d..3b90ed622148 100644
--- a/drivers/net/wireless/rt2x00/rt2500usb.c
+++ b/drivers/net/wireless/rt2x00/rt2500usb.c
@@ -1665,10 +1665,11 @@ static const struct rf_channel rf_vals_5222[] = {
1665 { 161, 0x00022020, 0x000090be, 0x00000101, 0x00000a07 }, 1665 { 161, 0x00022020, 0x000090be, 0x00000101, 0x00000a07 },
1666}; 1666};
1667 1667
1668static void rt2500usb_probe_hw_mode(struct rt2x00_dev *rt2x00dev) 1668static int rt2500usb_probe_hw_mode(struct rt2x00_dev *rt2x00dev)
1669{ 1669{
1670 struct hw_mode_spec *spec = &rt2x00dev->spec; 1670 struct hw_mode_spec *spec = &rt2x00dev->spec;
1671 u8 *txpower; 1671 struct channel_info *info;
1672 char *tx_power;
1672 unsigned int i; 1673 unsigned int i;
1673 1674
1674 /* 1675 /*
@@ -1687,20 +1688,10 @@ static void rt2500usb_probe_hw_mode(struct rt2x00_dev *rt2x00dev)
1687 EEPROM_MAC_ADDR_0)); 1688 EEPROM_MAC_ADDR_0));
1688 1689
1689 /* 1690 /*
1690 * Convert tx_power array in eeprom.
1691 */
1692 txpower = rt2x00_eeprom_addr(rt2x00dev, EEPROM_TXPOWER_START);
1693 for (i = 0; i < 14; i++)
1694 txpower[i] = TXPOWER_FROM_DEV(txpower[i]);
1695
1696 /*
1697 * Initialize hw_mode information. 1691 * Initialize hw_mode information.
1698 */ 1692 */
1699 spec->supported_bands = SUPPORT_BAND_2GHZ; 1693 spec->supported_bands = SUPPORT_BAND_2GHZ;
1700 spec->supported_rates = SUPPORT_RATE_CCK | SUPPORT_RATE_OFDM; 1694 spec->supported_rates = SUPPORT_RATE_CCK | SUPPORT_RATE_OFDM;
1701 spec->tx_power_a = NULL;
1702 spec->tx_power_bg = txpower;
1703 spec->tx_power_default = DEFAULT_TXPOWER;
1704 1695
1705 if (rt2x00_rf(&rt2x00dev->chip, RF2522)) { 1696 if (rt2x00_rf(&rt2x00dev->chip, RF2522)) {
1706 spec->num_channels = ARRAY_SIZE(rf_vals_bg_2522); 1697 spec->num_channels = ARRAY_SIZE(rf_vals_bg_2522);
@@ -1722,6 +1713,26 @@ static void rt2500usb_probe_hw_mode(struct rt2x00_dev *rt2x00dev)
1722 spec->num_channels = ARRAY_SIZE(rf_vals_5222); 1713 spec->num_channels = ARRAY_SIZE(rf_vals_5222);
1723 spec->channels = rf_vals_5222; 1714 spec->channels = rf_vals_5222;
1724 } 1715 }
1716
1717 /*
1718 * Create channel information array
1719 */
1720 info = kzalloc(spec->num_channels * sizeof(*info), GFP_KERNEL);
1721 if (!info)
1722 return -ENOMEM;
1723
1724 spec->channels_info = info;
1725
1726 tx_power = rt2x00_eeprom_addr(rt2x00dev, EEPROM_TXPOWER_START);
1727 for (i = 0; i < 14; i++)
1728 info[i].tx_power1 = TXPOWER_FROM_DEV(tx_power[i]);
1729
1730 if (spec->num_channels > 14) {
1731 for (i = 14; i < spec->num_channels; i++)
1732 info[i].tx_power1 = DEFAULT_TXPOWER;
1733 }
1734
1735 return 0;
1725} 1736}
1726 1737
1727static int rt2500usb_probe_hw(struct rt2x00_dev *rt2x00dev) 1738static int rt2500usb_probe_hw(struct rt2x00_dev *rt2x00dev)
@@ -1742,7 +1753,9 @@ static int rt2500usb_probe_hw(struct rt2x00_dev *rt2x00dev)
1742 /* 1753 /*
1743 * Initialize hw specifications. 1754 * Initialize hw specifications.
1744 */ 1755 */
1745 rt2500usb_probe_hw_mode(rt2x00dev); 1756 retval = rt2500usb_probe_hw_mode(rt2x00dev);
1757 if (retval)
1758 return retval;
1746 1759
1747 /* 1760 /*
1748 * This device requires the atim queue 1761 * This device requires the atim queue