wlantest: Verify FTIE length before checking MIC
tdls_verify_mic() and tdls_verify_mic_teardown() could have tried to read the 16-octet FTIE MIC when processing a TDLS frame even if the received FTIE is truncated. At least in theory, this could result in reading couple of octets beyond the frame buffer. Signed-off-by: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
253103681c
commit
d4c4ec9240
1 changed files with 4 additions and 2 deletions
|
@ -142,7 +142,8 @@ static int tdls_verify_mic(struct wlantest *wt, struct wlantest_tdls *tdls,
|
||||||
struct rsn_ftie *tmp_ftie;
|
struct rsn_ftie *tmp_ftie;
|
||||||
|
|
||||||
if (elems->link_id == NULL || elems->rsn_ie == NULL ||
|
if (elems->link_id == NULL || elems->rsn_ie == NULL ||
|
||||||
elems->timeout_int == NULL || elems->ftie == NULL)
|
elems->timeout_int == NULL || elems->ftie == NULL ||
|
||||||
|
elems->ftie_len < sizeof(struct rsn_ftie))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
len = 2 * ETH_ALEN + 1 + 2 + 18 + 2 + elems->rsn_ie_len +
|
len = 2 * ETH_ALEN + 1 + 2 + 18 + 2 + elems->rsn_ie_len +
|
||||||
|
@ -488,7 +489,8 @@ static int tdls_verify_mic_teardown(struct wlantest *wt,
|
||||||
const struct rsn_ftie *rx_ftie;
|
const struct rsn_ftie *rx_ftie;
|
||||||
struct rsn_ftie *tmp_ftie;
|
struct rsn_ftie *tmp_ftie;
|
||||||
|
|
||||||
if (elems->link_id == NULL || elems->ftie == NULL)
|
if (elems->link_id == NULL || elems->ftie == NULL ||
|
||||||
|
elems->ftie_len < sizeof(struct rsn_ftie))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
len = 2 + 18 + 2 + 1 + 1 + 2 + elems->ftie_len;
|
len = 2 + 18 + 2 + 1 + 1 + 2 + elems->ftie_len;
|
||||||
|
|
Loading…
Reference in a new issue