From 40c03fd40b3b47ee14267d69b118f4beb613abac Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Wed, 23 Jun 2010 22:37:27 -0700 Subject: [PATCH] P2P: Handle p2p_scan tracking in SEARCH state Previously, only the initial p2p_scan was used to delay starting new P2P operations. However, this should have applied to the SEARCH state scans, too. --- src/p2p/p2p.c | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/src/p2p/p2p.c b/src/p2p/p2p.c index 6fb1a0c03..689d35df4 100644 --- a/src/p2p/p2p.c +++ b/src/p2p/p2p.c @@ -32,8 +32,17 @@ static void p2p_process_presence_resp(struct p2p_data *p2p, const u8 *da, const u8 *sa, const u8 *data, size_t len); static void p2p_ext_listen_timeout(void *eloop_ctx, void *timeout_ctx); +static void p2p_scan_timeout(void *eloop_ctx, void *timeout_ctx); +/* + * p2p_scan recovery timeout + * + * Many drivers are using 30 second timeout on scan results. Allow a bit larger + * timeout for this to avoid hitting P2P timeout unnecessarily. + */ +#define P2P_SCAN_TIMEOUT 35 + /** * P2P_PEER_EXPIRATION_AGE - Number of seconds after which inactive peer * entries will be removed @@ -647,6 +656,12 @@ static void p2p_search(struct p2p_data *p2p) wpa_msg(p2p->cfg->msg_ctx, MSG_DEBUG, "P2P: Scan request failed"); p2p_continue_find(p2p); + } else { + wpa_msg(p2p->cfg->msg_ctx, MSG_DEBUG, "P2P: Running p2p_scan"); + p2p->p2p_scan_running = 1; + eloop_cancel_timeout(p2p_scan_timeout, p2p, NULL); + eloop_register_timeout(P2P_SCAN_TIMEOUT, 0, p2p_scan_timeout, + p2p, NULL); } } @@ -693,14 +708,6 @@ static int p2p_run_after_scan(struct p2p_data *p2p) } -/* - * p2p_scan recovery timeout - * - * Many drivers are using 30 second timeout on scan results. Allow a bit larger - * timeout for this to avoid hitting P2P timeout unnecessarily. - */ -#define P2P_SCAN_TIMEOUT 35 - static void p2p_scan_timeout(void *eloop_ctx, void *timeout_ctx) { struct p2p_data *p2p = eloop_ctx;