OLD | NEW |
1 /* This Source Code Form is subject to the terms of the Mozilla Public | 1 /* This Source Code Form is subject to the terms of the Mozilla Public |
2 * License, v. 2.0. If a copy of the MPL was not distributed with this | 2 * License, v. 2.0. If a copy of the MPL was not distributed with this |
3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | 3 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ |
4 /* | 4 /* |
5 * Initialize the PCKS 11 subsystem | 5 * Initialize the PCKS 11 subsystem |
6 */ | 6 */ |
7 #include "seccomon.h" | 7 #include "seccomon.h" |
8 #include "secmod.h" | 8 #include "secmod.h" |
9 #include "nssilock.h" | 9 #include "nssilock.h" |
10 #include "secmodi.h" | 10 #include "secmodi.h" |
11 #include "secmodti.h" | 11 #include "secmodti.h" |
12 #include "pk11func.h" | 12 #include "pk11func.h" |
13 #include "pki3hack.h" | 13 #include "pki3hack.h" |
14 #include "secerr.h" | 14 #include "secerr.h" |
15 #include "dev.h" | 15 #include "dev.h" |
16 #include "pkcs11ni.h" | 16 #include "pkcs11ni.h" |
| 17 #include "utilpars.h" |
17 | 18 |
18 /* these are for displaying error messages */ | 19 /* these are for displaying error messages */ |
19 | 20 |
20 static SECMODModuleList *modules = NULL; | 21 static SECMODModuleList *modules = NULL; |
21 static SECMODModuleList *modulesDB = NULL; | 22 static SECMODModuleList *modulesDB = NULL; |
22 static SECMODModuleList *modulesUnload = NULL; | 23 static SECMODModuleList *modulesUnload = NULL; |
23 static SECMODModule *internalModule = NULL; | 24 static SECMODModule *internalModule = NULL; |
24 static SECMODModule *defaultDBModule = NULL; | 25 static SECMODModule *defaultDBModule = NULL; |
25 static SECMODModule *pendingModule = NULL; | 26 static SECMODModule *pendingModule = NULL; |
26 static SECMODListLock *moduleLock = NULL; | 27 static SECMODListLock *moduleLock = NULL; |
(...skipping 1048 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1075 slot->flagSeries = series; | 1076 slot->flagSeries = series; |
1076 SECMOD_ReleaseReadLock(moduleLock); | 1077 SECMOD_ReleaseReadLock(moduleLock); |
1077 PZ_Lock(mod->refLock); | 1078 PZ_Lock(mod->refLock); |
1078 mod->evControlMask &= ~SECMOD_END_WAIT; | 1079 mod->evControlMask &= ~SECMOD_END_WAIT; |
1079 PZ_Unlock(mod->refLock); | 1080 PZ_Unlock(mod->refLock); |
1080 return PK11_ReferenceSlot(slot); | 1081 return PK11_ReferenceSlot(slot); |
1081 } | 1082 } |
1082 } | 1083 } |
1083 SECMOD_ReleaseReadLock(moduleLock); | 1084 SECMOD_ReleaseReadLock(moduleLock); |
1084 /* if everything was perm modules, don't lock up forever */ | 1085 /* if everything was perm modules, don't lock up forever */ |
1085 » if (!removableSlotsFound) { | 1086 » if ((mod->slotCount !=0) && !removableSlotsFound) { |
1086 error =SEC_ERROR_NO_SLOT_SELECTED; | 1087 error =SEC_ERROR_NO_SLOT_SELECTED; |
1087 PZ_Lock(mod->refLock); | 1088 PZ_Lock(mod->refLock); |
1088 break; | 1089 break; |
1089 } | 1090 } |
1090 if (flags & CKF_DONT_BLOCK) { | 1091 if (flags & CKF_DONT_BLOCK) { |
1091 PZ_Lock(mod->refLock); | 1092 PZ_Lock(mod->refLock); |
1092 break; | 1093 break; |
1093 } | 1094 } |
1094 PR_Sleep(latency); | 1095 PR_Sleep(latency); |
1095 PZ_Lock(mod->refLock); | 1096 PZ_Lock(mod->refLock); |
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1244 SECMOD_GetReadLock(moduleLock); | 1245 SECMOD_GetReadLock(moduleLock); |
1245 for (i=0; i < mod->slotCount; i++) { | 1246 for (i=0; i < mod->slotCount; i++) { |
1246 PK11SlotInfo *slot = mod->slots[i]; | 1247 PK11SlotInfo *slot = mod->slots[i]; |
1247 /* perm modules are not inserted or removed */ | 1248 /* perm modules are not inserted or removed */ |
1248 if (slot->isPerm) { | 1249 if (slot->isPerm) { |
1249 continue; | 1250 continue; |
1250 } | 1251 } |
1251 ret = PR_TRUE; | 1252 ret = PR_TRUE; |
1252 break; | 1253 break; |
1253 } | 1254 } |
| 1255 if (mod->slotCount == 0 ) { |
| 1256 ret = PR_TRUE; |
| 1257 } |
1254 SECMOD_ReleaseReadLock(moduleLock); | 1258 SECMOD_ReleaseReadLock(moduleLock); |
1255 return ret; | 1259 return ret; |
1256 } | 1260 } |
1257 | 1261 |
1258 /* | 1262 /* |
1259 * helper function to actually create and destroy user defined slots | 1263 * helper function to actually create and destroy user defined slots |
1260 */ | 1264 */ |
1261 static SECStatus | 1265 static SECStatus |
1262 secmod_UserDBOp(PK11SlotInfo *slot, CK_OBJECT_CLASS objClass, | 1266 secmod_UserDBOp(PK11SlotInfo *slot, CK_OBJECT_CLASS objClass, |
1263 const char *sendSpec) | 1267 const char *sendSpec) |
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1361 return NULL; | 1365 return NULL; |
1362 } | 1366 } |
1363 | 1367 |
1364 /* just grab the first slot in the module, any present slot should work */ | 1368 /* just grab the first slot in the module, any present slot should work */ |
1365 slot = PK11_ReferenceSlot(mod->slots[0]); | 1369 slot = PK11_ReferenceSlot(mod->slots[0]); |
1366 if (slot == NULL) { | 1370 if (slot == NULL) { |
1367 return NULL; | 1371 return NULL; |
1368 } | 1372 } |
1369 | 1373 |
1370 /* we've found the slot, now build the moduleSpec */ | 1374 /* we've found the slot, now build the moduleSpec */ |
1371 escSpec = secmod_DoubleEscape(moduleSpec, '>', ']'); | 1375 escSpec = NSSUTIL_DoubleEscape(moduleSpec, '>', ']'); |
1372 if (escSpec == NULL) { | 1376 if (escSpec == NULL) { |
1373 PK11_FreeSlot(slot); | 1377 PK11_FreeSlot(slot); |
1374 return NULL; | 1378 return NULL; |
1375 } | 1379 } |
1376 sendSpec = PR_smprintf("tokens=[0x%x=<%s>]", slotID, escSpec); | 1380 sendSpec = PR_smprintf("tokens=[0x%x=<%s>]", slotID, escSpec); |
1377 PORT_Free(escSpec); | 1381 PORT_Free(escSpec); |
1378 | 1382 |
1379 if (sendSpec == NULL) { | 1383 if (sendSpec == NULL) { |
1380 /* PR_smprintf does not set SEC_ERROR_NO_MEMORY on failure. */ | 1384 /* PR_smprintf does not set SEC_ERROR_NO_MEMORY on failure. */ |
1381 PK11_FreeSlot(slot); | 1385 PK11_FreeSlot(slot); |
1382 PORT_SetError(SEC_ERROR_NO_MEMORY); | 1386 PORT_SetError(SEC_ERROR_NO_MEMORY); |
1383 return NULL; | 1387 return NULL; |
1384 } | 1388 } |
1385 rv = secmod_UserDBOp(slot, CKO_NETSCAPE_NEWSLOT, sendSpec); | 1389 rv = secmod_UserDBOp(slot, CKO_NETSCAPE_NEWSLOT, sendSpec); |
1386 PR_smprintf_free(sendSpec); | 1390 PR_smprintf_free(sendSpec); |
1387 PK11_FreeSlot(slot); | 1391 PK11_FreeSlot(slot); |
1388 if (rv != SECSuccess) { | 1392 if (rv != SECSuccess) { |
1389 return NULL; | 1393 return NULL; |
1390 } | 1394 } |
1391 | 1395 |
1392 return SECMOD_FindSlotByID(mod, slotID); | 1396 slot = SECMOD_FindSlotByID(mod, slotID); |
| 1397 if (slot) { |
| 1398 » /* if we are in the delay period for the "isPresent" call, reset |
| 1399 » * the delay since we know things have probably changed... */ |
| 1400 » if (slot->nssToken && slot->nssToken->slot) { |
| 1401 » nssSlot_ResetDelay(slot->nssToken->slot); |
| 1402 » } |
| 1403 » /* force the slot info structures to properly reset */ |
| 1404 » (void)PK11_IsPresent(slot); |
| 1405 } |
| 1406 return slot; |
1393 } | 1407 } |
1394 | 1408 |
1395 /* | 1409 /* |
1396 * Open a new database using the softoken. The caller is responsible for making | 1410 * Open a new database using the softoken. The caller is responsible for making |
1397 * sure the module spec is correct and usable. The caller should ask for one | 1411 * sure the module spec is correct and usable. The caller should ask for one |
1398 * new database per call if the caller wants to get meaningful information | 1412 * new database per call if the caller wants to get meaningful information |
1399 * about the new database. | 1413 * about the new database. |
1400 * | 1414 * |
1401 * moduleSpec is the same data that you would pass to softoken at | 1415 * moduleSpec is the same data that you would pass to softoken at |
1402 * initialization time under the 'tokens' options. For example, if you were | 1416 * initialization time under the 'tokens' options. For example, if you were |
(...skipping 153 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1556 * on multiple failures, we are only returning the lastError. The caller | 1570 * on multiple failures, we are only returning the lastError. The caller |
1557 * can determine which slots are bad by calling PK11_IsDisabled(). | 1571 * can determine which slots are bad by calling PK11_IsDisabled(). |
1558 */ | 1572 */ |
1559 if (rrv != SECSuccess) { | 1573 if (rrv != SECSuccess) { |
1560 /* restore the last error code */ | 1574 /* restore the last error code */ |
1561 PORT_SetError(lastError); | 1575 PORT_SetError(lastError); |
1562 } | 1576 } |
1563 | 1577 |
1564 return rrv; | 1578 return rrv; |
1565 } | 1579 } |
OLD | NEW |