aboutsummaryrefslogtreecommitdiffstats
path: root/net/wireless
diff options
context:
space:
mode:
authorJouni Malinen <jouni@qca.qualcomm.com>2016-03-29 06:53:28 -0400
committerJohannes Berg <johannes.berg@intel.com>2016-04-06 09:09:28 -0400
commit4ce2bd9c4c1dfb416206ff1ad5283f6d24af4031 (patch)
treebda1737b572117dbe5fdf04d6aa15cfae24c63ce /net/wireless
parentba6fbacf9c073effaedf0c52fe7e52e2baf67725 (diff)
cfg80211: Allow reassociation to be requested with internal SME
If the user space issues a NL80211_CMD_CONNECT with NL80211_ATTR_PREV_BSSID when there is already a connection, allow this to proceed as a reassociation instead of rejecting the new connect command with EALREADY. Signed-off-by: Jouni Malinen <jouni@qca.qualcomm.com> [validate prev_bssid] Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Diffstat (limited to 'net/wireless')
-rw-r--r--net/wireless/nl80211.c3
-rw-r--r--net/wireless/sme.c14
2 files changed, 14 insertions, 3 deletions
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c
index 4f89e2dbb70e..4f45a2913104 100644
--- a/net/wireless/nl80211.c
+++ b/net/wireless/nl80211.c
@@ -8151,7 +8151,8 @@ static int nl80211_connect(struct sk_buff *skb, struct genl_info *info)
8151 } 8151 }
8152 8152
8153 wdev_lock(dev->ieee80211_ptr); 8153 wdev_lock(dev->ieee80211_ptr);
8154 err = cfg80211_connect(rdev, dev, &connect, connkeys, NULL); 8154 err = cfg80211_connect(rdev, dev, &connect, connkeys,
8155 connect.prev_bssid);
8155 wdev_unlock(dev->ieee80211_ptr); 8156 wdev_unlock(dev->ieee80211_ptr);
8156 if (err) 8157 if (err)
8157 kzfree(connkeys); 8158 kzfree(connkeys);
diff --git a/net/wireless/sme.c b/net/wireless/sme.c
index 65882d2777c0..1fba41676428 100644
--- a/net/wireless/sme.c
+++ b/net/wireless/sme.c
@@ -492,8 +492,18 @@ static int cfg80211_sme_connect(struct wireless_dev *wdev,
492 if (!rdev->ops->auth || !rdev->ops->assoc) 492 if (!rdev->ops->auth || !rdev->ops->assoc)
493 return -EOPNOTSUPP; 493 return -EOPNOTSUPP;
494 494
495 if (wdev->current_bss) 495 if (wdev->current_bss) {
496 return -EALREADY; 496 if (!prev_bssid)
497 return -EALREADY;
498 if (prev_bssid &&
499 !ether_addr_equal(prev_bssid, wdev->current_bss->pub.bssid))
500 return -ENOTCONN;
501 cfg80211_unhold_bss(wdev->current_bss);
502 cfg80211_put_bss(wdev->wiphy, &wdev->current_bss->pub);
503 wdev->current_bss = NULL;
504
505 cfg80211_sme_free(wdev);
506 }
497 507
498 if (WARN_ON(wdev->conn)) 508 if (WARN_ON(wdev->conn))
499 return -EINPROGRESS; 509 return -EINPROGRESS;