diff options
author | Jakub Kicinski <kubakici@wp.pl> | 2012-04-02 21:40:49 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-04-13 14:32:48 -0400 |
commit | 52b8243b75598c341143f67c56b0104938487231 (patch) | |
tree | ede3849e4fd841a7d5db332422af09e1913d6754 /drivers/net/wireless | |
parent | b7e1d225f5c2d397136fd79472d32b0f87017612 (diff) |
rt2800: initialize queues before giving up due to DMA error
Don't immediately abort .start if DMA is busy before we
initialize the queues. Some drivers do not deinitialize
queues properly and we would fail to take over after them.
This behaviour is consistent with legacy driver.
Signed-off-by: Jakub Kicinski <kubakici@wp.pl>
Acked-by: Gertjan van Wingerde <gwingerde@gmail.com>
Reviewed-by: Stanislaw Gruszka <sgruszka@redhat.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2800lib.c | 2 | ||||
-rw-r--r-- | drivers/net/wireless/rt2x00/rt2800pci.c | 6 |
2 files changed, 5 insertions, 3 deletions
diff --git a/drivers/net/wireless/rt2x00/rt2800lib.c b/drivers/net/wireless/rt2x00/rt2800lib.c index cc6ca183f3bf..bd1980202f19 100644 --- a/drivers/net/wireless/rt2x00/rt2800lib.c +++ b/drivers/net/wireless/rt2x00/rt2800lib.c | |||
@@ -290,7 +290,7 @@ int rt2800_wait_wpdma_ready(struct rt2x00_dev *rt2x00dev) | |||
290 | msleep(10); | 290 | msleep(10); |
291 | } | 291 | } |
292 | 292 | ||
293 | ERROR(rt2x00dev, "WPDMA TX/RX busy, aborting.\n"); | 293 | ERROR(rt2x00dev, "WPDMA TX/RX busy [0x%08x].\n", reg); |
294 | return -EACCES; | 294 | return -EACCES; |
295 | } | 295 | } |
296 | EXPORT_SYMBOL_GPL(rt2800_wait_wpdma_ready); | 296 | EXPORT_SYMBOL_GPL(rt2800_wait_wpdma_ready); |
diff --git a/drivers/net/wireless/rt2x00/rt2800pci.c b/drivers/net/wireless/rt2x00/rt2800pci.c index e499389d8cd3..4366c23672f0 100644 --- a/drivers/net/wireless/rt2x00/rt2800pci.c +++ b/drivers/net/wireless/rt2x00/rt2800pci.c | |||
@@ -496,8 +496,10 @@ static int rt2800pci_enable_radio(struct rt2x00_dev *rt2x00dev) | |||
496 | { | 496 | { |
497 | int retval; | 497 | int retval; |
498 | 498 | ||
499 | if (unlikely(rt2800_wait_wpdma_ready(rt2x00dev) || | 499 | /* Wait for DMA, ignore error until we initialize queues. */ |
500 | rt2800pci_init_queues(rt2x00dev))) | 500 | rt2800_wait_wpdma_ready(rt2x00dev); |
501 | |||
502 | if (unlikely(rt2800pci_init_queues(rt2x00dev))) | ||
501 | return -EIO; | 503 | return -EIO; |
502 | 504 | ||
503 | retval = rt2800_enable_radio(rt2x00dev); | 505 | retval = rt2800_enable_radio(rt2x00dev); |