aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/rt2x00/rt61pci.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/rt2x00/rt61pci.c')
-rw-r--r--drivers/net/wireless/rt2x00/rt61pci.c61
1 files changed, 29 insertions, 32 deletions
diff --git a/drivers/net/wireless/rt2x00/rt61pci.c b/drivers/net/wireless/rt2x00/rt61pci.c
index e13ed5ced26e..4658dbd7ef63 100644
--- a/drivers/net/wireless/rt2x00/rt61pci.c
+++ b/drivers/net/wireless/rt2x00/rt61pci.c
@@ -1270,25 +1270,32 @@ static int rt61pci_init_registers(struct rt2x00_dev *rt2x00dev)
1270 return 0; 1270 return 0;
1271} 1271}
1272 1272
1273static int rt61pci_init_bbp(struct rt2x00_dev *rt2x00dev) 1273static int rt61pci_wait_bbp_ready(struct rt2x00_dev *rt2x00dev)
1274{ 1274{
1275 unsigned int i; 1275 unsigned int i;
1276 u16 eeprom;
1277 u8 reg_id;
1278 u8 value; 1276 u8 value;
1279 1277
1280 for (i = 0; i < REGISTER_BUSY_COUNT; i++) { 1278 for (i = 0; i < REGISTER_BUSY_COUNT; i++) {
1281 rt61pci_bbp_read(rt2x00dev, 0, &value); 1279 rt61pci_bbp_read(rt2x00dev, 0, &value);
1282 if ((value != 0xff) && (value != 0x00)) 1280 if ((value != 0xff) && (value != 0x00))
1283 goto continue_csr_init; 1281 return 0;
1284 NOTICE(rt2x00dev, "Waiting for BBP register.\n");
1285 udelay(REGISTER_BUSY_DELAY); 1282 udelay(REGISTER_BUSY_DELAY);
1286 } 1283 }
1287 1284
1288 ERROR(rt2x00dev, "BBP register access failed, aborting.\n"); 1285 ERROR(rt2x00dev, "BBP register access failed, aborting.\n");
1289 return -EACCES; 1286 return -EACCES;
1287}
1288
1289static int rt61pci_init_bbp(struct rt2x00_dev *rt2x00dev)
1290{
1291 unsigned int i;
1292 u16 eeprom;
1293 u8 reg_id;
1294 u8 value;
1295
1296 if (unlikely(rt61pci_wait_bbp_ready(rt2x00dev)))
1297 return -EACCES;
1290 1298
1291continue_csr_init:
1292 rt61pci_bbp_write(rt2x00dev, 3, 0x00); 1299 rt61pci_bbp_write(rt2x00dev, 3, 0x00);
1293 rt61pci_bbp_write(rt2x00dev, 15, 0x30); 1300 rt61pci_bbp_write(rt2x00dev, 15, 0x30);
1294 rt61pci_bbp_write(rt2x00dev, 21, 0xc8); 1301 rt61pci_bbp_write(rt2x00dev, 21, 0xc8);
@@ -1337,7 +1344,8 @@ static void rt61pci_toggle_rx(struct rt2x00_dev *rt2x00dev,
1337 1344
1338 rt2x00pci_register_read(rt2x00dev, TXRX_CSR0, &reg); 1345 rt2x00pci_register_read(rt2x00dev, TXRX_CSR0, &reg);
1339 rt2x00_set_field32(&reg, TXRX_CSR0_DISABLE_RX, 1346 rt2x00_set_field32(&reg, TXRX_CSR0_DISABLE_RX,
1340 state == STATE_RADIO_RX_OFF); 1347 (state == STATE_RADIO_RX_OFF) ||
1348 (state == STATE_RADIO_RX_OFF_LINK));
1341 rt2x00pci_register_write(rt2x00dev, TXRX_CSR0, reg); 1349 rt2x00pci_register_write(rt2x00dev, TXRX_CSR0, reg);
1342} 1350}
1343 1351
@@ -1389,17 +1397,10 @@ static int rt61pci_enable_radio(struct rt2x00_dev *rt2x00dev)
1389 /* 1397 /*
1390 * Initialize all registers. 1398 * Initialize all registers.
1391 */ 1399 */
1392 if (rt61pci_init_queues(rt2x00dev) || 1400 if (unlikely(rt61pci_init_queues(rt2x00dev) ||
1393 rt61pci_init_registers(rt2x00dev) || 1401 rt61pci_init_registers(rt2x00dev) ||
1394 rt61pci_init_bbp(rt2x00dev)) { 1402 rt61pci_init_bbp(rt2x00dev)))
1395 ERROR(rt2x00dev, "Register initialization failed.\n");
1396 return -EIO; 1403 return -EIO;
1397 }
1398
1399 /*
1400 * Enable interrupts.
1401 */
1402 rt61pci_toggle_irq(rt2x00dev, STATE_RADIO_IRQ_ON);
1403 1404
1404 /* 1405 /*
1405 * Enable RX. 1406 * Enable RX.
@@ -1431,11 +1432,6 @@ static void rt61pci_disable_radio(struct rt2x00_dev *rt2x00dev)
1431 rt2x00_set_field32(&reg, TX_CNTL_CSR_ABORT_TX_AC2, 1); 1432 rt2x00_set_field32(&reg, TX_CNTL_CSR_ABORT_TX_AC2, 1);
1432 rt2x00_set_field32(&reg, TX_CNTL_CSR_ABORT_TX_AC3, 1); 1433 rt2x00_set_field32(&reg, TX_CNTL_CSR_ABORT_TX_AC3, 1);
1433 rt2x00pci_register_write(rt2x00dev, TX_CNTL_CSR, reg); 1434 rt2x00pci_register_write(rt2x00dev, TX_CNTL_CSR, reg);
1434
1435 /*
1436 * Disable interrupts.
1437 */
1438 rt61pci_toggle_irq(rt2x00dev, STATE_RADIO_IRQ_OFF);
1439} 1435}
1440 1436
1441static int rt61pci_set_state(struct rt2x00_dev *rt2x00dev, enum dev_state state) 1437static int rt61pci_set_state(struct rt2x00_dev *rt2x00dev, enum dev_state state)
@@ -1443,7 +1439,6 @@ static int rt61pci_set_state(struct rt2x00_dev *rt2x00dev, enum dev_state state)
1443 u32 reg; 1439 u32 reg;
1444 unsigned int i; 1440 unsigned int i;
1445 char put_to_sleep; 1441 char put_to_sleep;
1446 char current_state;
1447 1442
1448 put_to_sleep = (state != STATE_AWAKE); 1443 put_to_sleep = (state != STATE_AWAKE);
1449 1444
@@ -1459,16 +1454,12 @@ static int rt61pci_set_state(struct rt2x00_dev *rt2x00dev, enum dev_state state)
1459 */ 1454 */
1460 for (i = 0; i < REGISTER_BUSY_COUNT; i++) { 1455 for (i = 0; i < REGISTER_BUSY_COUNT; i++) {
1461 rt2x00pci_register_read(rt2x00dev, MAC_CSR12, &reg); 1456 rt2x00pci_register_read(rt2x00dev, MAC_CSR12, &reg);
1462 current_state = 1457 state = rt2x00_get_field32(reg, MAC_CSR12_BBP_CURRENT_STATE);
1463 rt2x00_get_field32(reg, MAC_CSR12_BBP_CURRENT_STATE); 1458 if (state == !put_to_sleep)
1464 if (current_state == !put_to_sleep)
1465 return 0; 1459 return 0;
1466 msleep(10); 1460 msleep(10);
1467 } 1461 }
1468 1462
1469 NOTICE(rt2x00dev, "Device failed to enter state %d, "
1470 "current device state %d.\n", !put_to_sleep, current_state);
1471
1472 return -EBUSY; 1463 return -EBUSY;
1473} 1464}
1474 1465
@@ -1486,11 +1477,13 @@ static int rt61pci_set_device_state(struct rt2x00_dev *rt2x00dev,
1486 break; 1477 break;
1487 case STATE_RADIO_RX_ON: 1478 case STATE_RADIO_RX_ON:
1488 case STATE_RADIO_RX_ON_LINK: 1479 case STATE_RADIO_RX_ON_LINK:
1489 rt61pci_toggle_rx(rt2x00dev, STATE_RADIO_RX_ON);
1490 break;
1491 case STATE_RADIO_RX_OFF: 1480 case STATE_RADIO_RX_OFF:
1492 case STATE_RADIO_RX_OFF_LINK: 1481 case STATE_RADIO_RX_OFF_LINK:
1493 rt61pci_toggle_rx(rt2x00dev, STATE_RADIO_RX_OFF); 1482 rt61pci_toggle_rx(rt2x00dev, state);
1483 break;
1484 case STATE_RADIO_IRQ_ON:
1485 case STATE_RADIO_IRQ_OFF:
1486 rt61pci_toggle_irq(rt2x00dev, state);
1494 break; 1487 break;
1495 case STATE_DEEP_SLEEP: 1488 case STATE_DEEP_SLEEP:
1496 case STATE_SLEEP: 1489 case STATE_SLEEP:
@@ -1503,6 +1496,10 @@ static int rt61pci_set_device_state(struct rt2x00_dev *rt2x00dev,
1503 break; 1496 break;
1504 } 1497 }
1505 1498
1499 if (unlikely(retval))
1500 ERROR(rt2x00dev, "Device failed to enter state %d (%d).\n",
1501 state, retval);
1502
1506 return retval; 1503 return retval;
1507} 1504}
1508 1505