P2P: Relax wpas_p2p_init_go_params() for P2P GO CSA

wpas_p2p_move_go_csa() uses wpas_p2p_init_p2p_params() to select the
frequency to move to. However, it is possible that all the channels are
already used, so the selection of a new frequency would fail, although
the frequency used by the P2P GO should not be considered as used if it
is the only one using it.

To overcome this, allow the frequency selection to continue even if all
the frequencies are in use, but the frequency used by the P2P GO is not
used by any station interface.

Signed-off-by: Ilan Peer <ilan.peer@intel.com>
This commit is contained in:
Ilan Peer 2015-09-08 12:46:17 +03:00 committed by Jouni Malinen
parent 73afc20d40
commit 23dcb302eb

View file

@ -5533,23 +5533,41 @@ static int wpas_p2p_init_go_params(struct wpa_supplicant *wpa_s,
struct wpa_used_freq_data *freqs; struct wpa_used_freq_data *freqs;
unsigned int cand; unsigned int cand;
unsigned int num, i; unsigned int num, i;
int ignore_no_freqs = 0;
os_memset(params, 0, sizeof(*params)); os_memset(params, 0, sizeof(*params));
params->role_go = 1; params->role_go = 1;
params->ht40 = ht40; params->ht40 = ht40;
params->vht = vht; params->vht = vht;
if (wpa_s->p2p_group_common_freqs_num)
wpa_printf(MSG_DEBUG, "P2P: %s called for an active GO",
__func__);
freqs = os_calloc(wpa_s->num_multichan_concurrent, freqs = os_calloc(wpa_s->num_multichan_concurrent,
sizeof(struct wpa_used_freq_data)); sizeof(struct wpa_used_freq_data));
if (!freqs) if (!freqs)
return -1; return -1;
num = wpas_p2p_valid_oper_freqs(wpa_s, freqs, num = get_shared_radio_freqs_data(wpa_s, freqs,
wpa_s->num_multichan_concurrent); wpa_s->num_multichan_concurrent);
if (wpa_s->current_ssid &&
wpa_s->current_ssid->mode == WPAS_MODE_P2P_GO &&
wpa_s->wpa_state == WPA_COMPLETED) {
wpa_printf(MSG_DEBUG, "P2P: %s called for an active GO",
__func__);
/*
* If the frequency selection is done for an active P2P GO that
* is not sharing a frequency, allow to select a new frequency
* even if there are no unused frequencies as we are about to
* move the P2P GO so its frequency can be re-used.
*/
for (i = 0; i < num; i++) {
if (freqs[i].freq == wpa_s->current_ssid->frequency &&
freqs[i].flags == 0) {
ignore_no_freqs = 1;
break;
}
}
}
/* try using the forced freq */ /* try using the forced freq */
if (freq) { if (freq) {
@ -5570,7 +5588,8 @@ static int wpas_p2p_init_go_params(struct wpa_supplicant *wpa_s,
} }
} }
if (wpas_p2p_num_unused_channels(wpa_s) <= 0) { if (!ignore_no_freqs &&
wpas_p2p_num_unused_channels(wpa_s) <= 0) {
wpa_printf(MSG_DEBUG, wpa_printf(MSG_DEBUG,
"P2P: Cannot force GO on freq (%d MHz) as all the channels are in use", "P2P: Cannot force GO on freq (%d MHz) as all the channels are in use",
freq); freq);
@ -5608,7 +5627,8 @@ static int wpas_p2p_init_go_params(struct wpa_supplicant *wpa_s,
} }
} }
if (wpas_p2p_num_unused_channels(wpa_s) <= 0) { if (!ignore_no_freqs &&
wpas_p2p_num_unused_channels(wpa_s) <= 0) {
wpa_printf(MSG_DEBUG, wpa_printf(MSG_DEBUG,
"P2P: Cannot force GO on any of the channels we are already using"); "P2P: Cannot force GO on any of the channels we are already using");
goto fail; goto fail;