nl80211: Change vif type to P2P_CLI upon P2P authentication

Currently, wpa_driver_nl80211_authenticate() changes the interface type
to station. However, in case of P2P, we need to change the interface
type to P2P_CLI.

Add p2p field to the authentication params, and consider it for choosing
the correct interface type.

Signed-off-by: Eliad Peller <eliad@wizery.com>
This commit is contained in:
Eliad Peller 2011-07-17 20:25:58 +03:00 committed by Jouni Malinen
parent b1f625e0d8
commit 2f4f73b154
3 changed files with 12 additions and 2 deletions

View File

@ -282,6 +282,12 @@ struct wpa_driver_auth_params {
size_t wep_key_len[4]; size_t wep_key_len[4];
int wep_tx_keyidx; int wep_tx_keyidx;
int local_state_change; int local_state_change;
/**
* p2p - Whether this connection is a P2P group
*/
int p2p;
}; };
enum wps_mode { enum wps_mode {

View File

@ -3160,13 +3160,16 @@ static int wpa_driver_nl80211_authenticate(
int ret = -1, i; int ret = -1, i;
struct nl_msg *msg; struct nl_msg *msg;
enum nl80211_auth_type type; enum nl80211_auth_type type;
enum nl80211_iftype nlmode;
int count = 0; int count = 0;
drv->associated = 0; drv->associated = 0;
os_memset(drv->auth_bssid, 0, ETH_ALEN); os_memset(drv->auth_bssid, 0, ETH_ALEN);
/* FIX: IBSS mode */ /* FIX: IBSS mode */
if (drv->nlmode != NL80211_IFTYPE_STATION && nlmode = params->p2p ?
wpa_driver_nl80211_set_mode(priv, NL80211_IFTYPE_STATION) < 0) NL80211_IFTYPE_P2P_CLIENT : NL80211_IFTYPE_STATION;
if (drv->nlmode != nlmode &&
wpa_driver_nl80211_set_mode(priv, nlmode) < 0)
return -1; return -1;
retry: retry:

View File

@ -72,6 +72,7 @@ void sme_authenticate(struct wpa_supplicant *wpa_s,
params.bssid = bss->bssid; params.bssid = bss->bssid;
params.ssid = bss->ssid; params.ssid = bss->ssid;
params.ssid_len = bss->ssid_len; params.ssid_len = bss->ssid_len;
params.p2p = ssid->p2p_group;
if (wpa_s->sme.ssid_len != params.ssid_len || if (wpa_s->sme.ssid_len != params.ssid_len ||
os_memcmp(wpa_s->sme.ssid, params.ssid, params.ssid_len) != 0) os_memcmp(wpa_s->sme.ssid, params.ssid, params.ssid_len) != 0)