GAS: Add support for multiple pending queries for the same destination
Need to use the pointer to the current ongoing query instead of matching from the pending list based on the destination address so that we get the correct query instance when processing the TX status report. Signed-hostap: Jouni Malinen <jouni@qca.qualcomm.com>
This commit is contained in:
parent
cbc5484892
commit
313424d46e
1 changed files with 18 additions and 11 deletions
|
@ -153,21 +153,25 @@ static void gas_query_tx_status(struct wpa_supplicant *wpa_s,
|
||||||
const u8 *data, size_t data_len,
|
const u8 *data, size_t data_len,
|
||||||
enum offchannel_send_action_result result)
|
enum offchannel_send_action_result result)
|
||||||
{
|
{
|
||||||
struct gas_query_pending *q, *query = NULL;
|
struct gas_query_pending *query;
|
||||||
struct gas_query *gas = wpa_s->gas;
|
struct gas_query *gas = wpa_s->gas;
|
||||||
|
|
||||||
dl_list_for_each(q, &gas->pending, struct gas_query_pending, list) {
|
if (gas->current == NULL) {
|
||||||
if (os_memcmp(q->addr, dst, ETH_ALEN) == 0) {
|
wpa_printf(MSG_DEBUG, "GAS: Unexpected TX status: freq=%u dst="
|
||||||
query = q;
|
MACSTR " result=%d - no query in progress",
|
||||||
break;
|
freq, MAC2STR(dst), result);
|
||||||
}
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
query = gas->current;
|
||||||
|
|
||||||
wpa_printf(MSG_DEBUG, "GAS: TX status: freq=%u dst=" MACSTR
|
wpa_printf(MSG_DEBUG, "GAS: TX status: freq=%u dst=" MACSTR
|
||||||
" result=%d query=%p",
|
" result=%d query=%p dialog_token=%u",
|
||||||
freq, MAC2STR(dst), result, query);
|
freq, MAC2STR(dst), result, query, query->dialog_token);
|
||||||
if (!query)
|
if (os_memcmp(dst, query->addr, ETH_ALEN) != 0) {
|
||||||
|
wpa_printf(MSG_DEBUG, "GAS: TX status for unexpected destination");
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (result == OFFCHANNEL_SEND_ACTION_SUCCESS) {
|
if (result == OFFCHANNEL_SEND_ACTION_SUCCESS) {
|
||||||
eloop_cancel_timeout(gas_query_timeout, gas, query);
|
eloop_cancel_timeout(gas_query_timeout, gas, query);
|
||||||
|
@ -469,8 +473,9 @@ static void gas_query_timeout(void *eloop_data, void *user_ctx)
|
||||||
struct gas_query *gas = eloop_data;
|
struct gas_query *gas = eloop_data;
|
||||||
struct gas_query_pending *query = user_ctx;
|
struct gas_query_pending *query = user_ctx;
|
||||||
|
|
||||||
wpa_printf(MSG_DEBUG, "GAS: No response received for query to " MACSTR,
|
wpa_printf(MSG_DEBUG, "GAS: No response received for query to " MACSTR
|
||||||
MAC2STR(query->addr));
|
" dialog token %u",
|
||||||
|
MAC2STR(query->addr), query->dialog_token);
|
||||||
gas_query_done(gas, query, GAS_QUERY_TIMEOUT);
|
gas_query_done(gas, query, GAS_QUERY_TIMEOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -505,6 +510,8 @@ static void gas_service_timeout(void *eloop_data, void *user_ctx)
|
||||||
}
|
}
|
||||||
gas->current = query;
|
gas->current = query;
|
||||||
|
|
||||||
|
wpa_printf(MSG_DEBUG, "GAS: Starting query timeout for dialog token %u",
|
||||||
|
query->dialog_token);
|
||||||
eloop_register_timeout(GAS_QUERY_TIMEOUT_PERIOD, 0,
|
eloop_register_timeout(GAS_QUERY_TIMEOUT_PERIOD, 0,
|
||||||
gas_query_timeout, gas, query);
|
gas_query_timeout, gas, query);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue