mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-07 15:01:44 +00:00
wil6210: ensure P2P device is stopped before removing interface
User space can remove the P2P management interface while it is active (for example, while listen/search is active) and this can cause a crash. Ensure the P2P device is fully stopped before removing. Signed-off-by: Lior David <qca_liord@qca.qualcomm.com> Signed-off-by: Maya Erez <qca_merez@qca.qualcomm.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
This commit is contained in:
parent
d83ad4c4fd
commit
69fecf599f
1 changed files with 29 additions and 28 deletions
|
@ -382,6 +382,34 @@ static int wil_cfg80211_dump_station(struct wiphy *wiphy,
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int wil_cfg80211_start_p2p_device(struct wiphy *wiphy,
|
||||||
|
struct wireless_dev *wdev)
|
||||||
|
{
|
||||||
|
struct wil6210_priv *wil = wiphy_to_wil(wiphy);
|
||||||
|
|
||||||
|
wil_dbg_misc(wil, "start_p2p_device: entered\n");
|
||||||
|
wil->p2p.p2p_dev_started = 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wil_cfg80211_stop_p2p_device(struct wiphy *wiphy,
|
||||||
|
struct wireless_dev *wdev)
|
||||||
|
{
|
||||||
|
struct wil6210_priv *wil = wiphy_to_wil(wiphy);
|
||||||
|
struct wil_p2p_info *p2p = &wil->p2p;
|
||||||
|
|
||||||
|
if (!p2p->p2p_dev_started)
|
||||||
|
return;
|
||||||
|
|
||||||
|
wil_dbg_misc(wil, "stop_p2p_device: entered\n");
|
||||||
|
mutex_lock(&wil->mutex);
|
||||||
|
mutex_lock(&wil->p2p_wdev_mutex);
|
||||||
|
wil_p2p_stop_radio_operations(wil);
|
||||||
|
p2p->p2p_dev_started = 0;
|
||||||
|
mutex_unlock(&wil->p2p_wdev_mutex);
|
||||||
|
mutex_unlock(&wil->mutex);
|
||||||
|
}
|
||||||
|
|
||||||
static struct wireless_dev *
|
static struct wireless_dev *
|
||||||
wil_cfg80211_add_iface(struct wiphy *wiphy, const char *name,
|
wil_cfg80211_add_iface(struct wiphy *wiphy, const char *name,
|
||||||
unsigned char name_assign_type,
|
unsigned char name_assign_type,
|
||||||
|
@ -430,6 +458,7 @@ static int wil_cfg80211_del_iface(struct wiphy *wiphy,
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wil_cfg80211_stop_p2p_device(wiphy, wdev);
|
||||||
wil_p2p_wdev_free(wil);
|
wil_p2p_wdev_free(wil);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1661,34 +1690,6 @@ static int wil_cfg80211_change_bss(struct wiphy *wiphy,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int wil_cfg80211_start_p2p_device(struct wiphy *wiphy,
|
|
||||||
struct wireless_dev *wdev)
|
|
||||||
{
|
|
||||||
struct wil6210_priv *wil = wiphy_to_wil(wiphy);
|
|
||||||
|
|
||||||
wil_dbg_misc(wil, "start_p2p_device: entered\n");
|
|
||||||
wil->p2p.p2p_dev_started = 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void wil_cfg80211_stop_p2p_device(struct wiphy *wiphy,
|
|
||||||
struct wireless_dev *wdev)
|
|
||||||
{
|
|
||||||
struct wil6210_priv *wil = wiphy_to_wil(wiphy);
|
|
||||||
struct wil_p2p_info *p2p = &wil->p2p;
|
|
||||||
|
|
||||||
if (!p2p->p2p_dev_started)
|
|
||||||
return;
|
|
||||||
|
|
||||||
wil_dbg_misc(wil, "stop_p2p_device: entered\n");
|
|
||||||
mutex_lock(&wil->mutex);
|
|
||||||
mutex_lock(&wil->p2p_wdev_mutex);
|
|
||||||
wil_p2p_stop_radio_operations(wil);
|
|
||||||
p2p->p2p_dev_started = 0;
|
|
||||||
mutex_unlock(&wil->p2p_wdev_mutex);
|
|
||||||
mutex_unlock(&wil->mutex);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int wil_cfg80211_set_power_mgmt(struct wiphy *wiphy,
|
static int wil_cfg80211_set_power_mgmt(struct wiphy *wiphy,
|
||||||
struct net_device *dev,
|
struct net_device *dev,
|
||||||
bool enabled, int timeout)
|
bool enabled, int timeout)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue