mwifiex: don't short-circuit netdev notifiers on interface deletion
When we leave the delete interface function, there are still netdev hooks that might try to process the device. We're short-circuiting some of that by changing the interface type and clearing ieee80211_ptr. This means we skip NETDEV_UNREGISTER_FINAL in cfg80211. Fortunately, that is currently a no-op. We don't need most of the cleanup here anyway: * the connection state will get (un)set as part of the disconnect process (which cfg80211 already initiates for us) * the interface type doesn't actually need to be cleared at all (it'll trigger a WARN_ON() in cfg80211 if we do) * the iee80211_ptr isn't really "ours" to clear anyway So stop resetting those 3 things. Signed-off-by: Brian Norris <briannorris@chromium.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
ce32d1d837
commit
6417dba335
@ -3123,11 +3123,7 @@ int mwifiex_del_virtual_intf(struct wiphy *wiphy, struct wireless_dev *wdev)
|
|||||||
priv->dfs_chan_sw_workqueue = NULL;
|
priv->dfs_chan_sw_workqueue = NULL;
|
||||||
}
|
}
|
||||||
/* Clear the priv in adapter */
|
/* Clear the priv in adapter */
|
||||||
priv->netdev->ieee80211_ptr = NULL;
|
|
||||||
priv->netdev = NULL;
|
priv->netdev = NULL;
|
||||||
priv->wdev.iftype = NL80211_IFTYPE_UNSPECIFIED;
|
|
||||||
|
|
||||||
priv->media_connected = false;
|
|
||||||
|
|
||||||
switch (priv->bss_mode) {
|
switch (priv->bss_mode) {
|
||||||
case NL80211_IFTYPE_UNSPECIFIED:
|
case NL80211_IFTYPE_UNSPECIFIED:
|
||||||
|
Loading…
Reference in New Issue
Block a user