EAP-pwd peer: Check for unexpected state for ID exchange
Aborty processing if ID exchange processing is entered twice unexpectedly. This avoids memory leaks in the function. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
44136f6ca2
commit
7280723fbf
1 changed files with 6 additions and 0 deletions
|
@ -255,6 +255,12 @@ eap_pwd_perform_id_exchange(struct eap_sm *sm, struct eap_pwd_data *data,
|
||||||
data->prep = id->prep;
|
data->prep = id->prep;
|
||||||
os_memcpy(data->token, id->token, sizeof(id->token));
|
os_memcpy(data->token, id->token, sizeof(id->token));
|
||||||
|
|
||||||
|
if (data->id_server || data->grp) {
|
||||||
|
wpa_printf(MSG_INFO, "EAP-pwd: data was already allocated");
|
||||||
|
eap_pwd_state(data, FAILURE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
data->id_server = os_malloc(payload_len - sizeof(struct eap_pwd_id));
|
data->id_server = os_malloc(payload_len - sizeof(struct eap_pwd_id));
|
||||||
if (data->id_server == NULL) {
|
if (data->id_server == NULL) {
|
||||||
wpa_printf(MSG_INFO, "EAP-PWD: memory allocation id fail");
|
wpa_printf(MSG_INFO, "EAP-PWD: memory allocation id fail");
|
||||||
|
|
Loading…
Reference in a new issue