summaryrefslogtreecommitdiff
path: root/pjsip/src/pjsip/sip_transport_tls.c
diff options
context:
space:
mode:
Diffstat (limited to 'pjsip/src/pjsip/sip_transport_tls.c')
-rw-r--r--pjsip/src/pjsip/sip_transport_tls.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/pjsip/src/pjsip/sip_transport_tls.c b/pjsip/src/pjsip/sip_transport_tls.c
index ac7ac930..5e63a2c8 100644
--- a/pjsip/src/pjsip/sip_transport_tls.c
+++ b/pjsip/src/pjsip/sip_transport_tls.c
@@ -1566,8 +1566,16 @@ static pj_bool_t on_connect_complete(pj_ssl_sock_t *ssock,
tls = (struct tls_transport*) pj_ssl_sock_get_user_data(ssock);
- if (tls->base.is_shutdown || tls->base.is_destroying)
- return PJ_FALSE;
+ /* If transport is being shutdown/destroyed, proceed as error connect.
+ * Note that it is important to notify application via on_data_sent()
+ * as otherwise the transport reference counter may never reach zero
+ * (see #1898).
+ */
+ if ((tls->base.is_shutdown || tls->base.is_destroying) &&
+ status == PJ_SUCCESS)
+ {
+ status = PJ_ECANCELLED;
+ }
/* Check connect() status */
if (status != PJ_SUCCESS) {