mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-13 20:22:33 +01:00
sae: remove authenticate timeout handler
This fixes an infinite loop issue when authenticate frames time out. If the AP is not responding IWD ends up retrying indefinitely due to how SAE was handling this timeout. Inside sae_auth_timeout it was actually sending another authenticate frame to reject the SAE handshake. This, again, resulted in a timeout which called the SAE timeout handler and repeated indefinitely. The kernel resend behavior was not taken into account when writing the SAE timeout behavior and in practice there is actually no need for SAE to do much of anything in response to a timeout. The kernel automatically resends Authenticate frames 3 times which mirrors IWDs SAE behavior anyways. Because of this the authenticate timeout handler can be completely removed, which will cause the connection to fail in the case of an autentication timeout.
This commit is contained in:
parent
fc4739f2db
commit
135ad0880e
30
src/sae.c
30
src/sae.c
@ -672,35 +672,6 @@ static bool sae_send_commit(struct sae_sm *sm, bool retry)
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool sae_auth_timeout(struct auth_proto *ap)
|
||||
{
|
||||
struct sae_sm *sm = l_container_of(ap, struct sae_sm, ap);
|
||||
|
||||
/* regardless of state, reject if sync exceeds max */
|
||||
if (sm->sync > SAE_SYNC_MAX) {
|
||||
sae_reject_authentication(sm, MMPDU_REASON_CODE_UNSPECIFIED);
|
||||
return false;
|
||||
}
|
||||
|
||||
sm->sync++;
|
||||
|
||||
switch (sm->state) {
|
||||
case SAE_STATE_COMMITTED:
|
||||
sae_send_commit(sm, true);
|
||||
break;
|
||||
case SAE_STATE_CONFIRMED:
|
||||
sm->sc++;
|
||||
sae_send_confirm(sm);
|
||||
break;
|
||||
default:
|
||||
/* should never happen */
|
||||
l_error("SAE timeout in bad state %u", sm->state);
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool sae_assoc_timeout(struct auth_proto *ap)
|
||||
{
|
||||
struct sae_sm *sm = l_container_of(ap, struct sae_sm, ap);
|
||||
@ -1194,7 +1165,6 @@ struct auth_proto *sae_sm_new(struct handshake_state *hs,
|
||||
sm->ap.free = sae_free;
|
||||
sm->ap.rx_authenticate = sae_rx_authenticate;
|
||||
sm->ap.rx_associate = sae_rx_associate;
|
||||
sm->ap.auth_timeout = sae_auth_timeout;
|
||||
sm->ap.assoc_timeout = sae_assoc_timeout;
|
||||
|
||||
return &sm->ap;
|
||||
|
Loading…
Reference in New Issue
Block a user