wil6210: pass is_go flag to firmware
When starting a PCP, pass the is_go flag to firmware in wmi_pcp_start. This flag indicates whether we started a PCP which is also a GO(P2P group owner) or just a regular PCP. 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
375a173fc1
commit
b4944f2c08
|
@ -1055,10 +1055,17 @@ static int _wil_cfg80211_start_ap(struct wiphy *wiphy,
|
||||||
int rc;
|
int rc;
|
||||||
struct wireless_dev *wdev = ndev->ieee80211_ptr;
|
struct wireless_dev *wdev = ndev->ieee80211_ptr;
|
||||||
u8 wmi_nettype = wil_iftype_nl2wmi(wdev->iftype);
|
u8 wmi_nettype = wil_iftype_nl2wmi(wdev->iftype);
|
||||||
|
u8 is_go = (wdev->iftype == NL80211_IFTYPE_P2P_GO);
|
||||||
|
|
||||||
if (pbss)
|
if (pbss)
|
||||||
wmi_nettype = WMI_NETTYPE_P2P;
|
wmi_nettype = WMI_NETTYPE_P2P;
|
||||||
|
|
||||||
|
wil_dbg_misc(wil, "%s: is_go=%d\n", __func__, is_go);
|
||||||
|
if (is_go && !pbss) {
|
||||||
|
wil_err(wil, "%s: P2P GO must be in PBSS\n", __func__);
|
||||||
|
return -ENOTSUPP;
|
||||||
|
}
|
||||||
|
|
||||||
wil_set_recovery_state(wil, fw_recovery_idle);
|
wil_set_recovery_state(wil, fw_recovery_idle);
|
||||||
|
|
||||||
mutex_lock(&wil->mutex);
|
mutex_lock(&wil->mutex);
|
||||||
|
@ -1083,7 +1090,7 @@ static int _wil_cfg80211_start_ap(struct wiphy *wiphy,
|
||||||
|
|
||||||
netif_carrier_on(ndev);
|
netif_carrier_on(ndev);
|
||||||
|
|
||||||
rc = wmi_pcp_start(wil, bi, wmi_nettype, chan, hidden_ssid);
|
rc = wmi_pcp_start(wil, bi, wmi_nettype, chan, hidden_ssid, is_go);
|
||||||
if (rc)
|
if (rc)
|
||||||
goto err_pcp_start;
|
goto err_pcp_start;
|
||||||
|
|
||||||
|
|
|
@ -802,7 +802,7 @@ void wil_p2p_wdev_free(struct wil6210_priv *wil);
|
||||||
|
|
||||||
int wmi_set_mac_address(struct wil6210_priv *wil, void *addr);
|
int wmi_set_mac_address(struct wil6210_priv *wil, void *addr);
|
||||||
int wmi_pcp_start(struct wil6210_priv *wil, int bi, u8 wmi_nettype,
|
int wmi_pcp_start(struct wil6210_priv *wil, int bi, u8 wmi_nettype,
|
||||||
u8 chan, u8 hidden_ssid);
|
u8 chan, u8 hidden_ssid, u8 is_go);
|
||||||
int wmi_pcp_stop(struct wil6210_priv *wil);
|
int wmi_pcp_stop(struct wil6210_priv *wil);
|
||||||
void wil6210_disconnect(struct wil6210_priv *wil, const u8 *bssid,
|
void wil6210_disconnect(struct wil6210_priv *wil, const u8 *bssid,
|
||||||
u16 reason_code, bool from_event);
|
u16 reason_code, bool from_event);
|
||||||
|
|
|
@ -962,7 +962,7 @@ int wmi_set_mac_address(struct wil6210_priv *wil, void *addr)
|
||||||
}
|
}
|
||||||
|
|
||||||
int wmi_pcp_start(struct wil6210_priv *wil, int bi, u8 wmi_nettype,
|
int wmi_pcp_start(struct wil6210_priv *wil, int bi, u8 wmi_nettype,
|
||||||
u8 chan, u8 hidden_ssid)
|
u8 chan, u8 hidden_ssid, u8 is_go)
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
|
@ -973,6 +973,7 @@ int wmi_pcp_start(struct wil6210_priv *wil, int bi, u8 wmi_nettype,
|
||||||
.channel = chan - 1,
|
.channel = chan - 1,
|
||||||
.pcp_max_assoc_sta = max_assoc_sta,
|
.pcp_max_assoc_sta = max_assoc_sta,
|
||||||
.hidden_ssid = hidden_ssid,
|
.hidden_ssid = hidden_ssid,
|
||||||
|
.is_go = is_go,
|
||||||
};
|
};
|
||||||
struct {
|
struct {
|
||||||
struct wmi_cmd_hdr wmi;
|
struct wmi_cmd_hdr wmi;
|
||||||
|
|
Loading…
Reference in New Issue