mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-05 04:32:34 +01:00
simutil: Optimize l_checksum usage
The checksum object was created / destroyed repeatedly. It was sufficient to simply call checksum_reset since the key was never changed.
This commit is contained in:
parent
aa7abb44c5
commit
c80b239b93
@ -203,6 +203,10 @@ bool eap_aka_prf_prime(const uint8_t *ik_p, const uint8_t *ck_p,
|
|||||||
memcpy(key, ik_p, EAP_AKA_IK_LEN);
|
memcpy(key, ik_p, EAP_AKA_IK_LEN);
|
||||||
memcpy(key + EAP_AKA_IK_LEN, ck_p, EAP_AKA_CK_LEN);
|
memcpy(key + EAP_AKA_IK_LEN, ck_p, EAP_AKA_CK_LEN);
|
||||||
|
|
||||||
|
hmac = l_checksum_new_hmac(L_CHECKSUM_SHA256, key, 32);
|
||||||
|
if (!hmac)
|
||||||
|
return false;
|
||||||
|
|
||||||
iov[0].iov_base = digest;
|
iov[0].iov_base = digest;
|
||||||
/* initial iteration digest is not used */
|
/* initial iteration digest is not used */
|
||||||
iov[0].iov_len = 0;
|
iov[0].iov_len = 0;
|
||||||
@ -215,13 +219,9 @@ bool eap_aka_prf_prime(const uint8_t *ik_p, const uint8_t *ck_p,
|
|||||||
|
|
||||||
/* need 208 bytes for all keys */
|
/* need 208 bytes for all keys */
|
||||||
while (pos < out + 224) {
|
while (pos < out + 224) {
|
||||||
hmac = l_checksum_new_hmac(L_CHECKSUM_SHA256, key, 32);
|
l_checksum_reset(hmac);
|
||||||
if (!hmac)
|
|
||||||
return false;
|
|
||||||
|
|
||||||
l_checksum_updatev(hmac, iov, 4);
|
l_checksum_updatev(hmac, iov, 4);
|
||||||
l_checksum_get_digest(hmac, digest, 32);
|
l_checksum_get_digest(hmac, digest, 32);
|
||||||
l_checksum_free(hmac);
|
|
||||||
memcpy(pos, digest, 32);
|
memcpy(pos, digest, 32);
|
||||||
pos += 32;
|
pos += 32;
|
||||||
i++;
|
i++;
|
||||||
@ -229,6 +229,8 @@ bool eap_aka_prf_prime(const uint8_t *ik_p, const uint8_t *ck_p,
|
|||||||
iov[0].iov_len = 32;
|
iov[0].iov_len = 32;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
l_checksum_free(hmac);
|
||||||
|
|
||||||
pos = out;
|
pos = out;
|
||||||
memcpy(k_encr, pos, EAP_SIM_K_ENCR_LEN);
|
memcpy(k_encr, pos, EAP_SIM_K_ENCR_LEN);
|
||||||
pos += EAP_SIM_K_ENCR_LEN;
|
pos += EAP_SIM_K_ENCR_LEN;
|
||||||
|
Loading…
Reference in New Issue
Block a user