aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/zd1211rw
diff options
context:
space:
mode:
authorJussi Kivilinna <jussi.kivilinna@mbnet.fi>2011-01-31 13:47:17 -0500
committerJohn W. Linville <linville@tuxdriver.com>2011-02-04 16:29:48 -0500
commitd741900d404b3a34bf478673f76ee9f16dad3f90 (patch)
tree24915e11f002efffc97acce19cd4d68711c742fb /drivers/net/wireless/zd1211rw
parent78fc800f06a72c25842e585fd747fa6a98f3f0e5 (diff)
zd1211rw: cancel process_intr work on zd_chip_disable_int()
OOPS if worker is running and disconnect() is called (triggered by unpluging device). Much harder to trigger at this stage but later when we have AP beacon work in process_intr it happens very easy. Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net/wireless/zd1211rw')
-rw-r--r--drivers/net/wireless/zd1211rw/zd_chip.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/wireless/zd1211rw/zd_chip.c b/drivers/net/wireless/zd1211rw/zd_chip.c
index 6a9b66051cf7..b644ced848e7 100644
--- a/drivers/net/wireless/zd1211rw/zd_chip.c
+++ b/drivers/net/wireless/zd1211rw/zd_chip.c
@@ -1407,6 +1407,9 @@ void zd_chip_disable_int(struct zd_chip *chip)
1407 mutex_lock(&chip->mutex); 1407 mutex_lock(&chip->mutex);
1408 zd_usb_disable_int(&chip->usb); 1408 zd_usb_disable_int(&chip->usb);
1409 mutex_unlock(&chip->mutex); 1409 mutex_unlock(&chip->mutex);
1410
1411 /* cancel pending interrupt work */
1412 cancel_work_sync(&zd_chip_to_mac(chip)->process_intr);
1410} 1413}
1411 1414
1412int zd_chip_enable_rxtx(struct zd_chip *chip) 1415int zd_chip_enable_rxtx(struct zd_chip *chip)