internal.c: refactoring BuildMessage to reduce stack usage:
--- variable hmac moved to the heap (up to 64 bytes saved)
This commit is contained in:
parent
5ef9a21eaa
commit
a7e585b63d
@ -6928,11 +6928,26 @@ static int BuildMessage(CYASSL* ssl, byte* output, int outSz,
|
|||||||
if (ssl->specs.cipher_type != aead) {
|
if (ssl->specs.cipher_type != aead) {
|
||||||
#ifdef HAVE_TRUNCATED_HMAC
|
#ifdef HAVE_TRUNCATED_HMAC
|
||||||
if (ssl->truncated_hmac && ssl->specs.hash_size > digestSz) {
|
if (ssl->truncated_hmac && ssl->specs.hash_size > digestSz) {
|
||||||
|
#ifdef CYASSL_SMALL_STACK
|
||||||
|
byte* hmac = NULL;
|
||||||
|
#else
|
||||||
byte hmac[MAX_DIGEST_SIZE];
|
byte hmac[MAX_DIGEST_SIZE];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CYASSL_SMALL_STACK
|
||||||
|
hmac = (byte*)XMALLOC(MAX_DIGEST_SIZE, NULL,
|
||||||
|
DYNAMIC_TYPE_TMP_BUFFER);
|
||||||
|
if (hmac == NULL)
|
||||||
|
return MEMORY_E;
|
||||||
|
#endif
|
||||||
|
|
||||||
ret = ssl->hmac(ssl, hmac, output + headerSz + ivSz, inSz,
|
ret = ssl->hmac(ssl, hmac, output + headerSz + ivSz, inSz,
|
||||||
type, 0);
|
type, 0);
|
||||||
XMEMCPY(output + idx, hmac, digestSz);
|
XMEMCPY(output + idx, hmac, digestSz);
|
||||||
|
|
||||||
|
#ifdef CYASSL_SMALL_STACK
|
||||||
|
XFREE(hmac, NULL, DYNAMIC_TYPE_TMP_BUFFER);
|
||||||
|
#endif
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
ret = ssl->hmac(ssl, output+idx, output + headerSz + ivSz, inSz,
|
ret = ssl->hmac(ssl, output+idx, output + headerSz + ivSz, inSz,
|
||||||
|
Loading…
Reference in New Issue
Block a user