nl80211: Add P2P operations
This commit is contained in:
parent
2883205ec8
commit
046b26a24e
1 changed files with 36 additions and 0 deletions
|
@ -747,9 +747,19 @@ static void mlme_event_deauth_disassoc(struct wpa_driver_nl80211_data *drv,
|
|||
if (type == EVENT_DISASSOC) {
|
||||
event.disassoc_info.addr = bssid;
|
||||
event.disassoc_info.reason_code = reason_code;
|
||||
if (frame + len > mgmt->u.disassoc.variable) {
|
||||
event.disassoc_info.ie = mgmt->u.disassoc.variable;
|
||||
event.disassoc_info.ie_len = frame + len -
|
||||
mgmt->u.disassoc.variable;
|
||||
}
|
||||
} else {
|
||||
event.deauth_info.addr = bssid;
|
||||
event.deauth_info.reason_code = reason_code;
|
||||
if (frame + len > mgmt->u.deauth.variable) {
|
||||
event.deauth_info.ie = mgmt->u.deauth.variable;
|
||||
event.deauth_info.ie_len = frame + len -
|
||||
mgmt->u.deauth.variable;
|
||||
}
|
||||
}
|
||||
|
||||
wpa_supplicant_event(drv->ctx, type, &event);
|
||||
|
@ -1312,6 +1322,7 @@ static int wpa_driver_nl80211_capa(struct wpa_driver_nl80211_data *drv)
|
|||
}
|
||||
|
||||
drv->capa.flags |= WPA_DRIVER_FLAGS_SET_KEYS_AFTER_ASSOC_DONE;
|
||||
drv->capa.flags |= WPA_DRIVER_FLAGS_P2P_CAPABLE;
|
||||
drv->capa.max_remain_on_chan = 5000;
|
||||
|
||||
return 0;
|
||||
|
@ -1572,6 +1583,25 @@ nla_put_failure:
|
|||
|
||||
static int nl80211_register_action_frames(struct wpa_driver_nl80211_data *drv)
|
||||
{
|
||||
#ifdef CONFIG_P2P
|
||||
/* GAS Initial Request */
|
||||
if (nl80211_register_action_frame(drv, (u8 *) "\x04\x0a", 2) < 0)
|
||||
return -1;
|
||||
/* GAS Initial Response */
|
||||
if (nl80211_register_action_frame(drv, (u8 *) "\x04\x0b", 2) < 0)
|
||||
return -1;
|
||||
/* P2P Public Action */
|
||||
if (nl80211_register_action_frame(drv,
|
||||
(u8 *) "\x04\x09\x50\x6f\x9a\x09",
|
||||
6) < 0)
|
||||
return -1;
|
||||
/* P2P Action */
|
||||
if (nl80211_register_action_frame(drv,
|
||||
(u8 *) "\x7f\x50\x6f\x9a\x09",
|
||||
5) < 0)
|
||||
return -1;
|
||||
#endif /* CONFIG_P2P */
|
||||
|
||||
/* FT Action frames */
|
||||
if (nl80211_register_action_frame(drv, (u8 *) "\x06", 1) < 0)
|
||||
return -1;
|
||||
|
@ -3752,6 +3782,9 @@ static int wpa_driver_nl80211_sta_set_flags(void *priv, const u8 *addr,
|
|||
static int wpa_driver_nl80211_ap(struct wpa_driver_nl80211_data *drv,
|
||||
struct wpa_driver_associate_params *params)
|
||||
{
|
||||
if (params->p2p)
|
||||
wpa_printf(MSG_DEBUG, "nl80211: Setup AP operations for P2P "
|
||||
"group (GO)");
|
||||
if (wpa_driver_nl80211_set_mode(&drv->first_bss, params->mode) ||
|
||||
wpa_driver_nl80211_set_freq(drv, params->freq, 0, 0)) {
|
||||
nl80211_remove_monitor_interface(drv);
|
||||
|
@ -4086,6 +4119,9 @@ static int wpa_driver_nl80211_associate(
|
|||
params->prev_bssid);
|
||||
}
|
||||
|
||||
if (params->p2p)
|
||||
wpa_printf(MSG_DEBUG, " * P2P group");
|
||||
|
||||
ret = send_and_recv_msgs(drv, msg, NULL, NULL);
|
||||
msg = NULL;
|
||||
if (ret) {
|
||||
|
|
Loading…
Reference in a new issue