From 213c1fa84de7d0006916fc2d29b9e81213494f70 Mon Sep 17 00:00:00 2001 From: Jouni Malinen Date: Tue, 25 Sep 2012 21:41:52 +0300 Subject: [PATCH] P2P: Fix ignoring of PD Response due to dialog token mismatch Commit 6b56cc2d97fe9efd1feea8d418714b4658b056f1 added clearing of the p2p->pending_action_state too early in this function. This should not be done if we are going to silently ignore the frame due to dialog token mismatch. Fix this by moving the code around to check the dialog token first. This issue resulted in PD Request retries getting stopped too early if the peer is sending out an unexpected PD Response (e.g., because of it being excessively slow with the response so that the response is received only after the next TX attempt with a new dialog token). Signed-hostap: Jouni Malinen --- src/p2p/p2p_pd.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/p2p/p2p_pd.c b/src/p2p/p2p_pd.c index a2d5aeeb8..42447e5ca 100644 --- a/src/p2p/p2p_pd.c +++ b/src/p2p/p2p_pd.c @@ -278,11 +278,6 @@ void p2p_process_prov_disc_resp(struct p2p_data *p2p, const u8 *sa, return; } - if (p2p->pending_action_state == P2P_PENDING_PD) { - os_memset(p2p->pending_pd_devaddr, 0, ETH_ALEN); - p2p->pending_action_state = P2P_NO_PENDING_ACTION; - } - if (dev->dialog_token != msg.dialog_token) { wpa_msg(p2p->cfg->msg_ctx, MSG_DEBUG, "P2P: Ignore Provision Discovery Response with " @@ -292,6 +287,11 @@ void p2p_process_prov_disc_resp(struct p2p_data *p2p, const u8 *sa, return; } + if (p2p->pending_action_state == P2P_PENDING_PD) { + os_memset(p2p->pending_pd_devaddr, 0, ETH_ALEN); + p2p->pending_action_state = P2P_NO_PENDING_ACTION; + } + /* * If the response is from the peer to whom a user initiated request * was sent earlier, we reset that state info here.