3
0
mirror of https://git.kernel.org/pub/scm/network/wireless/iwd.git synced 2025-01-13 12:02:33 +01:00

sae: fix inproper return value in sae_verify_accepted

This function was returning a boolean and the expected return was
a signed integer. Since this function actually returned false in
all cases the check for a success (0) return always worked.

The comment about the 'standard code path' was removed as this is
no longer valid.
This commit is contained in:
James Prestwood 2019-10-21 14:01:59 -07:00 committed by Denis Kenzior
parent 3f2b558f57
commit 47efe17461

View File

@ -938,7 +938,7 @@ static int sae_verify_confirmed(struct sae_sm *sm, uint16_t trans,
/*
* 802.11-2016 - 12.4.8.6.6 Protocol instance behavior - Accepted state
*/
static bool sae_verify_accepted(struct sae_sm *sm, uint16_t trans,
static int sae_verify_accepted(struct sae_sm *sm, uint16_t trans,
uint16_t status, const uint8_t *frame,
size_t len)
{
@ -947,14 +947,14 @@ static bool sae_verify_accepted(struct sae_sm *sm, uint16_t trans,
/* spec does not specify what to do here, so print and discard */
if (trans != SAE_STATE_CONFIRMED) {
l_error("received transaction %u in accepted state", trans);
return false;
return -EBADMSG;
}
if (sm->sync > SAE_SYNC_MAX)
return false;
return -EBADMSG;
if (len < 2)
return false;
return -EBADMSG;
sc = l_get_le16(frame);
@ -964,14 +964,14 @@ static bool sae_verify_accepted(struct sae_sm *sm, uint16_t trans,
* silently discarded.
*/
if (sc <= sm->rc || sc == 0xffff)
return false;
return -EBADMSG;
/*
* If the verification fails, the received frame shall be silently
* discarded.
*/
if (!sae_verify_confirm(sm, frame))
return false;
return -EBADMSG;
/*
* If the verification succeeds, the Rc variable shall be set to the
@ -984,11 +984,7 @@ static bool sae_verify_accepted(struct sae_sm *sm, uint16_t trans,
sae_send_confirm(sm);
/*
* Since the confirmed needed special processing because of accepted
* state we don't want the standard code path to execute.
*/
return false;
return 0;
}
static int sae_verify_packet(struct sae_sm *sm, uint16_t trans,