diff options
| -rw-r--r-- | net/wireless/sme.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/net/wireless/sme.c b/net/wireless/sme.c index 6fb6a704ca40..9ddc00e3c239 100644 --- a/net/wireless/sme.c +++ b/net/wireless/sme.c | |||
| @@ -395,6 +395,8 @@ void __cfg80211_connect_result(struct net_device *dev, const u8 *bssid, | |||
| 395 | 395 | ||
| 396 | if (status != WLAN_STATUS_SUCCESS) { | 396 | if (status != WLAN_STATUS_SUCCESS) { |
| 397 | wdev->sme_state = CFG80211_SME_IDLE; | 397 | wdev->sme_state = CFG80211_SME_IDLE; |
| 398 | if (wdev->conn) | ||
| 399 | kfree(wdev->conn->ie); | ||
| 398 | kfree(wdev->conn); | 400 | kfree(wdev->conn); |
| 399 | wdev->conn = NULL; | 401 | wdev->conn = NULL; |
| 400 | kfree(wdev->connect_keys); | 402 | kfree(wdev->connect_keys); |
| @@ -779,6 +781,7 @@ int __cfg80211_connect(struct cfg80211_registered_device *rdev, | |||
| 779 | } | 781 | } |
| 780 | } | 782 | } |
| 781 | if (err) { | 783 | if (err) { |
| 784 | kfree(wdev->conn->ie); | ||
| 782 | kfree(wdev->conn); | 785 | kfree(wdev->conn); |
| 783 | wdev->conn = NULL; | 786 | wdev->conn = NULL; |
| 784 | wdev->sme_state = CFG80211_SME_IDLE; | 787 | wdev->sme_state = CFG80211_SME_IDLE; |
| @@ -848,6 +851,7 @@ int __cfg80211_disconnect(struct cfg80211_registered_device *rdev, | |||
| 848 | (wdev->conn->state == CFG80211_CONN_SCANNING || | 851 | (wdev->conn->state == CFG80211_CONN_SCANNING || |
| 849 | wdev->conn->state == CFG80211_CONN_SCAN_AGAIN)) { | 852 | wdev->conn->state == CFG80211_CONN_SCAN_AGAIN)) { |
| 850 | wdev->sme_state = CFG80211_SME_IDLE; | 853 | wdev->sme_state = CFG80211_SME_IDLE; |
| 854 | kfree(wdev->conn->ie); | ||
| 851 | kfree(wdev->conn); | 855 | kfree(wdev->conn); |
| 852 | wdev->conn = NULL; | 856 | wdev->conn = NULL; |
| 853 | wdev->ssid_len = 0; | 857 | wdev->ssid_len = 0; |
