> +static u8 *fils_find_session(u8 *pos, u8 *end) > +{ > + while (end - pos > 2 && end - pos >= 2 + pos[1]) { > + if (pos[0] == 255 && pos[1] == 1 + 8 && pos[2] == 4) > + return pos; > + pos += 2 + pos[1]; > + } > + > + return NULL; > +} Hmm. I think we should try to write this in terms of cfg80211_find_ie, or perhaps cfg80211_find_ie_match, maybe we need to extend those but this won't be the only one using the 255 escape. Perhaps just making the eid passed there be a u16, and extending the EID definitions appropriately? The code would probably be shorter as is for now, but still ... > + if (!session) { > + sdata_info(sdata, > + "No FILS Session element in > (Re)Association Response frame from %pM", > + mgmt->sa); > + return -EINVAL; Should we really print the message this prominently? It seems like an error case that we may not want to log at all, in case somebody tries to flood us with such frames? > + crypt_len = frame + *frame_len - encr; > + if (crypt_len < AES_BLOCK_SIZE) { > + sdata_info(sdata, > + "Not enough room for AES-SIV data after > FILS Session element in (Re)Association Response frame from %pM", > + mgmt->sa); > + return -EINVAL; > + } > + res = aes_siv_decrypt(assoc_data->fils_kek, assoc_data- > >fils_kek_len, > + encr, crypt_len, 5, addr, len, encr); > + if (res != 0) { > + sdata_info(sdata, > + "AES-SIV decryption of (Re)Association > Response frame from %pM failed", > + mgmt->sa); > + return res; > + } Likewise here. Perhaps make these mlme_dbg() or so instead? > + if (req->fils_nonces) > + assoc_data_len += 2 * FILS_NONCE_LEN; Is this really correct? It seems like a bit of an artifact of initially having had the nonces in a variable part of the struct? Or perhaps they have to go into the frame in some place that I missed? Please add a comment if so. Also, you're never checking req->fils_nonces_set, so you can get rid of that. johannes