diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2009-11-04 12:36:17 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-11-06 16:48:57 -0500 |
commit | 4d6f8b9f17626da48d6badc6ba259fbacc1413c3 (patch) | |
tree | 3e5c40a7d2df005815af7a3c3bf1b2d14224459b | |
parent | 5822e0701d9c29291f16cf170417071b702edeee (diff) |
rt2800: prepare for rt2800lib addition
Part of preparations for later code unification.
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Acked-by: Ivo van Doorn <IvDoorn@gmail.com>
Acked-by: Gertjan van Wingerde <gwingerde@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2800pci.c | 103 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2800usb.c | 134 |
2 files changed, 133 insertions, 104 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2800pci.c b/drivers/net/wireless/rt2x00/rt2800pci.c index cae772ea5686..938f198f3562 100644 --- a/drivers/net/wireless/rt2x00/rt2800pci.c +++ b/drivers/net/wireless/rt2x00/rt2800pci.c | |||
@@ -97,7 +97,8 @@ static void rt2800pci_bbp_write(struct rt2x00_dev *rt2x00dev, | |||
97 | rt2x00_set_field32(®, BBP_CSR_CFG_REGNUM, word); | 97 | rt2x00_set_field32(®, BBP_CSR_CFG_REGNUM, word); |
98 | rt2x00_set_field32(®, BBP_CSR_CFG_BUSY, 1); | 98 | rt2x00_set_field32(®, BBP_CSR_CFG_BUSY, 1); |
99 | rt2x00_set_field32(®, BBP_CSR_CFG_READ_CONTROL, 0); | 99 | rt2x00_set_field32(®, BBP_CSR_CFG_READ_CONTROL, 0); |
100 | rt2x00_set_field32(®, BBP_CSR_CFG_BBP_RW_MODE, 1); | 100 | if (rt2x00_intf_is_pci(rt2x00dev)) |
101 | rt2x00_set_field32(®, BBP_CSR_CFG_BBP_RW_MODE, 1); | ||
101 | 102 | ||
102 | rt2800_register_write_lock(rt2x00dev, BBP_CSR_CFG, reg); | 103 | rt2800_register_write_lock(rt2x00dev, BBP_CSR_CFG, reg); |
103 | } | 104 | } |
@@ -125,7 +126,8 @@ static void rt2800pci_bbp_read(struct rt2x00_dev *rt2x00dev, | |||
125 | rt2x00_set_field32(®, BBP_CSR_CFG_REGNUM, word); | 126 | rt2x00_set_field32(®, BBP_CSR_CFG_REGNUM, word); |
126 | rt2x00_set_field32(®, BBP_CSR_CFG_BUSY, 1); | 127 | rt2x00_set_field32(®, BBP_CSR_CFG_BUSY, 1); |
127 | rt2x00_set_field32(®, BBP_CSR_CFG_READ_CONTROL, 1); | 128 | rt2x00_set_field32(®, BBP_CSR_CFG_READ_CONTROL, 1); |
128 | rt2x00_set_field32(®, BBP_CSR_CFG_BBP_RW_MODE, 1); | 129 | if (rt2x00_intf_is_pci(rt2x00dev)) |
130 | rt2x00_set_field32(®, BBP_CSR_CFG_BBP_RW_MODE, 1); | ||
129 | 131 | ||
130 | rt2800_register_write_lock(rt2x00dev, BBP_CSR_CFG, reg); | 132 | rt2800_register_write_lock(rt2x00dev, BBP_CSR_CFG, reg); |
131 | 133 | ||
@@ -253,12 +255,14 @@ static void rt2800pci_mcu_request(struct rt2x00_dev *rt2x00dev, | |||
253 | { | 255 | { |
254 | u32 reg; | 256 | u32 reg; |
255 | 257 | ||
256 | /* | 258 | if (rt2x00_intf_is_pci(rt2x00dev)) { |
257 | * RT2880 and RT3052 don't support MCU requests. | 259 | /* |
258 | */ | 260 | * RT2880 and RT3052 don't support MCU requests. |
259 | if (rt2x00_rt(&rt2x00dev->chip, RT2880) || | 261 | */ |
260 | rt2x00_rt(&rt2x00dev->chip, RT3052)) | 262 | if (rt2x00_rt(&rt2x00dev->chip, RT2880) || |
261 | return; | 263 | rt2x00_rt(&rt2x00dev->chip, RT3052)) |
264 | return; | ||
265 | } | ||
262 | 266 | ||
263 | mutex_lock(&rt2x00dev->csr_mutex); | 267 | mutex_lock(&rt2x00dev->csr_mutex); |
264 | 268 | ||
@@ -814,7 +818,8 @@ static void rt2800pci_config_ant(struct rt2x00_dev *rt2x00dev, | |||
814 | switch ((int)ant->tx) { | 818 | switch ((int)ant->tx) { |
815 | case 1: | 819 | case 1: |
816 | rt2x00_set_field8(&r1, BBP1_TX_ANTENNA, 0); | 820 | rt2x00_set_field8(&r1, BBP1_TX_ANTENNA, 0); |
817 | rt2x00_set_field8(&r3, BBP3_RX_ANTENNA, 0); | 821 | if (rt2x00_intf_is_pci(rt2x00dev)) |
822 | rt2x00_set_field8(&r3, BBP3_RX_ANTENNA, 0); | ||
818 | break; | 823 | break; |
819 | case 2: | 824 | case 2: |
820 | rt2x00_set_field8(&r1, BBP1_TX_ANTENNA, 2); | 825 | rt2x00_set_field8(&r1, BBP1_TX_ANTENNA, 2); |
@@ -1480,7 +1485,8 @@ static int rt2800pci_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1480 | u32 reg; | 1485 | u32 reg; |
1481 | unsigned int i; | 1486 | unsigned int i; |
1482 | 1487 | ||
1483 | rt2800_register_write(rt2x00dev, PWR_PIN_CFG, 0x00000003); | 1488 | if (rt2x00_intf_is_pci(rt2x00dev)) |
1489 | rt2800_register_write(rt2x00dev, PWR_PIN_CFG, 0x00000003); | ||
1484 | 1490 | ||
1485 | rt2800_register_read(rt2x00dev, MAC_SYS_CTRL, ®); | 1491 | rt2800_register_read(rt2x00dev, MAC_SYS_CTRL, ®); |
1486 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_CSR, 1); | 1492 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_CSR, 1); |
@@ -1803,7 +1809,8 @@ static int rt2800pci_init_bbp(struct rt2x00_dev *rt2x00dev) | |||
1803 | if (rt2x00_rev(&rt2x00dev->chip) > RT2860D_VERSION) | 1809 | if (rt2x00_rev(&rt2x00dev->chip) > RT2860D_VERSION) |
1804 | rt2800_bbp_write(rt2x00dev, 84, 0x19); | 1810 | rt2800_bbp_write(rt2x00dev, 84, 0x19); |
1805 | 1811 | ||
1806 | if (rt2x00_rt(&rt2x00dev->chip, RT3052)) { | 1812 | if (rt2x00_intf_is_pci(rt2x00dev) && |
1813 | rt2x00_rt(&rt2x00dev->chip, RT3052)) { | ||
1807 | rt2800_bbp_write(rt2x00dev, 31, 0x08); | 1814 | rt2800_bbp_write(rt2x00dev, 31, 0x08); |
1808 | rt2800_bbp_write(rt2x00dev, 78, 0x0e); | 1815 | rt2800_bbp_write(rt2x00dev, 78, 0x0e); |
1809 | rt2800_bbp_write(rt2x00dev, 80, 0x08); | 1816 | rt2800_bbp_write(rt2x00dev, 80, 0x08); |
@@ -1887,10 +1894,12 @@ static int rt2800pci_init_rfcsr(struct rt2x00_dev *rt2x00dev) | |||
1887 | u8 rfcsr; | 1894 | u8 rfcsr; |
1888 | u8 bbp; | 1895 | u8 bbp; |
1889 | 1896 | ||
1890 | if (!rt2x00_rf(&rt2x00dev->chip, RF3020) && | 1897 | if (rt2x00_intf_is_pci(rt2x00dev)) { |
1891 | !rt2x00_rf(&rt2x00dev->chip, RF3021) && | 1898 | if (!rt2x00_rf(&rt2x00dev->chip, RF3020) && |
1892 | !rt2x00_rf(&rt2x00dev->chip, RF3022)) | 1899 | !rt2x00_rf(&rt2x00dev->chip, RF3021) && |
1893 | return 0; | 1900 | !rt2x00_rf(&rt2x00dev->chip, RF3022)) |
1901 | return 0; | ||
1902 | } | ||
1894 | 1903 | ||
1895 | /* | 1904 | /* |
1896 | * Init RF calibration. | 1905 | * Init RF calibration. |
@@ -1902,36 +1911,38 @@ static int rt2800pci_init_rfcsr(struct rt2x00_dev *rt2x00dev) | |||
1902 | rt2x00_set_field8(&rfcsr, RFCSR30_RF_CALIBRATION, 0); | 1911 | rt2x00_set_field8(&rfcsr, RFCSR30_RF_CALIBRATION, 0); |
1903 | rt2800_rfcsr_write(rt2x00dev, 30, rfcsr); | 1912 | rt2800_rfcsr_write(rt2x00dev, 30, rfcsr); |
1904 | 1913 | ||
1905 | rt2800_rfcsr_write(rt2x00dev, 0, 0x50); | 1914 | if (rt2x00_intf_is_pci(rt2x00dev)) { |
1906 | rt2800_rfcsr_write(rt2x00dev, 1, 0x01); | 1915 | rt2800_rfcsr_write(rt2x00dev, 0, 0x50); |
1907 | rt2800_rfcsr_write(rt2x00dev, 2, 0xf7); | 1916 | rt2800_rfcsr_write(rt2x00dev, 1, 0x01); |
1908 | rt2800_rfcsr_write(rt2x00dev, 3, 0x75); | 1917 | rt2800_rfcsr_write(rt2x00dev, 2, 0xf7); |
1909 | rt2800_rfcsr_write(rt2x00dev, 4, 0x40); | 1918 | rt2800_rfcsr_write(rt2x00dev, 3, 0x75); |
1910 | rt2800_rfcsr_write(rt2x00dev, 5, 0x03); | 1919 | rt2800_rfcsr_write(rt2x00dev, 4, 0x40); |
1911 | rt2800_rfcsr_write(rt2x00dev, 6, 0x02); | 1920 | rt2800_rfcsr_write(rt2x00dev, 5, 0x03); |
1912 | rt2800_rfcsr_write(rt2x00dev, 7, 0x50); | 1921 | rt2800_rfcsr_write(rt2x00dev, 6, 0x02); |
1913 | rt2800_rfcsr_write(rt2x00dev, 8, 0x39); | 1922 | rt2800_rfcsr_write(rt2x00dev, 7, 0x50); |
1914 | rt2800_rfcsr_write(rt2x00dev, 9, 0x0f); | 1923 | rt2800_rfcsr_write(rt2x00dev, 8, 0x39); |
1915 | rt2800_rfcsr_write(rt2x00dev, 10, 0x60); | 1924 | rt2800_rfcsr_write(rt2x00dev, 9, 0x0f); |
1916 | rt2800_rfcsr_write(rt2x00dev, 11, 0x21); | 1925 | rt2800_rfcsr_write(rt2x00dev, 10, 0x60); |
1917 | rt2800_rfcsr_write(rt2x00dev, 12, 0x75); | 1926 | rt2800_rfcsr_write(rt2x00dev, 11, 0x21); |
1918 | rt2800_rfcsr_write(rt2x00dev, 13, 0x75); | 1927 | rt2800_rfcsr_write(rt2x00dev, 12, 0x75); |
1919 | rt2800_rfcsr_write(rt2x00dev, 14, 0x90); | 1928 | rt2800_rfcsr_write(rt2x00dev, 13, 0x75); |
1920 | rt2800_rfcsr_write(rt2x00dev, 15, 0x58); | 1929 | rt2800_rfcsr_write(rt2x00dev, 14, 0x90); |
1921 | rt2800_rfcsr_write(rt2x00dev, 16, 0xb3); | 1930 | rt2800_rfcsr_write(rt2x00dev, 15, 0x58); |
1922 | rt2800_rfcsr_write(rt2x00dev, 17, 0x92); | 1931 | rt2800_rfcsr_write(rt2x00dev, 16, 0xb3); |
1923 | rt2800_rfcsr_write(rt2x00dev, 18, 0x2c); | 1932 | rt2800_rfcsr_write(rt2x00dev, 17, 0x92); |
1924 | rt2800_rfcsr_write(rt2x00dev, 19, 0x02); | 1933 | rt2800_rfcsr_write(rt2x00dev, 18, 0x2c); |
1925 | rt2800_rfcsr_write(rt2x00dev, 20, 0xba); | 1934 | rt2800_rfcsr_write(rt2x00dev, 19, 0x02); |
1926 | rt2800_rfcsr_write(rt2x00dev, 21, 0xdb); | 1935 | rt2800_rfcsr_write(rt2x00dev, 20, 0xba); |
1927 | rt2800_rfcsr_write(rt2x00dev, 22, 0x00); | 1936 | rt2800_rfcsr_write(rt2x00dev, 21, 0xdb); |
1928 | rt2800_rfcsr_write(rt2x00dev, 23, 0x31); | 1937 | rt2800_rfcsr_write(rt2x00dev, 22, 0x00); |
1929 | rt2800_rfcsr_write(rt2x00dev, 24, 0x08); | 1938 | rt2800_rfcsr_write(rt2x00dev, 23, 0x31); |
1930 | rt2800_rfcsr_write(rt2x00dev, 25, 0x01); | 1939 | rt2800_rfcsr_write(rt2x00dev, 24, 0x08); |
1931 | rt2800_rfcsr_write(rt2x00dev, 26, 0x25); | 1940 | rt2800_rfcsr_write(rt2x00dev, 25, 0x01); |
1932 | rt2800_rfcsr_write(rt2x00dev, 27, 0x23); | 1941 | rt2800_rfcsr_write(rt2x00dev, 26, 0x25); |
1933 | rt2800_rfcsr_write(rt2x00dev, 28, 0x13); | 1942 | rt2800_rfcsr_write(rt2x00dev, 27, 0x23); |
1934 | rt2800_rfcsr_write(rt2x00dev, 29, 0x83); | 1943 | rt2800_rfcsr_write(rt2x00dev, 28, 0x13); |
1944 | rt2800_rfcsr_write(rt2x00dev, 29, 0x83); | ||
1945 | } | ||
1935 | 1946 | ||
1936 | /* | 1947 | /* |
1937 | * Set RX Filter calibration for 20MHz and 40MHz | 1948 | * Set RX Filter calibration for 20MHz and 40MHz |
@@ -3005,6 +3016,8 @@ static int rt2800pci_probe_hw(struct rt2x00_dev *rt2x00dev) | |||
3005 | { | 3016 | { |
3006 | int retval; | 3017 | int retval; |
3007 | 3018 | ||
3019 | rt2x00_set_chip_intf(rt2x00dev, RT2X00_CHIP_INTF_PCI); | ||
3020 | |||
3008 | rt2x00dev->priv = (void *)&rt2800pci_rt2800_ops; | 3021 | rt2x00dev->priv = (void *)&rt2800pci_rt2800_ops; |
3009 | 3022 | ||
3010 | /* | 3023 | /* |
diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c index 1383e55ff8ec..9aee3ab6589e 100644 --- a/drivers/net/wireless/rt2x00/rt2800usb.c +++ b/drivers/net/wireless/rt2x00/rt2800usb.c | |||
@@ -1050,7 +1050,8 @@ static void rt2800usb_link_stats(struct rt2x00_dev *rt2x00dev, | |||
1050 | static u8 rt2800usb_get_default_vgc(struct rt2x00_dev *rt2x00dev) | 1050 | static u8 rt2800usb_get_default_vgc(struct rt2x00_dev *rt2x00dev) |
1051 | { | 1051 | { |
1052 | if (rt2x00dev->curr_band == IEEE80211_BAND_2GHZ) { | 1052 | if (rt2x00dev->curr_band == IEEE80211_BAND_2GHZ) { |
1053 | if (rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) | 1053 | if (rt2x00_intf_is_usb(rt2x00dev) && |
1054 | rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) | ||
1054 | return 0x1c + (2 * rt2x00dev->lna_gain); | 1055 | return 0x1c + (2 * rt2x00dev->lna_gain); |
1055 | else | 1056 | else |
1056 | return 0x2e + rt2x00dev->lna_gain; | 1057 | return 0x2e + rt2x00dev->lna_gain; |
@@ -1285,33 +1286,38 @@ static int rt2800usb_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1285 | u32 reg; | 1286 | u32 reg; |
1286 | unsigned int i; | 1287 | unsigned int i; |
1287 | 1288 | ||
1288 | /* | 1289 | if (rt2x00_intf_is_usb(rt2x00dev)) { |
1289 | * Wait untill BBP and RF are ready. | 1290 | /* |
1290 | */ | 1291 | * Wait untill BBP and RF are ready. |
1291 | for (i = 0; i < REGISTER_BUSY_COUNT; i++) { | 1292 | */ |
1292 | rt2800_register_read(rt2x00dev, MAC_CSR0, ®); | 1293 | for (i = 0; i < REGISTER_BUSY_COUNT; i++) { |
1293 | if (reg && reg != ~0) | 1294 | rt2800_register_read(rt2x00dev, MAC_CSR0, ®); |
1294 | break; | 1295 | if (reg && reg != ~0) |
1295 | msleep(1); | 1296 | break; |
1296 | } | 1297 | msleep(1); |
1298 | } | ||
1297 | 1299 | ||
1298 | if (i == REGISTER_BUSY_COUNT) { | 1300 | if (i == REGISTER_BUSY_COUNT) { |
1299 | ERROR(rt2x00dev, "Unstable hardware.\n"); | 1301 | ERROR(rt2x00dev, "Unstable hardware.\n"); |
1300 | return -EBUSY; | 1302 | return -EBUSY; |
1301 | } | 1303 | } |
1302 | 1304 | ||
1303 | rt2800_register_read(rt2x00dev, PBF_SYS_CTRL, ®); | 1305 | rt2800_register_read(rt2x00dev, PBF_SYS_CTRL, ®); |
1304 | rt2800_register_write(rt2x00dev, PBF_SYS_CTRL, reg & ~0x00002000); | 1306 | rt2800_register_write(rt2x00dev, PBF_SYS_CTRL, |
1307 | reg & ~0x00002000); | ||
1308 | } | ||
1305 | 1309 | ||
1306 | rt2800_register_read(rt2x00dev, MAC_SYS_CTRL, ®); | 1310 | rt2800_register_read(rt2x00dev, MAC_SYS_CTRL, ®); |
1307 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_CSR, 1); | 1311 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_CSR, 1); |
1308 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_BBP, 1); | 1312 | rt2x00_set_field32(®, MAC_SYS_CTRL_RESET_BBP, 1); |
1309 | rt2800_register_write(rt2x00dev, MAC_SYS_CTRL, reg); | 1313 | rt2800_register_write(rt2x00dev, MAC_SYS_CTRL, reg); |
1310 | 1314 | ||
1311 | rt2800_register_write(rt2x00dev, USB_DMA_CFG, 0x00000000); | 1315 | if (rt2x00_intf_is_usb(rt2x00dev)) { |
1316 | rt2800_register_write(rt2x00dev, USB_DMA_CFG, 0x00000000); | ||
1312 | 1317 | ||
1313 | rt2x00usb_vendor_request_sw(rt2x00dev, USB_DEVICE_MODE, 0, | 1318 | rt2x00usb_vendor_request_sw(rt2x00dev, USB_DEVICE_MODE, 0, |
1314 | USB_MODE_RESET, REGISTER_TIMEOUT); | 1319 | USB_MODE_RESET, REGISTER_TIMEOUT); |
1320 | } | ||
1315 | 1321 | ||
1316 | rt2800_register_write(rt2x00dev, MAC_SYS_CTRL, 0x00000000); | 1322 | rt2800_register_write(rt2x00dev, MAC_SYS_CTRL, 0x00000000); |
1317 | 1323 | ||
@@ -1343,7 +1349,8 @@ static int rt2800usb_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1343 | rt2x00_set_field32(®, BCN_TIME_CFG_TX_TIME_COMPENSATE, 0); | 1349 | rt2x00_set_field32(®, BCN_TIME_CFG_TX_TIME_COMPENSATE, 0); |
1344 | rt2800_register_write(rt2x00dev, BCN_TIME_CFG, reg); | 1350 | rt2800_register_write(rt2x00dev, BCN_TIME_CFG, reg); |
1345 | 1351 | ||
1346 | if (rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) { | 1352 | if (rt2x00_intf_is_usb(rt2x00dev) && |
1353 | rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) { | ||
1347 | rt2800_register_write(rt2x00dev, TX_SW_CFG0, 0x00000400); | 1354 | rt2800_register_write(rt2x00dev, TX_SW_CFG0, 0x00000400); |
1348 | rt2800_register_write(rt2x00dev, TX_SW_CFG1, 0x00000000); | 1355 | rt2800_register_write(rt2x00dev, TX_SW_CFG1, 0x00000000); |
1349 | rt2800_register_write(rt2x00dev, TX_SW_CFG2, 0x00000000); | 1356 | rt2800_register_write(rt2x00dev, TX_SW_CFG2, 0x00000000); |
@@ -1461,19 +1468,21 @@ static int rt2800usb_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1461 | rt2x00_set_field32(®, GF40_PROT_CFG_TX_OP_ALLOW_GF40, 1); | 1468 | rt2x00_set_field32(®, GF40_PROT_CFG_TX_OP_ALLOW_GF40, 1); |
1462 | rt2800_register_write(rt2x00dev, GF40_PROT_CFG, reg); | 1469 | rt2800_register_write(rt2x00dev, GF40_PROT_CFG, reg); |
1463 | 1470 | ||
1464 | rt2800_register_write(rt2x00dev, PBF_CFG, 0xf40006); | 1471 | if (rt2x00_intf_is_usb(rt2x00dev)) { |
1472 | rt2800_register_write(rt2x00dev, PBF_CFG, 0xf40006); | ||
1465 | 1473 | ||
1466 | rt2800_register_read(rt2x00dev, WPDMA_GLO_CFG, ®); | 1474 | rt2800_register_read(rt2x00dev, WPDMA_GLO_CFG, ®); |
1467 | rt2x00_set_field32(®, WPDMA_GLO_CFG_ENABLE_TX_DMA, 0); | 1475 | rt2x00_set_field32(®, WPDMA_GLO_CFG_ENABLE_TX_DMA, 0); |
1468 | rt2x00_set_field32(®, WPDMA_GLO_CFG_TX_DMA_BUSY, 0); | 1476 | rt2x00_set_field32(®, WPDMA_GLO_CFG_TX_DMA_BUSY, 0); |
1469 | rt2x00_set_field32(®, WPDMA_GLO_CFG_ENABLE_RX_DMA, 0); | 1477 | rt2x00_set_field32(®, WPDMA_GLO_CFG_ENABLE_RX_DMA, 0); |
1470 | rt2x00_set_field32(®, WPDMA_GLO_CFG_RX_DMA_BUSY, 0); | 1478 | rt2x00_set_field32(®, WPDMA_GLO_CFG_RX_DMA_BUSY, 0); |
1471 | rt2x00_set_field32(®, WPDMA_GLO_CFG_WP_DMA_BURST_SIZE, 3); | 1479 | rt2x00_set_field32(®, WPDMA_GLO_CFG_WP_DMA_BURST_SIZE, 3); |
1472 | rt2x00_set_field32(®, WPDMA_GLO_CFG_TX_WRITEBACK_DONE, 0); | 1480 | rt2x00_set_field32(®, WPDMA_GLO_CFG_TX_WRITEBACK_DONE, 0); |
1473 | rt2x00_set_field32(®, WPDMA_GLO_CFG_BIG_ENDIAN, 0); | 1481 | rt2x00_set_field32(®, WPDMA_GLO_CFG_BIG_ENDIAN, 0); |
1474 | rt2x00_set_field32(®, WPDMA_GLO_CFG_RX_HDR_SCATTER, 0); | 1482 | rt2x00_set_field32(®, WPDMA_GLO_CFG_RX_HDR_SCATTER, 0); |
1475 | rt2x00_set_field32(®, WPDMA_GLO_CFG_HDR_SEG_LEN, 0); | 1483 | rt2x00_set_field32(®, WPDMA_GLO_CFG_HDR_SEG_LEN, 0); |
1476 | rt2800_register_write(rt2x00dev, WPDMA_GLO_CFG, reg); | 1484 | rt2800_register_write(rt2x00dev, WPDMA_GLO_CFG, reg); |
1485 | } | ||
1477 | 1486 | ||
1478 | rt2800_register_write(rt2x00dev, TXOP_CTRL_CFG, 0x0000583f); | 1487 | rt2800_register_write(rt2x00dev, TXOP_CTRL_CFG, 0x0000583f); |
1479 | rt2800_register_write(rt2x00dev, TXOP_HLDR_ET, 0x00000002); | 1488 | rt2800_register_write(rt2x00dev, TXOP_HLDR_ET, 0x00000002); |
@@ -1519,9 +1528,11 @@ static int rt2800usb_init_registers(struct rt2x00_dev *rt2x00dev) | |||
1519 | rt2800_register_write(rt2x00dev, HW_BEACON_BASE6, 0); | 1528 | rt2800_register_write(rt2x00dev, HW_BEACON_BASE6, 0); |
1520 | rt2800_register_write(rt2x00dev, HW_BEACON_BASE7, 0); | 1529 | rt2800_register_write(rt2x00dev, HW_BEACON_BASE7, 0); |
1521 | 1530 | ||
1522 | rt2800_register_read(rt2x00dev, USB_CYC_CFG, ®); | 1531 | if (rt2x00_intf_is_usb(rt2x00dev)) { |
1523 | rt2x00_set_field32(®, USB_CYC_CFG_CLOCK_CYCLE, 30); | 1532 | rt2800_register_read(rt2x00dev, USB_CYC_CFG, ®); |
1524 | rt2800_register_write(rt2x00dev, USB_CYC_CFG, reg); | 1533 | rt2x00_set_field32(®, USB_CYC_CFG_CLOCK_CYCLE, 30); |
1534 | rt2800_register_write(rt2x00dev, USB_CYC_CFG, reg); | ||
1535 | } | ||
1525 | 1536 | ||
1526 | rt2800_register_read(rt2x00dev, HT_FBK_CFG0, ®); | 1537 | rt2800_register_read(rt2x00dev, HT_FBK_CFG0, ®); |
1527 | rt2x00_set_field32(®, HT_FBK_CFG0_HTMCS0FBK, 0); | 1538 | rt2x00_set_field32(®, HT_FBK_CFG0_HTMCS0FBK, 0); |
@@ -1650,11 +1661,11 @@ static int rt2800usb_init_bbp(struct rt2x00_dev *rt2x00dev) | |||
1650 | rt2800_bbp_write(rt2x00dev, 73, 0x12); | 1661 | rt2800_bbp_write(rt2x00dev, 73, 0x12); |
1651 | } | 1662 | } |
1652 | 1663 | ||
1653 | if (rt2x00_rev(&rt2x00dev->chip) > RT2860D_VERSION) { | 1664 | if (rt2x00_rev(&rt2x00dev->chip) > RT2860D_VERSION) |
1654 | rt2800_bbp_write(rt2x00dev, 84, 0x19); | 1665 | rt2800_bbp_write(rt2x00dev, 84, 0x19); |
1655 | } | ||
1656 | 1666 | ||
1657 | if (rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) { | 1667 | if (rt2x00_intf_is_usb(rt2x00dev) && |
1668 | rt2x00_rev(&rt2x00dev->chip) == RT3070_VERSION) { | ||
1658 | rt2800_bbp_write(rt2x00dev, 70, 0x0a); | 1669 | rt2800_bbp_write(rt2x00dev, 70, 0x0a); |
1659 | rt2800_bbp_write(rt2x00dev, 84, 0x99); | 1670 | rt2800_bbp_write(rt2x00dev, 84, 0x99); |
1660 | rt2800_bbp_write(rt2x00dev, 105, 0x05); | 1671 | rt2800_bbp_write(rt2x00dev, 105, 0x05); |
@@ -1738,7 +1749,8 @@ static int rt2800usb_init_rfcsr(struct rt2x00_dev *rt2x00dev) | |||
1738 | u8 rfcsr; | 1749 | u8 rfcsr; |
1739 | u8 bbp; | 1750 | u8 bbp; |
1740 | 1751 | ||
1741 | if (rt2x00_rev(&rt2x00dev->chip) != RT3070_VERSION) | 1752 | if (rt2x00_intf_is_usb(rt2x00dev) && |
1753 | rt2x00_rev(&rt2x00dev->chip) != RT3070_VERSION) | ||
1742 | return 0; | 1754 | return 0; |
1743 | 1755 | ||
1744 | /* | 1756 | /* |
@@ -1751,26 +1763,28 @@ static int rt2800usb_init_rfcsr(struct rt2x00_dev *rt2x00dev) | |||
1751 | rt2x00_set_field8(&rfcsr, RFCSR30_RF_CALIBRATION, 0); | 1763 | rt2x00_set_field8(&rfcsr, RFCSR30_RF_CALIBRATION, 0); |
1752 | rt2800_rfcsr_write(rt2x00dev, 30, rfcsr); | 1764 | rt2800_rfcsr_write(rt2x00dev, 30, rfcsr); |
1753 | 1765 | ||
1754 | rt2800_rfcsr_write(rt2x00dev, 4, 0x40); | 1766 | if (rt2x00_intf_is_usb(rt2x00dev)) { |
1755 | rt2800_rfcsr_write(rt2x00dev, 5, 0x03); | 1767 | rt2800_rfcsr_write(rt2x00dev, 4, 0x40); |
1756 | rt2800_rfcsr_write(rt2x00dev, 6, 0x02); | 1768 | rt2800_rfcsr_write(rt2x00dev, 5, 0x03); |
1757 | rt2800_rfcsr_write(rt2x00dev, 7, 0x70); | 1769 | rt2800_rfcsr_write(rt2x00dev, 6, 0x02); |
1758 | rt2800_rfcsr_write(rt2x00dev, 9, 0x0f); | 1770 | rt2800_rfcsr_write(rt2x00dev, 7, 0x70); |
1759 | rt2800_rfcsr_write(rt2x00dev, 10, 0x71); | 1771 | rt2800_rfcsr_write(rt2x00dev, 9, 0x0f); |
1760 | rt2800_rfcsr_write(rt2x00dev, 11, 0x21); | 1772 | rt2800_rfcsr_write(rt2x00dev, 10, 0x71); |
1761 | rt2800_rfcsr_write(rt2x00dev, 12, 0x7b); | 1773 | rt2800_rfcsr_write(rt2x00dev, 11, 0x21); |
1762 | rt2800_rfcsr_write(rt2x00dev, 14, 0x90); | 1774 | rt2800_rfcsr_write(rt2x00dev, 12, 0x7b); |
1763 | rt2800_rfcsr_write(rt2x00dev, 15, 0x58); | 1775 | rt2800_rfcsr_write(rt2x00dev, 14, 0x90); |
1764 | rt2800_rfcsr_write(rt2x00dev, 16, 0xb3); | 1776 | rt2800_rfcsr_write(rt2x00dev, 15, 0x58); |
1765 | rt2800_rfcsr_write(rt2x00dev, 17, 0x92); | 1777 | rt2800_rfcsr_write(rt2x00dev, 16, 0xb3); |
1766 | rt2800_rfcsr_write(rt2x00dev, 18, 0x2c); | 1778 | rt2800_rfcsr_write(rt2x00dev, 17, 0x92); |
1767 | rt2800_rfcsr_write(rt2x00dev, 19, 0x02); | 1779 | rt2800_rfcsr_write(rt2x00dev, 18, 0x2c); |
1768 | rt2800_rfcsr_write(rt2x00dev, 20, 0xba); | 1780 | rt2800_rfcsr_write(rt2x00dev, 19, 0x02); |
1769 | rt2800_rfcsr_write(rt2x00dev, 21, 0xdb); | 1781 | rt2800_rfcsr_write(rt2x00dev, 20, 0xba); |
1770 | rt2800_rfcsr_write(rt2x00dev, 24, 0x16); | 1782 | rt2800_rfcsr_write(rt2x00dev, 21, 0xdb); |
1771 | rt2800_rfcsr_write(rt2x00dev, 25, 0x01); | 1783 | rt2800_rfcsr_write(rt2x00dev, 24, 0x16); |
1772 | rt2800_rfcsr_write(rt2x00dev, 27, 0x03); | 1784 | rt2800_rfcsr_write(rt2x00dev, 25, 0x01); |
1773 | rt2800_rfcsr_write(rt2x00dev, 29, 0x1f); | 1785 | rt2800_rfcsr_write(rt2x00dev, 27, 0x03); |
1786 | rt2800_rfcsr_write(rt2x00dev, 29, 0x1f); | ||
1787 | } | ||
1774 | 1788 | ||
1775 | /* | 1789 | /* |
1776 | * Set RX Filter calibration for 20MHz and 40MHz | 1790 | * Set RX Filter calibration for 20MHz and 40MHz |
@@ -2644,6 +2658,8 @@ static int rt2800usb_probe_hw(struct rt2x00_dev *rt2x00dev) | |||
2644 | { | 2658 | { |
2645 | int retval; | 2659 | int retval; |
2646 | 2660 | ||
2661 | rt2x00_set_chip_intf(rt2x00dev, RT2X00_CHIP_INTF_USB); | ||
2662 | |||
2647 | rt2x00dev->priv = (void *)&rt2800usb_rt2800_ops; | 2663 | rt2x00dev->priv = (void *)&rt2800usb_rt2800_ops; |
2648 | 2664 | ||
2649 | /* | 2665 | /* |