diff options
author | Avinash Patil <patila@marvell.com> | 2013-02-21 00:12:58 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2013-02-22 14:50:46 -0500 |
commit | 48f4d91679c0e0b26747f8adbb18e5212eb6d621 (patch) | |
tree | b569e3d8640cc3ef82ac4c930d46b723dfd7dd17 /drivers/net/wireless/mwifiex | |
parent | 1499d9fa54a41942973bfc2c4ab12ccc5f1e15de (diff) |
mwifiex: fix system freeze while reloading driver
Unload sequence for mwifiex PCIE driver is as follows:
1. Invoking cleanup module from kernel results into
pci_unregister_driver
2. Kernel invokes PCIE remove() handler which disconnects all
interfaces.
3. One step during disconnect is to clean PCIE TX rings.
During this we read txbd_rdptr from FW.
While loading driver next time, we see pci_enable_device()
results into system freeze. This may have happened because we
accessed PCI device after unregistering from bus driver.
Removing this ioread() operation resolves this bug.
Signed-off-by: Avinash Patil <patila@marvell.com>
Signed-off-by: Bing Zhao <bzhao@marvell.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/mwifiex')
-rw-r--r-- | drivers/net/wireless/mwifiex/pcie.c | 11 |
1 files changed, 1 insertions, 10 deletions
diff --git a/drivers/net/wireless/mwifiex/pcie.c b/drivers/net/wireless/mwifiex/pcie.c index 22db934bd403..35c79722c361 100644 --- a/drivers/net/wireless/mwifiex/pcie.c +++ b/drivers/net/wireless/mwifiex/pcie.c | |||
@@ -908,17 +908,8 @@ static int mwifiex_pcie_delete_sleep_cookie_buf(struct mwifiex_adapter *adapter) | |||
908 | static int mwifiex_clean_pcie_ring_buf(struct mwifiex_adapter *adapter) | 908 | static int mwifiex_clean_pcie_ring_buf(struct mwifiex_adapter *adapter) |
909 | { | 909 | { |
910 | struct pcie_service_card *card = adapter->card; | 910 | struct pcie_service_card *card = adapter->card; |
911 | const struct mwifiex_pcie_card_reg *reg = card->pcie.reg; | ||
912 | u32 rdptr; | ||
913 | |||
914 | /* Read the TX ring read pointer set by firmware */ | ||
915 | if (mwifiex_read_reg(adapter, reg->tx_rdptr, &rdptr)) { | ||
916 | dev_err(adapter->dev, | ||
917 | "Flush TXBD: failed to read reg->tx_rdptr\n"); | ||
918 | return -1; | ||
919 | } | ||
920 | 911 | ||
921 | if (!mwifiex_pcie_txbd_empty(card, rdptr)) { | 912 | if (!mwifiex_pcie_txbd_empty(card, card->txbd_rdptr)) { |
922 | card->txbd_flush = 1; | 913 | card->txbd_flush = 1; |
923 | /* write pointer already set at last send | 914 | /* write pointer already set at last send |
924 | * send dnld-rdy intr again, wait for completion. | 915 | * send dnld-rdy intr again, wait for completion. |