diff options
| -rw-r--r-- | net/wireless/sme.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/net/wireless/sme.c b/net/wireless/sme.c index ece378d531ef..9f0b2800a9d7 100644 --- a/net/wireless/sme.c +++ b/net/wireless/sme.c | |||
| @@ -165,7 +165,7 @@ void cfg80211_conn_work(struct work_struct *work) | |||
| 165 | struct cfg80211_registered_device *rdev = | 165 | struct cfg80211_registered_device *rdev = |
| 166 | container_of(work, struct cfg80211_registered_device, conn_work); | 166 | container_of(work, struct cfg80211_registered_device, conn_work); |
| 167 | struct wireless_dev *wdev; | 167 | struct wireless_dev *wdev; |
| 168 | u8 bssid[ETH_ALEN]; | 168 | u8 bssid_buf[ETH_ALEN], *bssid = NULL; |
| 169 | 169 | ||
| 170 | rtnl_lock(); | 170 | rtnl_lock(); |
| 171 | cfg80211_lock_rdev(rdev); | 171 | cfg80211_lock_rdev(rdev); |
| @@ -181,7 +181,10 @@ void cfg80211_conn_work(struct work_struct *work) | |||
| 181 | wdev_unlock(wdev); | 181 | wdev_unlock(wdev); |
| 182 | continue; | 182 | continue; |
| 183 | } | 183 | } |
| 184 | memcpy(bssid, wdev->conn->params.bssid, ETH_ALEN); | 184 | if (wdev->conn->params.bssid) { |
| 185 | memcpy(bssid_buf, wdev->conn->params.bssid, ETH_ALEN); | ||
| 186 | bssid = bssid_buf; | ||
| 187 | } | ||
| 185 | if (cfg80211_conn_do_work(wdev)) | 188 | if (cfg80211_conn_do_work(wdev)) |
| 186 | __cfg80211_connect_result( | 189 | __cfg80211_connect_result( |
| 187 | wdev->netdev, bssid, | 190 | wdev->netdev, bssid, |
