Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / net / third_party / nss / patches / cachelocks.patch
blob66a539b34761d10c8510da610e461c0948623238
1 diff --git a/ssl/ssl3con.c b/ssl/ssl3con.c
2 index 6819b03..6a4a443 100644
3 --- a/ssl/ssl3con.c
4 +++ b/ssl/ssl3con.c
5 @@ -5748,7 +5748,6 @@ SSL3_ShutdownServerCache(void)
8 PZ_Unlock(symWrapKeysLock);
9 - ssl_FreeSessionCacheLocks();
10 return SECSuccess;
13 @@ -5800,7 +5799,7 @@ getWrappingKey( sslSocket * ss,
15 pSymWrapKey = &symWrapKeys[symWrapMechIndex].symWrapKey[exchKeyType];
17 - ssl_InitSessionCacheLocks(PR_TRUE);
18 + ssl_InitSessionCacheLocks();
20 PZ_Lock(symWrapKeysLock);
22 diff --git a/ssl/sslimpl.h b/ssl/sslimpl.h
23 index 88b2eba..c4c87b4 100644
24 --- a/ssl/sslimpl.h
25 +++ b/ssl/sslimpl.h
26 @@ -1924,9 +1924,7 @@ extern SECStatus ssl_InitSymWrapKeysLock(void);
28 extern SECStatus ssl_FreeSymWrapKeysLock(void);
30 -extern SECStatus ssl_InitSessionCacheLocks(PRBool lazyInit);
32 -extern SECStatus ssl_FreeSessionCacheLocks(void);
33 +extern SECStatus ssl_InitSessionCacheLocks(void);
35 /***************** platform client auth ****************/
37 diff --git a/ssl/sslnonce.c b/ssl/sslnonce.c
38 index 1326a8b..c45849d 100644
39 --- a/ssl/sslnonce.c
40 +++ b/ssl/sslnonce.c
41 @@ -35,91 +35,55 @@ static PZLock * cacheLock = NULL;
42 #define LOCK_CACHE lock_cache()
43 #define UNLOCK_CACHE PZ_Unlock(cacheLock)
45 -static SECStatus
46 -ssl_InitClientSessionCacheLock(void)
48 - cacheLock = PZ_NewLock(nssILockCache);
49 - return cacheLock ? SECSuccess : SECFailure;
52 -static SECStatus
53 -ssl_FreeClientSessionCacheLock(void)
55 - if (cacheLock) {
56 - PZ_DestroyLock(cacheLock);
57 - cacheLock = NULL;
58 - return SECSuccess;
59 - }
60 - PORT_SetError(SEC_ERROR_NOT_INITIALIZED);
61 - return SECFailure;
64 -static PRBool LocksInitializedEarly = PR_FALSE;
65 +static PRCallOnceType lockOnce;
67 +/* FreeSessionCacheLocks is a callback from NSS_RegisterShutdown which destroys
68 + * the session cache locks on shutdown and resets them to their initial
69 + * state. */
70 static SECStatus
71 -FreeSessionCacheLocks()
72 +FreeSessionCacheLocks(void* appData, void* nssData)
74 - SECStatus rv1, rv2;
75 - rv1 = ssl_FreeSymWrapKeysLock();
76 - rv2 = ssl_FreeClientSessionCacheLock();
77 - if ( (SECSuccess == rv1) && (SECSuccess == rv2) ) {
78 - return SECSuccess;
79 - }
80 - return SECFailure;
82 + static const PRCallOnceType pristineCallOnce;
83 + SECStatus rv;
85 -static SECStatus
86 -InitSessionCacheLocks(void)
88 - SECStatus rv1, rv2;
89 - PRErrorCode rc;
90 - rv1 = ssl_InitSymWrapKeysLock();
91 - rv2 = ssl_InitClientSessionCacheLock();
92 - if ( (SECSuccess == rv1) && (SECSuccess == rv2) ) {
93 - return SECSuccess;
94 - }
95 - rc = PORT_GetError();
96 - FreeSessionCacheLocks();
97 - PORT_SetError(rc);
98 - return SECFailure;
101 -/* free the session cache locks if they were initialized early */
102 -SECStatus
103 -ssl_FreeSessionCacheLocks()
105 - PORT_Assert(PR_TRUE == LocksInitializedEarly);
106 - if (!LocksInitializedEarly) {
107 + if (!cacheLock) {
108 PORT_SetError(SEC_ERROR_NOT_INITIALIZED);
109 return SECFailure;
111 - FreeSessionCacheLocks();
112 - LocksInitializedEarly = PR_FALSE;
113 - return SECSuccess;
116 -static PRCallOnceType lockOnce;
117 + PZ_DestroyLock(cacheLock);
118 + cacheLock = NULL;
120 -/* free the session cache locks if they were initialized lazily */
121 -static SECStatus ssl_ShutdownLocks(void* appData, void* nssData)
123 - PORT_Assert(PR_FALSE == LocksInitializedEarly);
124 - if (LocksInitializedEarly) {
125 - PORT_SetError(SEC_ERROR_LIBRARY_FAILURE);
126 - return SECFailure;
127 + rv = ssl_FreeSymWrapKeysLock();
128 + if (rv != SECSuccess) {
129 + return rv;
131 - FreeSessionCacheLocks();
132 - memset(&lockOnce, 0, sizeof(lockOnce));
134 + lockOnce = pristineCallOnce;
135 return SECSuccess;
138 -static PRStatus initSessionCacheLocksLazily(void)
139 +/* InitSessionCacheLocks is called, protected by lockOnce, to create the
140 + * session cache locks. */
141 +static PRStatus
142 +InitSessionCacheLocks(void)
144 - SECStatus rv = InitSessionCacheLocks();
145 - if (SECSuccess != rv) {
146 + SECStatus rv;
148 + cacheLock = PZ_NewLock(nssILockCache);
149 + if (cacheLock == NULL) {
150 return PR_FAILURE;
152 - rv = NSS_RegisterShutdown(ssl_ShutdownLocks, NULL);
153 + rv = ssl_InitSymWrapKeysLock();
154 + if (rv != SECSuccess) {
155 + PRErrorCode error = PORT_GetError();
156 + PZ_DestroyLock(cacheLock);
157 + cacheLock = NULL;
158 + PORT_SetError(error);
159 + return PR_FAILURE;
162 + rv = NSS_RegisterShutdown(FreeSessionCacheLocks, NULL);
163 PORT_Assert(SECSuccess == rv);
164 if (SECSuccess != rv) {
165 return PR_FAILURE;
166 @@ -127,34 +91,18 @@ static PRStatus initSessionCacheLocksLazily(void)
167 return PR_SUCCESS;
170 -/* lazyInit means that the call is not happening during a 1-time
171 - * initialization function, but rather during dynamic, lazy initialization
172 - */
173 SECStatus
174 -ssl_InitSessionCacheLocks(PRBool lazyInit)
175 +ssl_InitSessionCacheLocks(void)
177 - if (LocksInitializedEarly) {
178 - return SECSuccess;
181 - if (lazyInit) {
182 - return (PR_SUCCESS ==
183 - PR_CallOnce(&lockOnce, initSessionCacheLocksLazily)) ?
184 - SECSuccess : SECFailure;
187 - if (SECSuccess == InitSessionCacheLocks()) {
188 - LocksInitializedEarly = PR_TRUE;
189 - return SECSuccess;
192 - return SECFailure;
193 + return (PR_SUCCESS ==
194 + PR_CallOnce(&lockOnce, InitSessionCacheLocks)) ?
195 + SECSuccess : SECFailure;
198 -static void
199 +static void
200 lock_cache(void)
202 - ssl_InitSessionCacheLocks(PR_TRUE);
203 + ssl_InitSessionCacheLocks();
204 PZ_Lock(cacheLock);
207 diff --git a/ssl/sslsnce.c b/ssl/sslsnce.c
208 index 4d9ef38..3279200 100644
209 --- a/ssl/sslsnce.c
210 +++ b/ssl/sslsnce.c
211 @@ -1352,7 +1352,7 @@ SSL_ConfigServerSessionIDCache( int maxCacheEntries,
212 PRUint32 ssl3_timeout,
213 const char * directory)
215 - ssl_InitSessionCacheLocks(PR_FALSE);
216 + ssl_InitSessionCacheLocks();
217 return SSL_ConfigServerSessionIDCacheInstance(&globalCache,
218 maxCacheEntries, ssl2_timeout, ssl3_timeout, directory, PR_FALSE);
220 @@ -1466,7 +1466,7 @@ SSL_ConfigServerSessionIDCacheWithOpt(
221 PRBool enableMPCache)
223 if (!enableMPCache) {
224 - ssl_InitSessionCacheLocks(PR_FALSE);
225 + ssl_InitSessionCacheLocks();
226 return ssl_ConfigServerSessionIDCacheInstanceWithOpt(&globalCache,
227 ssl2_timeout, ssl3_timeout, directory, PR_FALSE,
228 maxCacheEntries, maxCertCacheEntries, maxSrvNameCacheEntries);
229 @@ -1511,7 +1511,7 @@ SSL_InheritMPServerSIDCacheInstance(cacheDesc *cache, const char * envString)
230 return SECSuccess; /* already done. */
233 - ssl_InitSessionCacheLocks(PR_FALSE);
234 + ssl_InitSessionCacheLocks();
236 ssl_sid_lookup = ServerSessionIDLookup;
237 ssl_sid_cache = ServerSessionIDCache;