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 /* | 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 } |
OLD | NEW |