From b124bca592e15dcf41b621be517bc4af9e1e9d4d Mon Sep 17 00:00:00 2001 From: NIIBE Yutaka Date: Fri, 12 Nov 2021 15:09:05 +0900 Subject: [PATCH] gpg: Don't use malloc for kek_params. * g10/ecdh.c (pk_ecdh_default_params): Use stack for kek_params. -- GnuPG-bug-id: 5393 Signed-off-by: NIIBE Yutaka --- g10/ecdh.c | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/g10/ecdh.c b/g10/ecdh.c index d048951d7..c3337d1dc 100644 --- a/g10/ecdh.c +++ b/g10/ecdh.c @@ -52,15 +52,12 @@ static const struct gcry_mpi_t pk_ecdh_default_params (unsigned int qbits) { - byte *kek_params; + byte kek_params[4] = { + 3, /* Number of bytes to follow. */ + 1 /* Version for KDF+AESWRAP. */ + }; int i; - kek_params = xtrymalloc (4); - if (!kek_params) - return NULL; - kek_params[0] = 3; /* Number of bytes to follow. */ - kek_params[1] = 1; /* Version for KDF+AESWRAP. */ - /* Search for matching KEK parameter. Defaults to the strongest possible choices. Performance is not an issue here, only interoperability. */ @@ -78,7 +75,7 @@ pk_ecdh_default_params (unsigned int qbits) if (DBG_CRYPTO) log_printhex (kek_params, sizeof(kek_params), "ECDH KEK params are"); - return gcry_mpi_set_opaque (NULL, kek_params, 4 * 8); + return gcry_mpi_set_opaque_copy (NULL, kek_params, 4 * 8); }