aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlex Gaynor <alex.gaynor@gmail.com>2017-06-28 13:24:07 -0700
committerPaul Kehrer <paul.l.kehrer@gmail.com>2017-06-28 15:24:07 -0500
commitf21ffff2d2bc916b70e66810b4582a604f03965f (patch)
treedde2b3e3415cb61692247cd23d14811128a50660 /src
parent491fd7cc5aefff8064039d073331b41a2f606a63 (diff)
downloadcryptography-f21ffff2d2bc916b70e66810b4582a604f03965f.tar.gz
cryptography-f21ffff2d2bc916b70e66810b4582a604f03965f.tar.bz2
cryptography-f21ffff2d2bc916b70e66810b4582a604f03965f.zip
Fix for leaking memory in EllipticCurvePublicNumbers.public_key() (#3732)
* Test for leaking memory in EllipticCurvePublicNumbers.public_key() * Fix the memory leak As far as I can tell, from spelunking in the OpenSSL source (as you do), EC_KEY_set_public_key_affine_coordinates doesn't take ownership of "x" or "y". https://github.com/openssl/openssl/blob/master/crypto/ec/ecp_smpl.c#L362-L420 is the place in the source I found that actually uses "x" and "y". * Unused imports
Diffstat (limited to 'src')
-rw-r--r--src/cryptography/hazmat/backends/openssl/backend.py6
1 files changed, 3 insertions, 3 deletions
diff --git a/src/cryptography/hazmat/backends/openssl/backend.py b/src/cryptography/hazmat/backends/openssl/backend.py
index 5458a0f8..c481c094 100644
--- a/src/cryptography/hazmat/backends/openssl/backend.py
+++ b/src/cryptography/hazmat/backends/openssl/backend.py
@@ -1465,9 +1465,9 @@ class Backend(object):
"Invalid EC key. Both x and y must be non-negative."
)
- res = self._lib.EC_KEY_set_public_key_affine_coordinates(
- ctx, self._int_to_bn(x), self._int_to_bn(y)
- )
+ x = self._ffi.gc(self._int_to_bn(x), self._lib.BN_free)
+ y = self._ffi.gc(self._int_to_bn(y), self._lib.BN_free)
+ res = self._lib.EC_KEY_set_public_key_affine_coordinates(ctx, x, y)
if res != 1:
self._consume_errors()
raise ValueError("Invalid EC key.")