Fix memory leak in pg_hmac
The intermittent h buffer was not freed, causing it to leak. Backpatch through 14 where HMAC was refactored to the current API. Author: Sergey Shinderuk <s.shinderuk@postgrespro.ru> Discussion: https://postgr.es/m/af07e620-7e28-a742-4637-2bc44aa7c2be@postgrespro.ru Backpatch-through: 14
This commit is contained in:
parent
8c1144ba73
commit
0ded7039fa
@ -232,7 +232,10 @@ pg_hmac_final(pg_hmac_ctx *ctx, uint8 *dest, size_t len)
|
||||
memset(h, 0, ctx->digest_size);
|
||||
|
||||
if (pg_cryptohash_final(ctx->hash, h, ctx->digest_size) < 0)
|
||||
{
|
||||
FREE(h);
|
||||
return -1;
|
||||
}
|
||||
|
||||
/* H(K XOR opad, tmp) */
|
||||
if (pg_cryptohash_init(ctx->hash) < 0 ||
|
||||
@ -240,9 +243,11 @@ pg_hmac_final(pg_hmac_ctx *ctx, uint8 *dest, size_t len)
|
||||
pg_cryptohash_update(ctx->hash, h, ctx->digest_size) < 0 ||
|
||||
pg_cryptohash_final(ctx->hash, dest, len) < 0)
|
||||
{
|
||||
FREE(h);
|
||||
return -1;
|
||||
}
|
||||
|
||||
FREE(h);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user