schannel: on connection close there might not be a transfer
authorDaniel Stenberg <daniel@haxx.se>
Fri, 18 Jan 2019 10:21:25 +0000 (11:21 +0100)
committerDaniel Stenberg <daniel@haxx.se>
Fri, 18 Jan 2019 15:43:21 +0000 (16:43 +0100)
Reported-by: Marcel Raad
Fixes #3412
Closes #3483

lib/vtls/schannel.c

index 56fd93e1e567c00c4e6ff24a3d5c0048edb0d58e..ab7f83f466624210d5691ef68a56c674a3fd954a 100644 (file)
@@ -7,7 +7,7 @@
  *
  * Copyright (C) 2012 - 2016, Marc Hoersken, <info@marc-hoersken.de>
  * Copyright (C) 2012, Mark Salisbury, <mark.salisbury@hp.com>
- * Copyright (C) 2012 - 2018, Daniel Stenberg, <daniel@haxx.se>, et al.
+ * Copyright (C) 2012 - 2019, Daniel Stenberg, <daniel@haxx.se>, et al.
  *
  * This software is licensed as described in the file COPYING, which
  * you should have received as part of this distribution. The terms
@@ -2013,9 +2013,16 @@ static int Curl_schannel_shutdown(struct connectdata *conn, int sockindex)
 
   /* free SSPI Schannel API credential handle */
   if(BACKEND->cred) {
-    Curl_ssl_sessionid_lock(conn);
+    /*
+     * When this function is called from Curl_schannel_close() the connection
+     * might not have an associated transfer so the check for conn->data is
+     * necessary.
+     */
+    if(conn->data)
+      Curl_ssl_sessionid_lock(conn);
     Curl_schannel_session_free(BACKEND->cred);
-    Curl_ssl_sessionid_unlock(conn);
+    if(conn->data)
+      Curl_ssl_sessionid_unlock(conn);
     BACKEND->cred = NULL;
   }