Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(242)

Side by Side Diff: nss/lib/ckfw/sessobj.c

Issue 1843333003: Update NSPR to 4.12 and NSS to 3.23 on iOS (Closed) Base URL: https://chromium.googlesource.com/chromium/deps/nss.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 /* 5 /*
6 * sessobj.c 6 * sessobj.c
7 * 7 *
8 * This file contains an NSSCKMDObject implementation for session 8 * This file contains an NSSCKMDObject implementation for session
9 * objects. The framework uses this implementation to manage 9 * objects. The framework uses this implementation to manage
10 * session objects when a Module doesn't wish to be bothered. 10 * session objects when a Module doesn't wish to be bothered.
11 */ 11 */
12 12
13 #ifndef CK_T 13 #ifndef CK_T
14 #include "ck.h" 14 #include "ck.h"
15 #endif /* CK_T */ 15 #endif /* CK_T */
16 16
17 /* 17 /*
18 * nssCKMDSessionObject 18 * nssCKMDSessionObject
19 * 19 *
20 * -- create -- 20 * -- create --
21 * nssCKMDSessionObject_Create 21 * nssCKMDSessionObject_Create
22 * 22 *
23 * -- EPV calls -- 23 * -- EPV calls --
24 * nss_ckmdSessionObject_Finalize 24 * nss_ckmdSessionObject_Finalize
25 * nss_ckmdSessionObject_IsTokenObject 25 * nss_ckmdSessionObject_IsTokenObject
26 * nss_ckmdSessionObject_GetAttributeCount 26 * nss_ckmdSessionObject_GetAttributeCount
27 * nss_ckmdSessionObject_GetAttributeTypes 27 * nss_ckmdSessionObject_GetAttributeTypes
28 * nss_ckmdSessionObject_GetAttributeSize 28 * nss_ckmdSessionObject_GetAttributeSize
29 * nss_ckmdSessionObject_GetAttribute 29 * nss_ckmdSessionObject_GetAttribute
30 * nss_ckmdSessionObject_SetAttribute 30 * nss_ckmdSessionObject_SetAttribute
31 * nss_ckmdSessionObject_GetObjectSize 31 * nss_ckmdSessionObject_GetObjectSize
32 */ 32 */
33 33
34 struct nssCKMDSessionObjectStr { 34 struct nssCKMDSessionObjectStr {
35 CK_ULONG n; 35 CK_ULONG n;
36 NSSArena *arena; 36 NSSArena *arena;
37 NSSItem *attributes; 37 NSSItem *attributes;
38 CK_ATTRIBUTE_TYPE_PTR types; 38 CK_ATTRIBUTE_TYPE_PTR types;
39 nssCKFWHash *hash; 39 nssCKFWHash *hash;
40 }; 40 };
41 typedef struct nssCKMDSessionObjectStr nssCKMDSessionObject; 41 typedef struct nssCKMDSessionObjectStr nssCKMDSessionObject;
42 42
43 #ifdef DEBUG 43 #ifdef DEBUG
44 /* 44 /*
45 * But first, the pointer-tracking stuff. 45 * But first, the pointer-tracking stuff.
46 * 46 *
47 * NOTE: the pointer-tracking support in NSS/base currently relies 47 * NOTE: the pointer-tracking support in NSS/base currently relies
48 * upon NSPR's CallOnce support. That, however, relies upon NSPR's 48 * upon NSPR's CallOnce support. That, however, relies upon NSPR's
49 * locking, which is tied into the runtime. We need a pointer-tracker 49 * locking, which is tied into the runtime. We need a pointer-tracker
50 * implementation that uses the locks supplied through C_Initialize. 50 * implementation that uses the locks supplied through C_Initialize.
51 * That support, however, can be filled in later. So for now, I'll 51 * That support, however, can be filled in later. So for now, I'll
52 * just do this routines as no-ops. 52 * just do this routines as no-ops.
53 */ 53 */
54 54
55 static CK_RV 55 static CK_RV
56 nss_ckmdSessionObject_add_pointer 56 nss_ckmdSessionObject_add_pointer(
57 ( 57 const NSSCKMDObject *mdObject)
58 const NSSCKMDObject *mdObject
59 )
60 { 58 {
61 return CKR_OK; 59 return CKR_OK;
62 } 60 }
63 61
64 static CK_RV 62 static CK_RV
65 nss_ckmdSessionObject_remove_pointer 63 nss_ckmdSessionObject_remove_pointer(
66 ( 64 const NSSCKMDObject *mdObject)
67 const NSSCKMDObject *mdObject
68 )
69 { 65 {
70 return CKR_OK; 66 return CKR_OK;
71 } 67 }
72 68
73 #ifdef NSS_DEBUG 69 #ifdef NSS_DEBUG
74 static CK_RV 70 static CK_RV
75 nss_ckmdSessionObject_verifyPointer 71 nss_ckmdSessionObject_verifyPointer(
76 ( 72 const NSSCKMDObject *mdObject)
77 const NSSCKMDObject *mdObject
78 )
79 { 73 {
80 return CKR_OK; 74 return CKR_OK;
81 } 75 }
82 #endif 76 #endif
83 77
84 #endif /* DEBUG */ 78 #endif /* DEBUG */
85 79
86 /* 80 /*
87 * We must forward-declare these routines 81 * We must forward-declare these routines
88 */ 82 */
89 static void 83 static void
90 nss_ckmdSessionObject_Finalize 84 nss_ckmdSessionObject_Finalize(
91 ( 85 NSSCKMDObject *mdObject,
92 NSSCKMDObject *mdObject, 86 NSSCKFWObject *fwObject,
93 NSSCKFWObject *fwObject, 87 NSSCKMDSession *mdSession,
94 NSSCKMDSession *mdSession, 88 NSSCKFWSession *fwSession,
95 NSSCKFWSession *fwSession, 89 NSSCKMDToken *mdToken,
96 NSSCKMDToken *mdToken, 90 NSSCKFWToken *fwToken,
97 NSSCKFWToken *fwToken, 91 NSSCKMDInstance *mdInstance,
98 NSSCKMDInstance *mdInstance, 92 NSSCKFWInstance *fwInstance);
99 NSSCKFWInstance *fwInstance
100 );
101 93
102 static CK_RV 94 static CK_RV
103 nss_ckmdSessionObject_Destroy 95 nss_ckmdSessionObject_Destroy(
104 ( 96 NSSCKMDObject *mdObject,
105 NSSCKMDObject *mdObject, 97 NSSCKFWObject *fwObject,
106 NSSCKFWObject *fwObject, 98 NSSCKMDSession *mdSession,
107 NSSCKMDSession *mdSession, 99 NSSCKFWSession *fwSession,
108 NSSCKFWSession *fwSession, 100 NSSCKMDToken *mdToken,
109 NSSCKMDToken *mdToken, 101 NSSCKFWToken *fwToken,
110 NSSCKFWToken *fwToken, 102 NSSCKMDInstance *mdInstance,
111 NSSCKMDInstance *mdInstance, 103 NSSCKFWInstance *fwInstance);
112 NSSCKFWInstance *fwInstance
113 );
114 104
115 static CK_BBOOL 105 static CK_BBOOL
116 nss_ckmdSessionObject_IsTokenObject 106 nss_ckmdSessionObject_IsTokenObject(
117 ( 107 NSSCKMDObject *mdObject,
118 NSSCKMDObject *mdObject, 108 NSSCKFWObject *fwObject,
119 NSSCKFWObject *fwObject, 109 NSSCKMDSession *mdSession,
120 NSSCKMDSession *mdSession, 110 NSSCKFWSession *fwSession,
121 NSSCKFWSession *fwSession, 111 NSSCKMDToken *mdToken,
122 NSSCKMDToken *mdToken, 112 NSSCKFWToken *fwToken,
123 NSSCKFWToken *fwToken, 113 NSSCKMDInstance *mdInstance,
124 NSSCKMDInstance *mdInstance, 114 NSSCKFWInstance *fwInstance);
125 NSSCKFWInstance *fwInstance
126 );
127 115
128 static CK_ULONG 116 static CK_ULONG
129 nss_ckmdSessionObject_GetAttributeCount 117 nss_ckmdSessionObject_GetAttributeCount(
130 ( 118 NSSCKMDObject *mdObject,
131 NSSCKMDObject *mdObject, 119 NSSCKFWObject *fwObject,
132 NSSCKFWObject *fwObject, 120 NSSCKMDSession *mdSession,
133 NSSCKMDSession *mdSession, 121 NSSCKFWSession *fwSession,
134 NSSCKFWSession *fwSession, 122 NSSCKMDToken *mdToken,
135 NSSCKMDToken *mdToken, 123 NSSCKFWToken *fwToken,
136 NSSCKFWToken *fwToken, 124 NSSCKMDInstance *mdInstance,
137 NSSCKMDInstance *mdInstance, 125 NSSCKFWInstance *fwInstance,
138 NSSCKFWInstance *fwInstance, 126 CK_RV *pError);
139 CK_RV *pError
140 );
141 127
142 static CK_RV 128 static CK_RV
143 nss_ckmdSessionObject_GetAttributeTypes 129 nss_ckmdSessionObject_GetAttributeTypes(
144 ( 130 NSSCKMDObject *mdObject,
145 NSSCKMDObject *mdObject, 131 NSSCKFWObject *fwObject,
146 NSSCKFWObject *fwObject, 132 NSSCKMDSession *mdSession,
147 NSSCKMDSession *mdSession, 133 NSSCKFWSession *fwSession,
148 NSSCKFWSession *fwSession, 134 NSSCKMDToken *mdToken,
149 NSSCKMDToken *mdToken, 135 NSSCKFWToken *fwToken,
150 NSSCKFWToken *fwToken, 136 NSSCKMDInstance *mdInstance,
151 NSSCKMDInstance *mdInstance, 137 NSSCKFWInstance *fwInstance,
152 NSSCKFWInstance *fwInstance, 138 CK_ATTRIBUTE_TYPE_PTR typeArray,
153 CK_ATTRIBUTE_TYPE_PTR typeArray, 139 CK_ULONG ulCount);
154 CK_ULONG ulCount
155 );
156 140
157 static CK_ULONG 141 static CK_ULONG
158 nss_ckmdSessionObject_GetAttributeSize 142 nss_ckmdSessionObject_GetAttributeSize(
159 ( 143 NSSCKMDObject *mdObject,
160 NSSCKMDObject *mdObject, 144 NSSCKFWObject *fwObject,
161 NSSCKFWObject *fwObject, 145 NSSCKMDSession *mdSession,
162 NSSCKMDSession *mdSession, 146 NSSCKFWSession *fwSession,
163 NSSCKFWSession *fwSession, 147 NSSCKMDToken *mdToken,
164 NSSCKMDToken *mdToken, 148 NSSCKFWToken *fwToken,
165 NSSCKFWToken *fwToken, 149 NSSCKMDInstance *mdInstance,
166 NSSCKMDInstance *mdInstance, 150 NSSCKFWInstance *fwInstance,
167 NSSCKFWInstance *fwInstance, 151 CK_ATTRIBUTE_TYPE attribute,
168 CK_ATTRIBUTE_TYPE attribute, 152 CK_RV *pError);
169 CK_RV *pError
170 );
171 153
172 static NSSCKFWItem 154 static NSSCKFWItem
173 nss_ckmdSessionObject_GetAttribute 155 nss_ckmdSessionObject_GetAttribute(
174 ( 156 NSSCKMDObject *mdObject,
175 NSSCKMDObject *mdObject, 157 NSSCKFWObject *fwObject,
176 NSSCKFWObject *fwObject, 158 NSSCKMDSession *mdSession,
177 NSSCKMDSession *mdSession, 159 NSSCKFWSession *fwSession,
178 NSSCKFWSession *fwSession, 160 NSSCKMDToken *mdToken,
179 NSSCKMDToken *mdToken, 161 NSSCKFWToken *fwToken,
180 NSSCKFWToken *fwToken, 162 NSSCKMDInstance *mdInstance,
181 NSSCKMDInstance *mdInstance, 163 NSSCKFWInstance *fwInstance,
182 NSSCKFWInstance *fwInstance, 164 CK_ATTRIBUTE_TYPE attribute,
183 CK_ATTRIBUTE_TYPE attribute, 165 CK_RV *pError);
184 CK_RV *pError
185 );
186 166
187 static CK_RV 167 static CK_RV
188 nss_ckmdSessionObject_SetAttribute 168 nss_ckmdSessionObject_SetAttribute(
189 ( 169 NSSCKMDObject *mdObject,
190 NSSCKMDObject *mdObject, 170 NSSCKFWObject *fwObject,
191 NSSCKFWObject *fwObject, 171 NSSCKMDSession *mdSession,
192 NSSCKMDSession *mdSession, 172 NSSCKFWSession *fwSession,
193 NSSCKFWSession *fwSession, 173 NSSCKMDToken *mdToken,
194 NSSCKMDToken *mdToken, 174 NSSCKFWToken *fwToken,
195 NSSCKFWToken *fwToken, 175 NSSCKMDInstance *mdInstance,
196 NSSCKMDInstance *mdInstance, 176 NSSCKFWInstance *fwInstance,
197 NSSCKFWInstance *fwInstance, 177 CK_ATTRIBUTE_TYPE attribute,
198 CK_ATTRIBUTE_TYPE attribute, 178 NSSItem *value);
199 NSSItem *value
200 );
201 179
202 static CK_ULONG 180 static CK_ULONG
203 nss_ckmdSessionObject_GetObjectSize 181 nss_ckmdSessionObject_GetObjectSize(
204 ( 182 NSSCKMDObject *mdObject,
205 NSSCKMDObject *mdObject, 183 NSSCKFWObject *fwObject,
206 NSSCKFWObject *fwObject, 184 NSSCKMDSession *mdSession,
207 NSSCKMDSession *mdSession, 185 NSSCKFWSession *fwSession,
208 NSSCKFWSession *fwSession, 186 NSSCKMDToken *mdToken,
209 NSSCKMDToken *mdToken, 187 NSSCKFWToken *fwToken,
210 NSSCKFWToken *fwToken, 188 NSSCKMDInstance *mdInstance,
211 NSSCKMDInstance *mdInstance, 189 NSSCKFWInstance *fwInstance,
212 NSSCKFWInstance *fwInstance, 190 CK_RV *pError);
213 CK_RV *pError
214 );
215 191
216 /* 192 /*
217 * nssCKMDSessionObject_Create 193 * nssCKMDSessionObject_Create
218 * 194 *
219 */ 195 */
220 NSS_IMPLEMENT NSSCKMDObject * 196 NSS_IMPLEMENT NSSCKMDObject *
221 nssCKMDSessionObject_Create 197 nssCKMDSessionObject_Create(
222 ( 198 NSSCKFWToken *fwToken,
223 NSSCKFWToken *fwToken, 199 NSSArena *arena,
224 NSSArena *arena, 200 CK_ATTRIBUTE_PTR attributes,
225 CK_ATTRIBUTE_PTR attributes, 201 CK_ULONG ulCount,
226 CK_ULONG ulCount, 202 CK_RV *pError)
227 CK_RV *pError
228 )
229 { 203 {
230 NSSCKMDObject *mdObject = (NSSCKMDObject *)NULL; 204 NSSCKMDObject *mdObject = (NSSCKMDObject *)NULL;
231 nssCKMDSessionObject *mdso = (nssCKMDSessionObject *)NULL; 205 nssCKMDSessionObject *mdso = (nssCKMDSessionObject *)NULL;
232 CK_ULONG i; 206 CK_ULONG i;
233 nssCKFWHash *hash; 207 nssCKFWHash *hash;
234 208
235 *pError = CKR_OK; 209 *pError = CKR_OK;
236 210
237 mdso = nss_ZNEW(arena, nssCKMDSessionObject); 211 mdso = nss_ZNEW(arena, nssCKMDSessionObject);
238 if (!mdso) { 212 if (!mdso) {
239 goto loser; 213 goto loser;
240 } 214 }
241 215
242 mdso->arena = arena; 216 mdso->arena = arena;
243 mdso->n = ulCount; 217 mdso->n = ulCount;
244 mdso->attributes = nss_ZNEWARRAY(arena, NSSItem, ulCount); 218 mdso->attributes = nss_ZNEWARRAY(arena, NSSItem, ulCount);
245 if (!mdso->attributes) { 219 if (!mdso->attributes) {
246 goto loser; 220 goto loser;
247 } 221 }
248 222
249 mdso->types = nss_ZNEWARRAY(arena, CK_ATTRIBUTE_TYPE, ulCount); 223 mdso->types = nss_ZNEWARRAY(arena, CK_ATTRIBUTE_TYPE, ulCount);
250 if (!mdso->types) { 224 if (!mdso->types) {
251 goto loser; 225 goto loser;
252 } 226 }
253 for( i = 0; i < ulCount; i++ ) { 227 for (i = 0; i < ulCount; i++) {
254 mdso->types[i] = attributes[i].type; 228 mdso->types[i] = attributes[i].type;
255 mdso->attributes[i].size = attributes[i].ulValueLen; 229 mdso->attributes[i].size = attributes[i].ulValueLen;
256 mdso->attributes[i].data = nss_ZAlloc(arena, attributes[i].ulValueLen); 230 mdso->attributes[i].data = nss_ZAlloc(arena, attributes[i].ulValueLen);
257 if (!mdso->attributes[i].data) { 231 if (!mdso->attributes[i].data) {
258 goto loser; 232 goto loser;
259 } 233 }
260 (void)nsslibc_memcpy(mdso->attributes[i].data, attributes[i].pValue, 234 (void)nsslibc_memcpy(mdso->attributes[i].data, attributes[i].pValue,
261 attributes[i].ulValueLen); 235 attributes[i].ulValueLen);
262 } 236 }
263 237
264 mdObject = nss_ZNEW(arena, NSSCKMDObject); 238 mdObject = nss_ZNEW(arena, NSSCKMDObject);
265 if (!mdObject) { 239 if (!mdObject) {
266 goto loser; 240 goto loser;
267 } 241 }
268 242
269 mdObject->etc = (void *)mdso; 243 mdObject->etc = (void *)mdso;
270 mdObject->Finalize = nss_ckmdSessionObject_Finalize; 244 mdObject->Finalize = nss_ckmdSessionObject_Finalize;
271 mdObject->Destroy = nss_ckmdSessionObject_Destroy; 245 mdObject->Destroy = nss_ckmdSessionObject_Destroy;
272 mdObject->IsTokenObject = nss_ckmdSessionObject_IsTokenObject; 246 mdObject->IsTokenObject = nss_ckmdSessionObject_IsTokenObject;
273 mdObject->GetAttributeCount = nss_ckmdSessionObject_GetAttributeCount; 247 mdObject->GetAttributeCount = nss_ckmdSessionObject_GetAttributeCount;
274 mdObject->GetAttributeTypes = nss_ckmdSessionObject_GetAttributeTypes; 248 mdObject->GetAttributeTypes = nss_ckmdSessionObject_GetAttributeTypes;
275 mdObject->GetAttributeSize = nss_ckmdSessionObject_GetAttributeSize; 249 mdObject->GetAttributeSize = nss_ckmdSessionObject_GetAttributeSize;
276 mdObject->GetAttribute = nss_ckmdSessionObject_GetAttribute; 250 mdObject->GetAttribute = nss_ckmdSessionObject_GetAttribute;
277 mdObject->SetAttribute = nss_ckmdSessionObject_SetAttribute; 251 mdObject->SetAttribute = nss_ckmdSessionObject_SetAttribute;
278 mdObject->GetObjectSize = nss_ckmdSessionObject_GetObjectSize; 252 mdObject->GetObjectSize = nss_ckmdSessionObject_GetObjectSize;
279 253
280 hash = nssCKFWToken_GetSessionObjectHash(fwToken); 254 hash = nssCKFWToken_GetSessionObjectHash(fwToken);
281 if (!hash) { 255 if (!hash) {
282 *pError = CKR_GENERAL_ERROR; 256 *pError = CKR_GENERAL_ERROR;
283 goto loser; 257 goto loser;
284 } 258 }
285 259
286 mdso->hash = hash; 260 mdso->hash = hash;
287 261
288 *pError = nssCKFWHash_Add(hash, mdObject, mdObject); 262 *pError = nssCKFWHash_Add(hash, mdObject, mdObject);
289 if( CKR_OK != *pError ) { 263 if (CKR_OK != *pError) {
290 goto loser; 264 goto loser;
291 } 265 }
292 266
293 #ifdef DEBUG 267 #ifdef DEBUG
294 if(( *pError = nss_ckmdSessionObject_add_pointer(mdObject)) != CKR_OK ) { 268 if ((*pError = nss_ckmdSessionObject_add_pointer(mdObject)) != CKR_OK) {
295 goto loser; 269 goto loser;
296 } 270 }
297 #endif /* DEBUG */ 271 #endif /* DEBUG */
298 272
299 return mdObject; 273 return mdObject;
300 274
301 loser: 275 loser:
302 if (mdso) { 276 if (mdso) {
303 if (mdso->attributes) { 277 if (mdso->attributes) {
304 for( i = 0; i < ulCount; i++ ) { 278 for (i = 0; i < ulCount; i++) {
305 nss_ZFreeIf(mdso->attributes[i].data); 279 nss_ZFreeIf(mdso->attributes[i].data);
306 } 280 }
307 nss_ZFreeIf(mdso->attributes); 281 nss_ZFreeIf(mdso->attributes);
308 } 282 }
309 nss_ZFreeIf(mdso->types); 283 nss_ZFreeIf(mdso->types);
310 nss_ZFreeIf(mdso); 284 nss_ZFreeIf(mdso);
311 } 285 }
312 286
313 nss_ZFreeIf(mdObject); 287 nss_ZFreeIf(mdObject);
314 if (*pError == CKR_OK) { 288 if (*pError == CKR_OK) {
315 *pError = CKR_HOST_MEMORY; 289 *pError = CKR_HOST_MEMORY;
316 } 290 }
317 return (NSSCKMDObject *)NULL; 291 return (NSSCKMDObject *)NULL;
318 } 292 }
319 293
320 /* 294 /*
321 * nss_ckmdSessionObject_Finalize 295 * nss_ckmdSessionObject_Finalize
322 * 296 *
323 */ 297 */
324 static void 298 static void
325 nss_ckmdSessionObject_Finalize 299 nss_ckmdSessionObject_Finalize(
326 ( 300 NSSCKMDObject *mdObject,
327 NSSCKMDObject *mdObject, 301 NSSCKFWObject *fwObject,
328 NSSCKFWObject *fwObject, 302 NSSCKMDSession *mdSession,
329 NSSCKMDSession *mdSession, 303 NSSCKFWSession *fwSession,
330 NSSCKFWSession *fwSession, 304 NSSCKMDToken *mdToken,
331 NSSCKMDToken *mdToken, 305 NSSCKFWToken *fwToken,
332 NSSCKFWToken *fwToken, 306 NSSCKMDInstance *mdInstance,
333 NSSCKMDInstance *mdInstance, 307 NSSCKFWInstance *fwInstance)
334 NSSCKFWInstance *fwInstance
335 )
336 { 308 {
337 /* This shouldn't ever be called */ 309 /* This shouldn't ever be called */
338 return; 310 return;
339 } 311 }
340 312
341 /* 313 /*
342 * nss_ckmdSessionObject_Destroy 314 * nss_ckmdSessionObject_Destroy
343 * 315 *
344 */ 316 */
345 317
346 static CK_RV 318 static CK_RV
347 nss_ckmdSessionObject_Destroy 319 nss_ckmdSessionObject_Destroy(
348 ( 320 NSSCKMDObject *mdObject,
349 NSSCKMDObject *mdObject, 321 NSSCKFWObject *fwObject,
350 NSSCKFWObject *fwObject, 322 NSSCKMDSession *mdSession,
351 NSSCKMDSession *mdSession, 323 NSSCKFWSession *fwSession,
352 NSSCKFWSession *fwSession, 324 NSSCKMDToken *mdToken,
353 NSSCKMDToken *mdToken, 325 NSSCKFWToken *fwToken,
354 NSSCKFWToken *fwToken, 326 NSSCKMDInstance *mdInstance,
355 NSSCKMDInstance *mdInstance, 327 NSSCKFWInstance *fwInstance)
356 NSSCKFWInstance *fwInstance
357 )
358 { 328 {
359 #ifdef NSSDEBUG 329 #ifdef NSSDEBUG
360 CK_RV error = CKR_OK; 330 CK_RV error = CKR_OK;
361 #endif /* NSSDEBUG */ 331 #endif /* NSSDEBUG */
362 nssCKMDSessionObject *mdso; 332 nssCKMDSessionObject *mdso;
363 CK_ULONG i; 333 CK_ULONG i;
364 334
365 #ifdef NSSDEBUG 335 #ifdef NSSDEBUG
366 error = nss_ckmdSessionObject_verifyPointer(mdObject); 336 error = nss_ckmdSessionObject_verifyPointer(mdObject);
367 if( CKR_OK != error ) { 337 if (CKR_OK != error) {
368 return error; 338 return error;
369 } 339 }
370 #endif /* NSSDEBUG */ 340 #endif /* NSSDEBUG */
371 341
372 mdso = (nssCKMDSessionObject *)mdObject->etc; 342 mdso = (nssCKMDSessionObject *)mdObject->etc;
373 343
374 nssCKFWHash_Remove(mdso->hash, mdObject); 344 nssCKFWHash_Remove(mdso->hash, mdObject);
375 345
376 for( i = 0; i < mdso->n; i++ ) { 346 for (i = 0; i < mdso->n; i++) {
377 nss_ZFreeIf(mdso->attributes[i].data); 347 nss_ZFreeIf(mdso->attributes[i].data);
378 } 348 }
379 nss_ZFreeIf(mdso->attributes); 349 nss_ZFreeIf(mdso->attributes);
380 nss_ZFreeIf(mdso->types); 350 nss_ZFreeIf(mdso->types);
381 nss_ZFreeIf(mdso); 351 nss_ZFreeIf(mdso);
382 nss_ZFreeIf(mdObject); 352 nss_ZFreeIf(mdObject);
383 353
384 #ifdef DEBUG 354 #ifdef DEBUG
385 (void)nss_ckmdSessionObject_remove_pointer(mdObject); 355 (void)nss_ckmdSessionObject_remove_pointer(mdObject);
386 #endif /* DEBUG */ 356 #endif /* DEBUG */
387 357
388 return CKR_OK; 358 return CKR_OK;
389 } 359 }
390 360
391 /* 361 /*
392 * nss_ckmdSessionObject_IsTokenObject 362 * nss_ckmdSessionObject_IsTokenObject
393 * 363 *
394 */ 364 */
395 365
396 static CK_BBOOL 366 static CK_BBOOL
397 nss_ckmdSessionObject_IsTokenObject 367 nss_ckmdSessionObject_IsTokenObject(
398 ( 368 NSSCKMDObject *mdObject,
399 NSSCKMDObject *mdObject, 369 NSSCKFWObject *fwObject,
400 NSSCKFWObject *fwObject, 370 NSSCKMDSession *mdSession,
401 NSSCKMDSession *mdSession, 371 NSSCKFWSession *fwSession,
402 NSSCKFWSession *fwSession, 372 NSSCKMDToken *mdToken,
403 NSSCKMDToken *mdToken, 373 NSSCKFWToken *fwToken,
404 NSSCKFWToken *fwToken, 374 NSSCKMDInstance *mdInstance,
405 NSSCKMDInstance *mdInstance, 375 NSSCKFWInstance *fwInstance)
406 NSSCKFWInstance *fwInstance
407 )
408 { 376 {
409 #ifdef NSSDEBUG 377 #ifdef NSSDEBUG
410 if( CKR_OK != nss_ckmdSessionObject_verifyPointer(mdObject) ) { 378 if (CKR_OK != nss_ckmdSessionObject_verifyPointer(mdObject)) {
411 return CK_FALSE; 379 return CK_FALSE;
412 } 380 }
413 #endif /* NSSDEBUG */ 381 #endif /* NSSDEBUG */
414 382
415 /* 383 /*
416 * This implementation is only ever used for session objects. 384 * This implementation is only ever used for session objects.
417 */ 385 */
418 return CK_FALSE; 386 return CK_FALSE;
419 } 387 }
420 388
421 /* 389 /*
422 * nss_ckmdSessionObject_GetAttributeCount 390 * nss_ckmdSessionObject_GetAttributeCount
423 * 391 *
424 */ 392 */
425 static CK_ULONG 393 static CK_ULONG
426 nss_ckmdSessionObject_GetAttributeCount 394 nss_ckmdSessionObject_GetAttributeCount(
427 ( 395 NSSCKMDObject *mdObject,
428 NSSCKMDObject *mdObject, 396 NSSCKFWObject *fwObject,
429 NSSCKFWObject *fwObject, 397 NSSCKMDSession *mdSession,
430 NSSCKMDSession *mdSession, 398 NSSCKFWSession *fwSession,
431 NSSCKFWSession *fwSession, 399 NSSCKMDToken *mdToken,
432 NSSCKMDToken *mdToken, 400 NSSCKFWToken *fwToken,
433 NSSCKFWToken *fwToken, 401 NSSCKMDInstance *mdInstance,
434 NSSCKMDInstance *mdInstance, 402 NSSCKFWInstance *fwInstance,
435 NSSCKFWInstance *fwInstance, 403 CK_RV *pError)
436 CK_RV *pError
437 )
438 { 404 {
439 nssCKMDSessionObject *obj; 405 nssCKMDSessionObject *obj;
440 406
441 #ifdef NSSDEBUG 407 #ifdef NSSDEBUG
442 if (!pError) { 408 if (!pError) {
443 return 0; 409 return 0;
444 } 410 }
445 411
446 *pError = nss_ckmdSessionObject_verifyPointer(mdObject); 412 *pError = nss_ckmdSessionObject_verifyPointer(mdObject);
447 if( CKR_OK != *pError ) { 413 if (CKR_OK != *pError) {
448 return 0; 414 return 0;
449 } 415 }
450 416
451 /* We could even check all the other arguments, for sanity. */ 417 /* We could even check all the other arguments, for sanity. */
452 #endif /* NSSDEBUG */ 418 #endif /* NSSDEBUG */
453 419
454 obj = (nssCKMDSessionObject *)mdObject->etc; 420 obj = (nssCKMDSessionObject *)mdObject->etc;
455 421
456 return obj->n; 422 return obj->n;
457 } 423 }
458 424
459 /* 425 /*
460 * nss_ckmdSessionObject_GetAttributeTypes 426 * nss_ckmdSessionObject_GetAttributeTypes
461 * 427 *
462 */ 428 */
463 static CK_RV 429 static CK_RV
464 nss_ckmdSessionObject_GetAttributeTypes 430 nss_ckmdSessionObject_GetAttributeTypes(
465 ( 431 NSSCKMDObject *mdObject,
466 NSSCKMDObject *mdObject, 432 NSSCKFWObject *fwObject,
467 NSSCKFWObject *fwObject, 433 NSSCKMDSession *mdSession,
468 NSSCKMDSession *mdSession, 434 NSSCKFWSession *fwSession,
469 NSSCKFWSession *fwSession, 435 NSSCKMDToken *mdToken,
470 NSSCKMDToken *mdToken, 436 NSSCKFWToken *fwToken,
471 NSSCKFWToken *fwToken, 437 NSSCKMDInstance *mdInstance,
472 NSSCKMDInstance *mdInstance, 438 NSSCKFWInstance *fwInstance,
473 NSSCKFWInstance *fwInstance, 439 CK_ATTRIBUTE_TYPE_PTR typeArray,
474 CK_ATTRIBUTE_TYPE_PTR typeArray, 440 CK_ULONG ulCount)
475 CK_ULONG ulCount
476 )
477 { 441 {
478 #ifdef NSSDEBUG 442 #ifdef NSSDEBUG
479 CK_RV error = CKR_OK; 443 CK_RV error = CKR_OK;
480 #endif /* NSSDEBUG */ 444 #endif /* NSSDEBUG */
481 nssCKMDSessionObject *obj; 445 nssCKMDSessionObject *obj;
482 446
483 #ifdef NSSDEBUG 447 #ifdef NSSDEBUG
484 error = nss_ckmdSessionObject_verifyPointer(mdObject); 448 error = nss_ckmdSessionObject_verifyPointer(mdObject);
485 if( CKR_OK != error ) { 449 if (CKR_OK != error) {
486 return error; 450 return error;
487 } 451 }
488 452
489 /* We could even check all the other arguments, for sanity. */ 453 /* We could even check all the other arguments, for sanity. */
490 #endif /* NSSDEBUG */ 454 #endif /* NSSDEBUG */
491 455
492 obj = (nssCKMDSessionObject *)mdObject->etc; 456 obj = (nssCKMDSessionObject *)mdObject->etc;
493 457
494 if( ulCount < obj->n ) { 458 if (ulCount < obj->n) {
495 return CKR_BUFFER_TOO_SMALL; 459 return CKR_BUFFER_TOO_SMALL;
496 } 460 }
497 461
498 (void)nsslibc_memcpy(typeArray, obj->types, 462 (void)nsslibc_memcpy(typeArray, obj->types,
499 sizeof(CK_ATTRIBUTE_TYPE) * obj->n); 463 sizeof(CK_ATTRIBUTE_TYPE) *
464 obj->n);
500 465
501 return CKR_OK; 466 return CKR_OK;
502 } 467 }
503 468
504 /* 469 /*
505 * nss_ckmdSessionObject_GetAttributeSize 470 * nss_ckmdSessionObject_GetAttributeSize
506 * 471 *
507 */ 472 */
508 static CK_ULONG 473 static CK_ULONG
509 nss_ckmdSessionObject_GetAttributeSize 474 nss_ckmdSessionObject_GetAttributeSize(
510 ( 475 NSSCKMDObject *mdObject,
511 NSSCKMDObject *mdObject, 476 NSSCKFWObject *fwObject,
512 NSSCKFWObject *fwObject, 477 NSSCKMDSession *mdSession,
513 NSSCKMDSession *mdSession, 478 NSSCKFWSession *fwSession,
514 NSSCKFWSession *fwSession, 479 NSSCKMDToken *mdToken,
515 NSSCKMDToken *mdToken, 480 NSSCKFWToken *fwToken,
516 NSSCKFWToken *fwToken, 481 NSSCKMDInstance *mdInstance,
517 NSSCKMDInstance *mdInstance, 482 NSSCKFWInstance *fwInstance,
518 NSSCKFWInstance *fwInstance, 483 CK_ATTRIBUTE_TYPE attribute,
519 CK_ATTRIBUTE_TYPE attribute, 484 CK_RV *pError)
520 CK_RV *pError
521 )
522 { 485 {
523 nssCKMDSessionObject *obj; 486 nssCKMDSessionObject *obj;
524 CK_ULONG i; 487 CK_ULONG i;
525 488
526 #ifdef NSSDEBUG 489 #ifdef NSSDEBUG
527 if (!pError) { 490 if (!pError) {
528 return 0; 491 return 0;
529 } 492 }
530 493
531 *pError = nss_ckmdSessionObject_verifyPointer(mdObject); 494 *pError = nss_ckmdSessionObject_verifyPointer(mdObject);
532 if( CKR_OK != *pError ) { 495 if (CKR_OK != *pError) {
533 return 0; 496 return 0;
534 } 497 }
535 498
536 /* We could even check all the other arguments, for sanity. */ 499 /* We could even check all the other arguments, for sanity. */
537 #endif /* NSSDEBUG */ 500 #endif /* NSSDEBUG */
538 501
539 obj = (nssCKMDSessionObject *)mdObject->etc; 502 obj = (nssCKMDSessionObject *)mdObject->etc;
540 503
541 for( i = 0; i < obj->n; i++ ) { 504 for (i = 0; i < obj->n; i++) {
542 if( attribute == obj->types[i] ) { 505 if (attribute == obj->types[i]) {
543 return (CK_ULONG)(obj->attributes[i].size); 506 return (CK_ULONG)(obj->attributes[i].size);
507 }
544 } 508 }
545 }
546 509
547 *pError = CKR_ATTRIBUTE_TYPE_INVALID; 510 *pError = CKR_ATTRIBUTE_TYPE_INVALID;
548 return 0; 511 return 0;
549 } 512 }
550 513
551 /* 514 /*
552 * nss_ckmdSessionObject_GetAttribute 515 * nss_ckmdSessionObject_GetAttribute
553 * 516 *
554 */ 517 */
555 static NSSCKFWItem 518 static NSSCKFWItem
556 nss_ckmdSessionObject_GetAttribute 519 nss_ckmdSessionObject_GetAttribute(
557 ( 520 NSSCKMDObject *mdObject,
558 NSSCKMDObject *mdObject, 521 NSSCKFWObject *fwObject,
559 NSSCKFWObject *fwObject, 522 NSSCKMDSession *mdSession,
560 NSSCKMDSession *mdSession, 523 NSSCKFWSession *fwSession,
561 NSSCKFWSession *fwSession, 524 NSSCKMDToken *mdToken,
562 NSSCKMDToken *mdToken, 525 NSSCKFWToken *fwToken,
563 NSSCKFWToken *fwToken, 526 NSSCKMDInstance *mdInstance,
564 NSSCKMDInstance *mdInstance, 527 NSSCKFWInstance *fwInstance,
565 NSSCKFWInstance *fwInstance, 528 CK_ATTRIBUTE_TYPE attribute,
566 CK_ATTRIBUTE_TYPE attribute, 529 CK_RV *pError)
567 CK_RV *pError
568 )
569 { 530 {
570 NSSCKFWItem item; 531 NSSCKFWItem item;
571 nssCKMDSessionObject *obj; 532 nssCKMDSessionObject *obj;
572 CK_ULONG i; 533 CK_ULONG i;
573 534
574 item.needsFreeing = PR_FALSE; 535 item.needsFreeing = PR_FALSE;
575 item.item = NULL; 536 item.item = NULL;
576 #ifdef NSSDEBUG 537 #ifdef NSSDEBUG
577 if (!pError) { 538 if (!pError) {
578 return item; 539 return item;
579 } 540 }
580 541
581 *pError = nss_ckmdSessionObject_verifyPointer(mdObject); 542 *pError = nss_ckmdSessionObject_verifyPointer(mdObject);
582 if( CKR_OK != *pError ) { 543 if (CKR_OK != *pError) {
583 return item; 544 return item;
584 } 545 }
585 546
586 /* We could even check all the other arguments, for sanity. */ 547 /* We could even check all the other arguments, for sanity. */
587 #endif /* NSSDEBUG */ 548 #endif /* NSSDEBUG */
588 549
589 obj = (nssCKMDSessionObject *)mdObject->etc; 550 obj = (nssCKMDSessionObject *)mdObject->etc;
590 551
591 for( i = 0; i < obj->n; i++ ) { 552 for (i = 0; i < obj->n; i++) {
592 if( attribute == obj->types[i] ) { 553 if (attribute == obj->types[i]) {
593 item.item = &obj->attributes[i]; 554 item.item = &obj->attributes[i];
594 return item; 555 return item;
556 }
595 } 557 }
596 }
597 558
598 *pError = CKR_ATTRIBUTE_TYPE_INVALID; 559 *pError = CKR_ATTRIBUTE_TYPE_INVALID;
599 return item; 560 return item;
600 } 561 }
601 562
602 /* 563 /*
603 * nss_ckmdSessionObject_SetAttribute 564 * nss_ckmdSessionObject_SetAttribute
604 * 565 *
605 */ 566 */
606 567
607 /* 568 /*
608 * Okay, so this implementation sucks. It doesn't support removing 569 * Okay, so this implementation sucks. It doesn't support removing
609 * an attribute (if value == NULL), and could be more graceful about 570 * an attribute (if value == NULL), and could be more graceful about
610 * memory. It should allow "blank" slots in the arrays, with some 571 * memory. It should allow "blank" slots in the arrays, with some
611 * invalid attribute type, and then it could support removal much 572 * invalid attribute type, and then it could support removal much
612 * more easily. Do this later. 573 * more easily. Do this later.
613 */ 574 */
614 static CK_RV 575 static CK_RV
615 nss_ckmdSessionObject_SetAttribute 576 nss_ckmdSessionObject_SetAttribute(
616 ( 577 NSSCKMDObject *mdObject,
617 NSSCKMDObject *mdObject, 578 NSSCKFWObject *fwObject,
618 NSSCKFWObject *fwObject, 579 NSSCKMDSession *mdSession,
619 NSSCKMDSession *mdSession, 580 NSSCKFWSession *fwSession,
620 NSSCKFWSession *fwSession, 581 NSSCKMDToken *mdToken,
621 NSSCKMDToken *mdToken, 582 NSSCKFWToken *fwToken,
622 NSSCKFWToken *fwToken, 583 NSSCKMDInstance *mdInstance,
623 NSSCKMDInstance *mdInstance, 584 NSSCKFWInstance *fwInstance,
624 NSSCKFWInstance *fwInstance, 585 CK_ATTRIBUTE_TYPE attribute,
625 CK_ATTRIBUTE_TYPE attribute, 586 NSSItem *value)
626 NSSItem *value
627 )
628 { 587 {
629 nssCKMDSessionObject *obj; 588 nssCKMDSessionObject *obj;
630 CK_ULONG i; 589 CK_ULONG i;
631 NSSItem n; 590 NSSItem n;
632 NSSItem *ra; 591 NSSItem *ra;
633 CK_ATTRIBUTE_TYPE_PTR rt; 592 CK_ATTRIBUTE_TYPE_PTR rt;
634 #ifdef NSSDEBUG 593 #ifdef NSSDEBUG
635 CK_RV error; 594 CK_RV error;
636 #endif /* NSSDEBUG */ 595 #endif /* NSSDEBUG */
637 596
638 #ifdef NSSDEBUG 597 #ifdef NSSDEBUG
639 error = nss_ckmdSessionObject_verifyPointer(mdObject); 598 error = nss_ckmdSessionObject_verifyPointer(mdObject);
640 if( CKR_OK != error ) { 599 if (CKR_OK != error) {
641 return 0; 600 return 0;
642 } 601 }
643 602
644 /* We could even check all the other arguments, for sanity. */ 603 /* We could even check all the other arguments, for sanity. */
645 #endif /* NSSDEBUG */ 604 #endif /* NSSDEBUG */
646 605
647 obj = (nssCKMDSessionObject *)mdObject->etc; 606 obj = (nssCKMDSessionObject *)mdObject->etc;
648 607
649 n.size = value->size; 608 n.size = value->size;
650 n.data = nss_ZAlloc(obj->arena, n.size); 609 n.data = nss_ZAlloc(obj->arena, n.size);
651 if (!n.data) { 610 if (!n.data) {
652 return CKR_HOST_MEMORY; 611 return CKR_HOST_MEMORY;
653 } 612 }
654 (void)nsslibc_memcpy(n.data, value->data, n.size); 613 (void)nsslibc_memcpy(n.data, value->data, n.size);
655 614
656 for( i = 0; i < obj->n; i++ ) { 615 for (i = 0; i < obj->n; i++) {
657 if( attribute == obj->types[i] ) { 616 if (attribute == obj->types[i]) {
658 nss_ZFreeIf(obj->attributes[i].data); 617 nss_ZFreeIf(obj->attributes[i].data);
659 obj->attributes[i] = n; 618 obj->attributes[i] = n;
660 return CKR_OK; 619 return CKR_OK;
620 }
661 } 621 }
662 }
663 622
664 /* 623 /*
665 * It's new. 624 * It's new.
666 */ 625 */
667 626
668 ra = (NSSItem *)nss_ZRealloc(obj->attributes, sizeof(NSSItem) * (obj->n + 1)); 627 ra = (NSSItem *)nss_ZRealloc(obj->attributes, sizeof(NSSItem) * (obj->n + 1) );
669 if (!ra) { 628 if (!ra) {
670 nss_ZFreeIf(n.data); 629 nss_ZFreeIf(n.data);
671 return CKR_HOST_MEMORY; 630 return CKR_HOST_MEMORY;
672 } 631 }
673 obj->attributes = ra; 632 obj->attributes = ra;
674 633
675 rt = (CK_ATTRIBUTE_TYPE_PTR)nss_ZRealloc(obj->types, 634 rt = (CK_ATTRIBUTE_TYPE_PTR)nss_ZRealloc(obj->types,
676 sizeof(CK_ATTRIBUTE_TYPE) * (obj->n + 1)); 635 sizeof(CK_ATTRIBUTE_TYPE) * (obj->n + 1));
677 if (!rt) { 636 if (!rt) {
678 nss_ZFreeIf(n.data); 637 nss_ZFreeIf(n.data);
679 return CKR_HOST_MEMORY; 638 return CKR_HOST_MEMORY;
680 } 639 }
681 640
682 obj->types = rt; 641 obj->types = rt;
683 obj->attributes[obj->n] = n; 642 obj->attributes[obj->n] = n;
684 obj->types[obj->n] = attribute; 643 obj->types[obj->n] = attribute;
685 obj->n++; 644 obj->n++;
686 645
687 return CKR_OK; 646 return CKR_OK;
688 } 647 }
689 648
690 /* 649 /*
691 * nss_ckmdSessionObject_GetObjectSize 650 * nss_ckmdSessionObject_GetObjectSize
692 * 651 *
693 */ 652 */
694 static CK_ULONG 653 static CK_ULONG
695 nss_ckmdSessionObject_GetObjectSize 654 nss_ckmdSessionObject_GetObjectSize(
696 ( 655 NSSCKMDObject *mdObject,
697 NSSCKMDObject *mdObject, 656 NSSCKFWObject *fwObject,
698 NSSCKFWObject *fwObject, 657 NSSCKMDSession *mdSession,
699 NSSCKMDSession *mdSession, 658 NSSCKFWSession *fwSession,
700 NSSCKFWSession *fwSession, 659 NSSCKMDToken *mdToken,
701 NSSCKMDToken *mdToken, 660 NSSCKFWToken *fwToken,
702 NSSCKFWToken *fwToken, 661 NSSCKMDInstance *mdInstance,
703 NSSCKMDInstance *mdInstance, 662 NSSCKFWInstance *fwInstance,
704 NSSCKFWInstance *fwInstance, 663 CK_RV *pError)
705 CK_RV *pError
706 )
707 { 664 {
708 nssCKMDSessionObject *obj; 665 nssCKMDSessionObject *obj;
709 CK_ULONG i; 666 CK_ULONG i;
710 CK_ULONG rv = (CK_ULONG)0; 667 CK_ULONG rv = (CK_ULONG)0;
711 668
712 #ifdef NSSDEBUG 669 #ifdef NSSDEBUG
713 if (!pError) { 670 if (!pError) {
714 return 0; 671 return 0;
715 } 672 }
716 673
717 *pError = nss_ckmdSessionObject_verifyPointer(mdObject); 674 *pError = nss_ckmdSessionObject_verifyPointer(mdObject);
718 if( CKR_OK != *pError ) { 675 if (CKR_OK != *pError) {
719 return 0; 676 return 0;
720 } 677 }
721 678
722 /* We could even check all the other arguments, for sanity. */ 679 /* We could even check all the other arguments, for sanity. */
723 #endif /* NSSDEBUG */ 680 #endif /* NSSDEBUG */
724 681
725 obj = (nssCKMDSessionObject *)mdObject->etc; 682 obj = (nssCKMDSessionObject *)mdObject->etc;
726 683
727 for( i = 0; i < obj->n; i++ ) { 684 for (i = 0; i < obj->n; i++) {
728 rv += obj->attributes[i].size; 685 rv += obj->attributes[i].size;
729 } 686 }
730 687
731 rv += sizeof(NSSItem) * obj->n; 688 rv += sizeof(NSSItem) * obj->n;
732 rv += sizeof(CK_ATTRIBUTE_TYPE) * obj->n; 689 rv += sizeof(CK_ATTRIBUTE_TYPE) * obj->n;
733 rv += sizeof(nssCKMDSessionObject); 690 rv += sizeof(nssCKMDSessionObject);
734 691
735 return rv; 692 return rv;
736 } 693 }
737 694
738 /* 695 /*
739 * nssCKMDFindSessionObjects 696 * nssCKMDFindSessionObjects
740 * 697 *
741 * -- create -- 698 * -- create --
742 * nssCKMDFindSessionObjects_Create 699 * nssCKMDFindSessionObjects_Create
743 * 700 *
744 * -- EPV calls -- 701 * -- EPV calls --
745 * nss_ckmdFindSessionObjects_Final 702 * nss_ckmdFindSessionObjects_Final
746 * nss_ckmdFindSessionObjects_Next 703 * nss_ckmdFindSessionObjects_Next
747 */ 704 */
748 705
749 struct nodeStr { 706 struct nodeStr {
750 struct nodeStr *next; 707 struct nodeStr *next;
751 NSSCKMDObject *mdObject; 708 NSSCKMDObject *mdObject;
752 }; 709 };
753 710
754 struct nssCKMDFindSessionObjectsStr { 711 struct nssCKMDFindSessionObjectsStr {
755 NSSArena *arena; 712 NSSArena *arena;
756 CK_RV error; 713 CK_RV error;
757 CK_ATTRIBUTE_PTR pTemplate; 714 CK_ATTRIBUTE_PTR pTemplate;
758 CK_ULONG ulCount; 715 CK_ULONG ulCount;
759 struct nodeStr *list; 716 struct nodeStr *list;
760 nssCKFWHash *hash; 717 nssCKFWHash *hash;
761
762 }; 718 };
763 typedef struct nssCKMDFindSessionObjectsStr nssCKMDFindSessionObjects; 719 typedef struct nssCKMDFindSessionObjectsStr nssCKMDFindSessionObjects;
764 720
765 #ifdef DEBUG 721 #ifdef DEBUG
766 /* 722 /*
767 * But first, the pointer-tracking stuff. 723 * But first, the pointer-tracking stuff.
768 * 724 *
769 * NOTE: the pointer-tracking support in NSS/base currently relies 725 * NOTE: the pointer-tracking support in NSS/base currently relies
770 * upon NSPR's CallOnce support. That, however, relies upon NSPR's 726 * upon NSPR's CallOnce support. That, however, relies upon NSPR's
771 * locking, which is tied into the runtime. We need a pointer-tracker 727 * locking, which is tied into the runtime. We need a pointer-tracker
772 * implementation that uses the locks supplied through C_Initialize. 728 * implementation that uses the locks supplied through C_Initialize.
773 * That support, however, can be filled in later. So for now, I'll 729 * That support, however, can be filled in later. So for now, I'll
774 * just do this routines as no-ops. 730 * just do this routines as no-ops.
775 */ 731 */
776 732
777 static CK_RV 733 static CK_RV
778 nss_ckmdFindSessionObjects_add_pointer 734 nss_ckmdFindSessionObjects_add_pointer(
779 ( 735 const NSSCKMDFindObjects *mdFindObjects)
780 const NSSCKMDFindObjects *mdFindObjects
781 )
782 { 736 {
783 return CKR_OK; 737 return CKR_OK;
784 } 738 }
785 739
786 static CK_RV 740 static CK_RV
787 nss_ckmdFindSessionObjects_remove_pointer 741 nss_ckmdFindSessionObjects_remove_pointer(
788 ( 742 const NSSCKMDFindObjects *mdFindObjects)
789 const NSSCKMDFindObjects *mdFindObjects
790 )
791 { 743 {
792 return CKR_OK; 744 return CKR_OK;
793 } 745 }
794 746
795 #ifdef NSS_DEBUG 747 #ifdef NSS_DEBUG
796 static CK_RV 748 static CK_RV
797 nss_ckmdFindSessionObjects_verifyPointer 749 nss_ckmdFindSessionObjects_verifyPointer(
798 ( 750 const NSSCKMDFindObjects *mdFindObjects)
799 const NSSCKMDFindObjects *mdFindObjects
800 )
801 { 751 {
802 return CKR_OK; 752 return CKR_OK;
803 } 753 }
804 #endif 754 #endif
805 755
806 #endif /* DEBUG */ 756 #endif /* DEBUG */
807 757
808 /* 758 /*
809 * We must forward-declare these routines. 759 * We must forward-declare these routines.
810 */ 760 */
811 static void 761 static void
812 nss_ckmdFindSessionObjects_Final 762 nss_ckmdFindSessionObjects_Final(
813 ( 763 NSSCKMDFindObjects *mdFindObjects,
814 NSSCKMDFindObjects *mdFindObjects, 764 NSSCKFWFindObjects *fwFindObjects,
815 NSSCKFWFindObjects *fwFindObjects, 765 NSSCKMDSession *mdSession,
816 NSSCKMDSession *mdSession, 766 NSSCKFWSession *fwSession,
817 NSSCKFWSession *fwSession, 767 NSSCKMDToken *mdToken,
818 NSSCKMDToken *mdToken, 768 NSSCKFWToken *fwToken,
819 NSSCKFWToken *fwToken, 769 NSSCKMDInstance *mdInstance,
820 NSSCKMDInstance *mdInstance, 770 NSSCKFWInstance *fwInstance);
821 NSSCKFWInstance *fwInstance
822 );
823 771
824 static NSSCKMDObject * 772 static NSSCKMDObject *
825 nss_ckmdFindSessionObjects_Next 773 nss_ckmdFindSessionObjects_Next(
826 ( 774 NSSCKMDFindObjects *mdFindObjects,
827 NSSCKMDFindObjects *mdFindObjects, 775 NSSCKFWFindObjects *fwFindObjects,
828 NSSCKFWFindObjects *fwFindObjects, 776 NSSCKMDSession *mdSession,
829 NSSCKMDSession *mdSession, 777 NSSCKFWSession *fwSession,
830 NSSCKFWSession *fwSession, 778 NSSCKMDToken *mdToken,
831 NSSCKMDToken *mdToken, 779 NSSCKFWToken *fwToken,
832 NSSCKFWToken *fwToken, 780 NSSCKMDInstance *mdInstance,
833 NSSCKMDInstance *mdInstance, 781 NSSCKFWInstance *fwInstance,
834 NSSCKFWInstance *fwInstance, 782 NSSArena *arena,
835 NSSArena *arena, 783 CK_RV *pError);
836 CK_RV *pError
837 );
838 784
839 static CK_BBOOL 785 static CK_BBOOL
840 items_match 786 items_match(
841 ( 787 NSSItem *a,
842 NSSItem *a, 788 CK_VOID_PTR pValue,
843 CK_VOID_PTR pValue, 789 CK_ULONG ulValueLen)
844 CK_ULONG ulValueLen
845 )
846 { 790 {
847 if( a->size != ulValueLen ) { 791 if (a->size != ulValueLen) {
848 return CK_FALSE; 792 return CK_FALSE;
849 } 793 }
850 794
851 if( PR_TRUE == nsslibc_memequal(a->data, pValue, ulValueLen, (PRStatus *)NULL) ) { 795 if (PR_TRUE == nsslibc_memequal(a->data, pValue, ulValueLen, (PRStatus *)NUL L)) {
852 return CK_TRUE; 796 return CK_TRUE;
853 } else { 797 } else {
854 return CK_FALSE; 798 return CK_FALSE;
855 } 799 }
856 } 800 }
857 801
858 /* 802 /*
859 * Our hashtable iterator 803 * Our hashtable iterator
860 */ 804 */
861 static void 805 static void
862 findfcn 806 findfcn(
863 ( 807 const void *key,
864 const void *key, 808 void *value,
865 void *value, 809 void *closure)
866 void *closure
867 )
868 { 810 {
869 NSSCKMDObject *mdObject = (NSSCKMDObject *)value; 811 NSSCKMDObject *mdObject = (NSSCKMDObject *)value;
870 nssCKMDSessionObject *mdso = (nssCKMDSessionObject *)mdObject->etc; 812 nssCKMDSessionObject *mdso = (nssCKMDSessionObject *)mdObject->etc;
871 nssCKMDFindSessionObjects *mdfso = (nssCKMDFindSessionObjects *)closure; 813 nssCKMDFindSessionObjects *mdfso = (nssCKMDFindSessionObjects *)closure;
872 CK_ULONG i, j; 814 CK_ULONG i, j;
873 struct nodeStr *node; 815 struct nodeStr *node;
874 816
875 if( CKR_OK != mdfso->error ) { 817 if (CKR_OK != mdfso->error) {
876 return; 818 return;
877 }
878
879 for( i = 0; i < mdfso->ulCount; i++ ) {
880 CK_ATTRIBUTE_PTR p = &mdfso->pTemplate[i];
881
882 for( j = 0; j < mdso->n; j++ ) {
883 if( mdso->types[j] == p->type ) {
884 if( !items_match(&mdso->attributes[j], p->pValue, p->ulValueLen) ) {
885 return;
886 } else {
887 break;
888 }
889 }
890 } 819 }
891 820
892 if( j == mdso->n ) { 821 for (i = 0; i < mdfso->ulCount; i++) {
893 /* Attribute not found */ 822 CK_ATTRIBUTE_PTR p = &mdfso->pTemplate[i];
894 return; 823
824 for (j = 0; j < mdso->n; j++) {
825 if (mdso->types[j] == p->type) {
826 if (!items_match(&mdso->attributes[j], p->pValue, p->ulValueLen) ) {
827 return;
828 } else {
829 break;
830 }
831 }
832 }
833
834 if (j == mdso->n) {
835 /* Attribute not found */
836 return;
837 }
895 } 838 }
896 }
897 839
898 /* Matches */ 840 /* Matches */
899 node = nss_ZNEW(mdfso->arena, struct nodeStr); 841 node = nss_ZNEW(mdfso->arena, struct nodeStr);
900 if( (struct nodeStr *)NULL == node ) { 842 if ((struct nodeStr *)NULL == node) {
901 mdfso->error = CKR_HOST_MEMORY; 843 mdfso->error = CKR_HOST_MEMORY;
844 return;
845 }
846
847 node->mdObject = mdObject;
848 node->next = mdfso->list;
849 mdfso->list = node;
850
902 return; 851 return;
903 }
904
905 node->mdObject = mdObject;
906 node->next = mdfso->list;
907 mdfso->list = node;
908
909 return;
910 } 852 }
911 853
912 /* 854 /*
913 * nssCKMDFindSessionObjects_Create 855 * nssCKMDFindSessionObjects_Create
914 * 856 *
915 */ 857 */
916 NSS_IMPLEMENT NSSCKMDFindObjects * 858 NSS_IMPLEMENT NSSCKMDFindObjects *
917 nssCKMDFindSessionObjects_Create 859 nssCKMDFindSessionObjects_Create(
918 ( 860 NSSCKFWToken *fwToken,
919 NSSCKFWToken *fwToken, 861 CK_ATTRIBUTE_PTR pTemplate,
920 CK_ATTRIBUTE_PTR pTemplate, 862 CK_ULONG ulCount,
921 CK_ULONG ulCount, 863 CK_RV *pError)
922 CK_RV *pError
923 )
924 { 864 {
925 NSSArena *arena; 865 NSSArena *arena;
926 nssCKMDFindSessionObjects *mdfso; 866 nssCKMDFindSessionObjects *mdfso;
927 nssCKFWHash *hash; 867 nssCKFWHash *hash;
928 NSSCKMDFindObjects *rv; 868 NSSCKMDFindObjects *rv;
929 869
930 #ifdef NSSDEBUG 870 #ifdef NSSDEBUG
931 if (!pError) { 871 if (!pError) {
932 return (NSSCKMDFindObjects *)NULL; 872 return (NSSCKMDFindObjects *)NULL;
933 } 873 }
934 874
935 *pError = nssCKFWToken_verifyPointer(fwToken); 875 *pError = nssCKFWToken_verifyPointer(fwToken);
936 if( CKR_OK != *pError ) { 876 if (CKR_OK != *pError) {
937 return (NSSCKMDFindObjects *)NULL; 877 return (NSSCKMDFindObjects *)NULL;
938 } 878 }
939 879
940 if( (CK_ATTRIBUTE_PTR)NULL == pTemplate ) { 880 if ((CK_ATTRIBUTE_PTR)NULL == pTemplate) {
941 *pError = CKR_ARGUMENTS_BAD; 881 *pError = CKR_ARGUMENTS_BAD;
942 return (NSSCKMDFindObjects *)NULL; 882 return (NSSCKMDFindObjects *)NULL;
943 } 883 }
944 #endif /* NSSDEBUG */ 884 #endif /* NSSDEBUG */
945 885
946 *pError = CKR_OK; 886 *pError = CKR_OK;
947 887
948 hash = nssCKFWToken_GetSessionObjectHash(fwToken); 888 hash = nssCKFWToken_GetSessionObjectHash(fwToken);
949 if (!hash) { 889 if (!hash) {
950 *pError= CKR_GENERAL_ERROR; 890 *pError = CKR_GENERAL_ERROR;
951 return (NSSCKMDFindObjects *)NULL; 891 return (NSSCKMDFindObjects *)NULL;
952 } 892 }
953 893
954 arena = NSSArena_Create(); 894 arena = NSSArena_Create();
955 if (!arena) { 895 if (!arena) {
956 *pError = CKR_HOST_MEMORY; 896 *pError = CKR_HOST_MEMORY;
957 return (NSSCKMDFindObjects *)NULL; 897 return (NSSCKMDFindObjects *)NULL;
958 } 898 }
959 899
960 mdfso = nss_ZNEW(arena, nssCKMDFindSessionObjects); 900 mdfso = nss_ZNEW(arena, nssCKMDFindSessionObjects);
961 if (!mdfso) { 901 if (!mdfso) {
962 goto loser; 902 goto loser;
963 } 903 }
964 904
965 rv = nss_ZNEW(arena, NSSCKMDFindObjects); 905 rv = nss_ZNEW(arena, NSSCKMDFindObjects);
966 if(rv == NULL) { 906 if (rv == NULL) {
967 goto loser; 907 goto loser;
968 } 908 }
969 909
970 mdfso->error = CKR_OK; 910 mdfso->error = CKR_OK;
971 mdfso->pTemplate = pTemplate; 911 mdfso->pTemplate = pTemplate;
972 mdfso->ulCount = ulCount; 912 mdfso->ulCount = ulCount;
973 mdfso->hash = hash; 913 mdfso->hash = hash;
974 914
975 nssCKFWHash_Iterate(hash, findfcn, mdfso); 915 nssCKFWHash_Iterate(hash, findfcn, mdfso);
976 916
977 if( CKR_OK != mdfso->error ) { 917 if (CKR_OK != mdfso->error) {
978 goto loser; 918 goto loser;
979 } 919 }
980 920
981 rv->etc = (void *)mdfso; 921 rv->etc = (void *)mdfso;
982 rv->Final = nss_ckmdFindSessionObjects_Final; 922 rv->Final = nss_ckmdFindSessionObjects_Final;
983 rv->Next = nss_ckmdFindSessionObjects_Next; 923 rv->Next = nss_ckmdFindSessionObjects_Next;
984 924
985 #ifdef DEBUG 925 #ifdef DEBUG
986 if( (*pError = nss_ckmdFindSessionObjects_add_pointer(rv)) != CKR_OK ) { 926 if ((*pError = nss_ckmdFindSessionObjects_add_pointer(rv)) != CKR_OK) {
987 goto loser; 927 goto loser;
988 } 928 }
989 #endif /* DEBUG */ 929 #endif /* DEBUG */
990 mdfso->arena = arena; 930 mdfso->arena = arena;
991 931
992 return rv; 932 return rv;
993 933
994 loser: 934 loser:
995 if (arena) { 935 if (arena) {
996 NSSArena_Destroy(arena); 936 NSSArena_Destroy(arena);
997 } 937 }
998 if (*pError == CKR_OK) { 938 if (*pError == CKR_OK) {
999 *pError = CKR_HOST_MEMORY; 939 *pError = CKR_HOST_MEMORY;
1000 } 940 }
1001 return NULL; 941 return NULL;
1002 } 942 }
1003 943
1004 static void 944 static void
1005 nss_ckmdFindSessionObjects_Final 945 nss_ckmdFindSessionObjects_Final(
1006 ( 946 NSSCKMDFindObjects *mdFindObjects,
1007 NSSCKMDFindObjects *mdFindObjects, 947 NSSCKFWFindObjects *fwFindObjects,
1008 NSSCKFWFindObjects *fwFindObjects, 948 NSSCKMDSession *mdSession,
1009 NSSCKMDSession *mdSession, 949 NSSCKFWSession *fwSession,
1010 NSSCKFWSession *fwSession, 950 NSSCKMDToken *mdToken,
1011 NSSCKMDToken *mdToken, 951 NSSCKFWToken *fwToken,
1012 NSSCKFWToken *fwToken, 952 NSSCKMDInstance *mdInstance,
1013 NSSCKMDInstance *mdInstance, 953 NSSCKFWInstance *fwInstance)
1014 NSSCKFWInstance *fwInstance
1015 )
1016 { 954 {
1017 nssCKMDFindSessionObjects *mdfso; 955 nssCKMDFindSessionObjects *mdfso;
1018 956
1019 #ifdef NSSDEBUG 957 #ifdef NSSDEBUG
1020 if( CKR_OK != nss_ckmdFindSessionObjects_verifyPointer(mdFindObjects) ) { 958 if (CKR_OK != nss_ckmdFindSessionObjects_verifyPointer(mdFindObjects)) {
1021 return; 959 return;
1022 } 960 }
1023 #endif /* NSSDEBUG */ 961 #endif /* NSSDEBUG */
1024 962
1025 mdfso = (nssCKMDFindSessionObjects *)mdFindObjects->etc; 963 mdfso = (nssCKMDFindSessionObjects *)mdFindObjects->etc;
1026 if (mdfso->arena) NSSArena_Destroy(mdfso->arena); 964 if (mdfso->arena)
965 NSSArena_Destroy(mdfso->arena);
1027 966
1028 #ifdef DEBUG 967 #ifdef DEBUG
1029 (void)nss_ckmdFindSessionObjects_remove_pointer(mdFindObjects); 968 (void)nss_ckmdFindSessionObjects_remove_pointer(mdFindObjects);
1030 #endif /* DEBUG */ 969 #endif /* DEBUG */
1031 970
1032 return; 971 return;
1033 } 972 }
1034 973
1035 static NSSCKMDObject * 974 static NSSCKMDObject *
1036 nss_ckmdFindSessionObjects_Next 975 nss_ckmdFindSessionObjects_Next(
1037 ( 976 NSSCKMDFindObjects *mdFindObjects,
1038 NSSCKMDFindObjects *mdFindObjects, 977 NSSCKFWFindObjects *fwFindObjects,
1039 NSSCKFWFindObjects *fwFindObjects, 978 NSSCKMDSession *mdSession,
1040 NSSCKMDSession *mdSession, 979 NSSCKFWSession *fwSession,
1041 NSSCKFWSession *fwSession, 980 NSSCKMDToken *mdToken,
1042 NSSCKMDToken *mdToken, 981 NSSCKFWToken *fwToken,
1043 NSSCKFWToken *fwToken, 982 NSSCKMDInstance *mdInstance,
1044 NSSCKMDInstance *mdInstance, 983 NSSCKFWInstance *fwInstance,
1045 NSSCKFWInstance *fwInstance, 984 NSSArena *arena,
1046 NSSArena *arena, 985 CK_RV *pError)
1047 CK_RV *pError
1048 )
1049 { 986 {
1050 nssCKMDFindSessionObjects *mdfso; 987 nssCKMDFindSessionObjects *mdfso;
1051 NSSCKMDObject *rv = (NSSCKMDObject *)NULL; 988 NSSCKMDObject *rv = (NSSCKMDObject *)NULL;
1052 989
1053 #ifdef NSSDEBUG 990 #ifdef NSSDEBUG
1054 if( CKR_OK != nss_ckmdFindSessionObjects_verifyPointer(mdFindObjects) ) { 991 if (CKR_OK != nss_ckmdFindSessionObjects_verifyPointer(mdFindObjects)) {
1055 return (NSSCKMDObject *)NULL; 992 return (NSSCKMDObject *)NULL;
1056 } 993 }
1057 #endif /* NSSDEBUG */ 994 #endif /* NSSDEBUG */
1058 995
1059 mdfso = (nssCKMDFindSessionObjects *)mdFindObjects->etc; 996 mdfso = (nssCKMDFindSessionObjects *)mdFindObjects->etc;
1060 997
1061 while (!rv) { 998 while (!rv) {
1062 if( (struct nodeStr *)NULL == mdfso->list ) { 999 if ((struct nodeStr *)NULL == mdfso->list) {
1063 *pError = CKR_OK; 1000 *pError = CKR_OK;
1064 return (NSSCKMDObject *)NULL; 1001 return (NSSCKMDObject *)NULL;
1002 }
1003
1004 if (nssCKFWHash_Exists(mdfso->hash, mdfso->list->mdObject)) {
1005 rv = mdfso->list->mdObject;
1006 }
1007
1008 mdfso->list = mdfso->list->next;
1065 } 1009 }
1066 1010
1067 if( nssCKFWHash_Exists(mdfso->hash, mdfso->list->mdObject) ) { 1011 return rv;
1068 rv = mdfso->list->mdObject;
1069 }
1070
1071 mdfso->list = mdfso->list->next;
1072 }
1073
1074 return rv;
1075 } 1012 }
OLDNEW
« no previous file with comments | « nss/lib/ckfw/session.c ('k') | nss/lib/ckfw/slot.c » ('j') | nss/lib/util/secoid.c » ('J')

Powered by Google App Engine
This is Rietveld 408576698