1 diff -pu a/nss/lib/ssl/sslinfo.c b/nss/lib/ssl/sslinfo.c 2 --- a/nss/lib/ssl/sslinfo.c 2013-07-31 12:07:10.974699609 -0700 3 +++ b/nss/lib/ssl/sslinfo.c 2013-07-31 14:11:28.834113906 -0700 4 @@ -349,8 +349,13 @@ SSL_ExportKeyingMaterial(PRFileDesc *fd, 5 return SECFailure; 6 } 7 8 + ssl_GetRecvBufLock(ss); 9 + ssl_GetSSL3HandshakeLock(ss); 10 + 11 if (ss->version < SSL_LIBRARY_VERSION_3_1_TLS) { 12 PORT_SetError(SSL_ERROR_FEATURE_NOT_SUPPORTED_FOR_VERSION); 13 + ssl_ReleaseSSL3HandshakeLock(ss); 14 + ssl_ReleaseRecvBufLock(ss); 15 return SECFailure; 16 } 17 18 @@ -361,13 +366,17 @@ SSL_ExportKeyingMaterial(PRFileDesc *fd, 19 } 20 val = PORT_Alloc(valLen); 21 if (!val) { 22 + ssl_ReleaseSSL3HandshakeLock(ss); 23 + ssl_ReleaseRecvBufLock(ss); 24 return SECFailure; 25 } 26 i = 0; 27 + 28 PORT_Memcpy(val + i, &ss->ssl3.hs.client_random.rand, SSL3_RANDOM_LENGTH); 29 i += SSL3_RANDOM_LENGTH; 30 PORT_Memcpy(val + i, &ss->ssl3.hs.server_random.rand, SSL3_RANDOM_LENGTH); 31 i += SSL3_RANDOM_LENGTH; 32 + 33 if (hasContext) { 34 val[i++] = contextLen >> 8; 35 val[i++] = contextLen; 36 @@ -388,6 +397,8 @@ SSL_ExportKeyingMaterial(PRFileDesc *fd, 37 valLen, out, outLen); 38 } 39 ssl_ReleaseSpecReadLock(ss); 40 + ssl_ReleaseSSL3HandshakeLock(ss); 41 + ssl_ReleaseRecvBufLock(ss); 42 43 PORT_ZFree(val, valLen); 44 return rv; 45