aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/mwifiex
diff options
context:
space:
mode:
authorAvinash Patil <patila@marvell.com>2013-02-21 00:12:58 -0500
committerJohn W. Linville <linville@tuxdriver.com>2013-02-22 14:50:46 -0500
commit48f4d91679c0e0b26747f8adbb18e5212eb6d621 (patch)
treeb569e3d8640cc3ef82ac4c930d46b723dfd7dd17 /drivers/net/wireless/mwifiex
parent1499d9fa54a41942973bfc2c4ab12ccc5f1e15de (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.c11
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)
908static int mwifiex_clean_pcie_ring_buf(struct mwifiex_adapter *adapter) 908static 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.