diff options
Diffstat (limited to 'drivers/net/wireless')
| -rw-r--r-- | drivers/net/wireless/iwlwifi/iwl-pci.c | 25 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2800usb.c | 20 | ||||
| -rw-r--r-- | drivers/net/wireless/rt2x00/rt2x00usb.c | 17 | ||||
| -rw-r--r-- | drivers/net/wireless/wl12xx/acx.c | 6 | ||||
| -rw-r--r-- | drivers/net/wireless/wl12xx/testmode.c | 5 |
5 files changed, 37 insertions, 36 deletions
diff --git a/drivers/net/wireless/iwlwifi/iwl-pci.c b/drivers/net/wireless/iwlwifi/iwl-pci.c index 69d4ec467dca..2fdbffa079c1 100644 --- a/drivers/net/wireless/iwlwifi/iwl-pci.c +++ b/drivers/net/wireless/iwlwifi/iwl-pci.c | |||
| @@ -478,27 +478,22 @@ out_no_pci: | |||
| 478 | return err; | 478 | return err; |
| 479 | } | 479 | } |
| 480 | 480 | ||
| 481 | static void iwl_pci_down(struct iwl_bus *bus) | ||
| 482 | { | ||
| 483 | struct iwl_pci_bus *pci_bus = (struct iwl_pci_bus *) bus->bus_specific; | ||
| 484 | |||
| 485 | pci_disable_msi(pci_bus->pci_dev); | ||
| 486 | pci_iounmap(pci_bus->pci_dev, pci_bus->hw_base); | ||
| 487 | pci_release_regions(pci_bus->pci_dev); | ||
| 488 | pci_disable_device(pci_bus->pci_dev); | ||
| 489 | pci_set_drvdata(pci_bus->pci_dev, NULL); | ||
| 490 | |||
| 491 | kfree(bus); | ||
| 492 | } | ||
| 493 | |||
| 494 | static void __devexit iwl_pci_remove(struct pci_dev *pdev) | 481 | static void __devexit iwl_pci_remove(struct pci_dev *pdev) |
| 495 | { | 482 | { |
| 496 | struct iwl_priv *priv = pci_get_drvdata(pdev); | 483 | struct iwl_priv *priv = pci_get_drvdata(pdev); |
| 497 | void *bus_specific = priv->bus->bus_specific; | 484 | struct iwl_bus *bus = priv->bus; |
| 485 | struct iwl_pci_bus *pci_bus = IWL_BUS_GET_PCI_BUS(bus); | ||
| 486 | struct pci_dev *pci_dev = IWL_BUS_GET_PCI_DEV(bus); | ||
| 498 | 487 | ||
| 499 | iwl_remove(priv); | 488 | iwl_remove(priv); |
| 500 | 489 | ||
| 501 | iwl_pci_down(bus_specific); | 490 | pci_disable_msi(pci_dev); |
| 491 | pci_iounmap(pci_dev, pci_bus->hw_base); | ||
| 492 | pci_release_regions(pci_dev); | ||
| 493 | pci_disable_device(pci_dev); | ||
| 494 | pci_set_drvdata(pci_dev, NULL); | ||
| 495 | |||
| 496 | kfree(bus); | ||
| 502 | } | 497 | } |
| 503 | 498 | ||
| 504 | #ifdef CONFIG_PM | 499 | #ifdef CONFIG_PM |
diff --git a/drivers/net/wireless/rt2x00/rt2800usb.c b/drivers/net/wireless/rt2x00/rt2800usb.c index 939563162fb3..dbf501ca317f 100644 --- a/drivers/net/wireless/rt2x00/rt2800usb.c +++ b/drivers/net/wireless/rt2x00/rt2800usb.c | |||
| @@ -464,6 +464,15 @@ static bool rt2800usb_txdone_entry_check(struct queue_entry *entry, u32 reg) | |||
| 464 | int wcid, ack, pid; | 464 | int wcid, ack, pid; |
| 465 | int tx_wcid, tx_ack, tx_pid; | 465 | int tx_wcid, tx_ack, tx_pid; |
| 466 | 466 | ||
| 467 | if (test_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags) || | ||
| 468 | !test_bit(ENTRY_DATA_STATUS_PENDING, &entry->flags)) { | ||
| 469 | WARNING(entry->queue->rt2x00dev, | ||
| 470 | "Data pending for entry %u in queue %u\n", | ||
| 471 | entry->entry_idx, entry->queue->qid); | ||
| 472 | cond_resched(); | ||
| 473 | return false; | ||
| 474 | } | ||
| 475 | |||
| 467 | wcid = rt2x00_get_field32(reg, TX_STA_FIFO_WCID); | 476 | wcid = rt2x00_get_field32(reg, TX_STA_FIFO_WCID); |
| 468 | ack = rt2x00_get_field32(reg, TX_STA_FIFO_TX_ACK_REQUIRED); | 477 | ack = rt2x00_get_field32(reg, TX_STA_FIFO_TX_ACK_REQUIRED); |
| 469 | pid = rt2x00_get_field32(reg, TX_STA_FIFO_PID_TYPE); | 478 | pid = rt2x00_get_field32(reg, TX_STA_FIFO_PID_TYPE); |
| @@ -529,12 +538,11 @@ static void rt2800usb_txdone(struct rt2x00_dev *rt2x00dev) | |||
| 529 | entry = rt2x00queue_get_entry(queue, Q_INDEX_DONE); | 538 | entry = rt2x00queue_get_entry(queue, Q_INDEX_DONE); |
| 530 | if (rt2800usb_txdone_entry_check(entry, reg)) | 539 | if (rt2800usb_txdone_entry_check(entry, reg)) |
| 531 | break; | 540 | break; |
| 541 | entry = NULL; | ||
| 532 | } | 542 | } |
| 533 | 543 | ||
| 534 | if (!entry || rt2x00queue_empty(queue)) | 544 | if (entry) |
| 535 | break; | 545 | rt2800_txdone_entry(entry, reg); |
| 536 | |||
| 537 | rt2800_txdone_entry(entry, reg); | ||
| 538 | } | 546 | } |
| 539 | } | 547 | } |
| 540 | 548 | ||
| @@ -558,8 +566,10 @@ static void rt2800usb_work_txdone(struct work_struct *work) | |||
| 558 | while (!rt2x00queue_empty(queue)) { | 566 | while (!rt2x00queue_empty(queue)) { |
| 559 | entry = rt2x00queue_get_entry(queue, Q_INDEX_DONE); | 567 | entry = rt2x00queue_get_entry(queue, Q_INDEX_DONE); |
| 560 | 568 | ||
| 561 | if (test_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags)) | 569 | if (test_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags) || |
| 570 | !test_bit(ENTRY_DATA_STATUS_PENDING, &entry->flags)) | ||
| 562 | break; | 571 | break; |
| 572 | |||
| 563 | if (test_bit(ENTRY_DATA_IO_FAILED, &entry->flags)) | 573 | if (test_bit(ENTRY_DATA_IO_FAILED, &entry->flags)) |
| 564 | rt2x00lib_txdone_noinfo(entry, TXDONE_FAILURE); | 574 | rt2x00lib_txdone_noinfo(entry, TXDONE_FAILURE); |
| 565 | else if (rt2x00queue_status_timeout(entry)) | 575 | else if (rt2x00queue_status_timeout(entry)) |
diff --git a/drivers/net/wireless/rt2x00/rt2x00usb.c b/drivers/net/wireless/rt2x00/rt2x00usb.c index b6b4542c2460..7fbb55c9da82 100644 --- a/drivers/net/wireless/rt2x00/rt2x00usb.c +++ b/drivers/net/wireless/rt2x00/rt2x00usb.c | |||
| @@ -262,23 +262,20 @@ static void rt2x00usb_interrupt_txdone(struct urb *urb) | |||
| 262 | struct queue_entry *entry = (struct queue_entry *)urb->context; | 262 | struct queue_entry *entry = (struct queue_entry *)urb->context; |
| 263 | struct rt2x00_dev *rt2x00dev = entry->queue->rt2x00dev; | 263 | struct rt2x00_dev *rt2x00dev = entry->queue->rt2x00dev; |
| 264 | 264 | ||
| 265 | if (!test_and_clear_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags)) | 265 | if (!test_bit(ENTRY_OWNER_DEVICE_DATA, &entry->flags)) |
| 266 | return; | 266 | return; |
| 267 | |||
| 268 | if (rt2x00dev->ops->lib->tx_dma_done) | ||
| 269 | rt2x00dev->ops->lib->tx_dma_done(entry); | ||
| 270 | |||
| 271 | /* | ||
| 272 | * Report the frame as DMA done | ||
| 273 | */ | ||
| 274 | rt2x00lib_dmadone(entry); | ||
| 275 | |||
| 276 | /* | 267 | /* |
| 277 | * Check if the frame was correctly uploaded | 268 | * Check if the frame was correctly uploaded |
| 278 | */ | 269 | */ |
| 279 | if (urb->status) | 270 | if (urb->status) |
| 280 | set_bit(ENTRY_DATA_IO_FAILED, &entry->flags); | 271 | set_bit(ENTRY_DATA_IO_FAILED, &entry->flags); |
| 272 | /* | ||
| 273 | * Report the frame as DMA done | ||
| 274 | */ | ||
| 275 | rt2x00lib_dmadone(entry); | ||
| 281 | 276 | ||
| 277 | if (rt2x00dev->ops->lib->tx_dma_done) | ||
| 278 | rt2x00dev->ops->lib->tx_dma_done(entry); | ||
| 282 | /* | 279 | /* |
| 283 | * Schedule the delayed work for reading the TX status | 280 | * Schedule the delayed work for reading the TX status |
| 284 | * from the device. | 281 | * from the device. |
diff --git a/drivers/net/wireless/wl12xx/acx.c b/drivers/net/wireless/wl12xx/acx.c index 7e33f1f4f3d4..34f6ab53e519 100644 --- a/drivers/net/wireless/wl12xx/acx.c +++ b/drivers/net/wireless/wl12xx/acx.c | |||
| @@ -77,8 +77,6 @@ int wl1271_acx_sleep_auth(struct wl1271 *wl, u8 sleep_auth) | |||
| 77 | auth->sleep_auth = sleep_auth; | 77 | auth->sleep_auth = sleep_auth; |
| 78 | 78 | ||
| 79 | ret = wl1271_cmd_configure(wl, ACX_SLEEP_AUTH, auth, sizeof(*auth)); | 79 | ret = wl1271_cmd_configure(wl, ACX_SLEEP_AUTH, auth, sizeof(*auth)); |
| 80 | if (ret < 0) | ||
| 81 | return ret; | ||
| 82 | 80 | ||
| 83 | out: | 81 | out: |
| 84 | kfree(auth); | 82 | kfree(auth); |
| @@ -624,10 +622,8 @@ int wl1271_acx_cca_threshold(struct wl1271 *wl) | |||
| 624 | 622 | ||
| 625 | ret = wl1271_cmd_configure(wl, ACX_CCA_THRESHOLD, | 623 | ret = wl1271_cmd_configure(wl, ACX_CCA_THRESHOLD, |
| 626 | detection, sizeof(*detection)); | 624 | detection, sizeof(*detection)); |
| 627 | if (ret < 0) { | 625 | if (ret < 0) |
| 628 | wl1271_warning("failed to set cca threshold: %d", ret); | 626 | wl1271_warning("failed to set cca threshold: %d", ret); |
| 629 | return ret; | ||
| 630 | } | ||
| 631 | 627 | ||
| 632 | out: | 628 | out: |
| 633 | kfree(detection); | 629 | kfree(detection); |
diff --git a/drivers/net/wireless/wl12xx/testmode.c b/drivers/net/wireless/wl12xx/testmode.c index 5d5e1ef87206..88add68bd9ac 100644 --- a/drivers/net/wireless/wl12xx/testmode.c +++ b/drivers/net/wireless/wl12xx/testmode.c | |||
| @@ -139,12 +139,15 @@ static int wl1271_tm_cmd_interrogate(struct wl1271 *wl, struct nlattr *tb[]) | |||
| 139 | 139 | ||
| 140 | if (ret < 0) { | 140 | if (ret < 0) { |
| 141 | wl1271_warning("testmode cmd interrogate failed: %d", ret); | 141 | wl1271_warning("testmode cmd interrogate failed: %d", ret); |
| 142 | kfree(cmd); | ||
| 142 | return ret; | 143 | return ret; |
| 143 | } | 144 | } |
| 144 | 145 | ||
| 145 | skb = cfg80211_testmode_alloc_reply_skb(wl->hw->wiphy, sizeof(*cmd)); | 146 | skb = cfg80211_testmode_alloc_reply_skb(wl->hw->wiphy, sizeof(*cmd)); |
| 146 | if (!skb) | 147 | if (!skb) { |
| 148 | kfree(cmd); | ||
| 147 | return -ENOMEM; | 149 | return -ENOMEM; |
| 150 | } | ||
| 148 | 151 | ||
| 149 | NLA_PUT(skb, WL1271_TM_ATTR_DATA, sizeof(*cmd), cmd); | 152 | NLA_PUT(skb, WL1271_TM_ATTR_DATA, sizeof(*cmd), cmd); |
| 150 | 153 | ||
