summaryrefslogtreecommitdiffstats
path: root/Modules/_ssl.c
diff options
context:
space:
mode:
authorOlivier Vielpeau <olivielpeau@users.noreply.github.com>2017-04-15 01:06:07 (GMT)
committerMariatta <Mariatta@users.noreply.github.com>2017-04-15 01:06:07 (GMT)
commit2849cc34a8db93d448a62d69c462402347b50dcb (patch)
treed01e839920c3586df77c96dcd9c4ee362bd980b7 /Modules/_ssl.c
parent0dc5c3169dcd4853612d11ed8c92b12fa210c07f (diff)
downloadcpython-2849cc34a8db93d448a62d69c462402347b50dcb.zip
cpython-2849cc34a8db93d448a62d69c462402347b50dcb.tar.gz
cpython-2849cc34a8db93d448a62d69c462402347b50dcb.tar.bz2
bpo-29738: Fix memory leak in _get_crl_dp (GH-526)
* Remove conditional on free of `dps`, since `dps` is now allocated for all versions of OpenSSL * Remove call to `x509_check_ca` since it was only used to cache the `crldp` field of the certificate CRL_DIST_POINTS_free is available in all supported versions of OpenSSL (recent 0.9.8+) and LibreSSL.
Diffstat (limited to 'Modules/_ssl.c')
-rw-r--r--Modules/_ssl.c8
1 files changed, 1 insertions, 7 deletions
diff --git a/Modules/_ssl.c b/Modules/_ssl.c
index 327fb37..5f2de61 100644
--- a/Modules/_ssl.c
+++ b/Modules/_ssl.c
@@ -1209,10 +1209,6 @@ _get_crl_dp(X509 *certificate) {
int i, j;
PyObject *lst, *res = NULL;
-#if OPENSSL_VERSION_NUMBER >= 0x10001000L
- /* Calls x509v3_cache_extensions and sets up crldp */
- X509_check_ca(certificate);
-#endif
dps = X509_get_ext_d2i(certificate, NID_crl_distribution_points, NULL, NULL);
if (dps == NULL)
@@ -1257,9 +1253,7 @@ _get_crl_dp(X509 *certificate) {
done:
Py_XDECREF(lst);
-#if OPENSSL_VERSION_NUMBER < 0x10001000L
- sk_DIST_POINT_free(dps);
-#endif
+ CRL_DIST_POINTS_free(dps);
return res;
}