diff --git a/[refs] b/[refs] index 57fdd1be2bde..66c2f144d44c 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c9cf01226e0bd1fa4f7f7024d8d53e982fad208f +refs/heads/master: 78485475618cf9f1c70dc7f15e8deafa8b6074ab diff --git a/trunk/net/wireless/core.c b/trunk/net/wireless/core.c index 7b66cf15349a..83ec7197bd7c 100644 --- a/trunk/net/wireless/core.c +++ b/trunk/net/wireless/core.c @@ -567,9 +567,6 @@ static int cfg80211_netdev_notifier_call(struct notifier_block * nb, #endif break; case NETDEV_GOING_DOWN: - if (!wdev->ssid_len) - break; - switch (wdev->iftype) { case NL80211_IFTYPE_ADHOC: cfg80211_leave_ibss(rdev, dev, true); diff --git a/trunk/net/wireless/ibss.c b/trunk/net/wireless/ibss.c index c92b542d54b0..a5330c5a5477 100644 --- a/trunk/net/wireless/ibss.c +++ b/trunk/net/wireless/ibss.c @@ -92,8 +92,12 @@ void cfg80211_clear_ibss(struct net_device *dev, bool nowext) int cfg80211_leave_ibss(struct cfg80211_registered_device *rdev, struct net_device *dev, bool nowext) { + struct wireless_dev *wdev = dev->ieee80211_ptr; int err; + if (!wdev->ssid_len) + return -ENOLINK; + err = rdev->ops->leave_ibss(&rdev->wiphy, dev); if (err)