aboutsummaryrefslogtreecommitdiffstats
path: root/net/wireless/mlme.c
diff options
context:
space:
mode:
authorJohannes Berg <johannes@sipsolutions.net>2009-07-27 04:22:28 -0400
committerJohn W. Linville <linville@tuxdriver.com>2009-07-29 15:46:11 -0400
commitf9d6b402603a63b5e5b56bd7a79fa72a818be55b (patch)
treef1568e0d82005fb40186d5436627841be053ac87 /net/wireless/mlme.c
parentfec247c0d5bfbaa0861774ce31d515bbd48f7fce (diff)
cfg80211: fix disassoc while not associated
When trying to disassociate while not associated, the kernel would crash rather than refusing the operation, fix this; Reported-by: Maxim Levitsky <maximlevitsky@gmail.com> Signed-off-by: Johannes Berg <johannes@sipsolutions.net> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'net/wireless/mlme.c')
-rw-r--r--net/wireless/mlme.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/net/wireless/mlme.c b/net/wireless/mlme.c
index 5b9b22120824..30058a80d7af 100644
--- a/net/wireless/mlme.c
+++ b/net/wireless/mlme.c
@@ -545,6 +545,12 @@ static int __cfg80211_mlme_disassoc(struct cfg80211_registered_device *rdev,
545 545
546 ASSERT_WDEV_LOCK(wdev); 546 ASSERT_WDEV_LOCK(wdev);
547 547
548 if (wdev->sme_state != CFG80211_SME_CONNECTED)
549 return -ENOTCONN;
550
551 if (WARN_ON(!wdev->current_bss))
552 return -ENOTCONN;
553
548 memset(&req, 0, sizeof(req)); 554 memset(&req, 0, sizeof(req));
549 req.reason_code = reason; 555 req.reason_code = reason;
550 req.ie = ie; 556 req.ie = ie;