From: Nathaniel J. Smith Date: Thu, 8 Jun 2017 11:14:44 +0000 (-0700) Subject: [3.5] bpo-30594: Fixed refcounting in newPySSLSocket (GH-1992) (#1993) X-Git-Tag: v3.5.4rc1~104 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=54ba41ecc5711f89841342c5f9dd555ee13404b5;p=python [3.5] bpo-30594: Fixed refcounting in newPySSLSocket (GH-1992) (#1993) If pass a server_hostname= that fails IDNA decoding to SSLContext.wrap_socket or SSLContext.wrap_bio, then the SSLContext object had a spurious Py_DECREF called on it, eventually leading to segfaults. (cherry picked from commit 65ece7ca2366308fa91a39a8dfa255e6bdce3cca) --- diff --git a/Modules/_ssl.c b/Modules/_ssl.c index 9f79d17f6d..3b2d3add28 100644 --- a/Modules/_ssl.c +++ b/Modules/_ssl.c @@ -570,6 +570,7 @@ newPySSLSocket(PySSLContext *sslctx, PySocketSockObject *sock, self->ssl = NULL; self->Socket = NULL; self->ctx = sslctx; + Py_INCREF(sslctx); self->shutdown_seen_zero = 0; self->handshake_done = 0; self->owner = NULL; @@ -584,8 +585,6 @@ newPySSLSocket(PySSLContext *sslctx, PySocketSockObject *sock, self->server_hostname = hostname; } - Py_INCREF(sslctx); - /* Make sure the SSL error state is initialized */ (void) ERR_get_state(); ERR_clear_error();