1 /*
2  * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved.
3  */
4 
5 /* Copyright  (c) 2002 Graz University of Technology. All rights reserved.
6  *
7  * Redistribution and use in  source and binary forms, with or without
8  * modification, are permitted  provided that the following conditions are met:
9  *
10  * 1. Redistributions of  source code must retain the above copyright notice,
11  *    this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in  binary form must reproduce the above copyright notice,
14  *    this list of conditions and the following disclaimer in the documentation
15  *    and/or other materials provided with the distribution.
16  *
17  * 3. The end-user documentation included with the redistribution, if any, must
18  *    include the following acknowledgment:
19  *
20  *    "This product includes software developed by IAIK of Graz University of
21  *     Technology."
22  *
23  *    Alternately, this acknowledgment may appear in the software itself, if
24  *    and wherever such third-party acknowledgments normally appear.
25  *
26  * 4. The names "Graz University of Technology" and "IAIK of Graz University of
27  *    Technology" must not be used to endorse or promote products derived from
28  *    this software without prior written permission.
29  *
30  * 5. Products derived from this software may not be called
31  *    "IAIK PKCS Wrapper", nor may "IAIK" appear in their name, without prior
32  *    written permission of Graz University of Technology.
33  *
34  *  THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED
35  *  WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
36  *  WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
37  *  PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE LICENSOR BE
38  *  LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
39  *  OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
40  *  PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA,
41  *  OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
42  *  ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
43  *  OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
44  *  OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
45  *  POSSIBILITY  OF SUCH DAMAGE.
46  */
47 
48 package sun.security.pkcs11.wrapper;
49 
50 import java.math.BigInteger;
51 
52 import java.util.*;
53 
54 import static sun.security.pkcs11.wrapper.PKCS11Constants.*;
55 
56 /**
57  * This class contains only static methods. It is the place for all functions
58  * that are used by several classes in this package.
59  *
60  * @author Karl Scheibelhofer <Karl.Scheibelhofer@iaik.at>
61  * @author Martin Schlaeffer <schlaeff@sbox.tugraz.at>
62  */
63 public class Functions {
64 
65     // maps between ids and their names, forward and reverse
66     // ids are stored as Integers to save space
67     // since only the lower 32 bits are ever used anyway
68 
69     // mechanisms (CKM_*)
70     private static final Map<Integer,String> mechNames =
71         new HashMap<Integer,String>();
72 
73     private static final Map<String,Integer> mechIds =
74         new HashMap<String,Integer>();
75 
76     private static final Map<String, Long> hashMechIds =
77             new HashMap<String, Long>();
78 
79     // key types (CKK_*)
80     private static final Map<Integer,String> keyNames =
81         new HashMap<Integer,String>();
82 
83     private static final Map<String,Integer> keyIds =
84         new HashMap<String,Integer>();
85 
86     // attributes (CKA_*)
87     private static final Map<Integer,String> attributeNames =
88         new HashMap<Integer,String>();
89 
90     private static final Map<String,Integer> attributeIds =
91         new HashMap<String,Integer>();
92 
93     // object classes (CKO_*)
94     private static final Map<Integer,String> objectClassNames =
95         new HashMap<Integer,String>();
96 
97     private static final Map<String,Integer> objectClassIds =
98         new HashMap<String,Integer>();
99 
100     // MGFs (CKG_*)
101     private static final Map<Integer,String> mgfNames =
102         new HashMap<Integer,String>();
103 
104     private static final Map<String,Integer> mgfIds =
105         new HashMap<String,Integer>();
106 
107     /**
108      * For converting numbers to their hex presentation.
109      */
110     private static final char[] HEX_DIGITS = "0123456789ABCDEF".toCharArray();
111 
112     /**
113      * Converts a long value to a hexadecimal String of length 16. Includes
114      * leading zeros if necessary.
115      *
116      * @param value The long value to be converted.
117      * @return The hexadecimal string representation of the long value.
118      */
toFullHexString(long value)119     public static String toFullHexString(long value) {
120         long currentValue = value;
121         StringBuilder sb = new StringBuilder(16);
122         for(int j = 0; j < 16; j++) {
123             int currentDigit = (int) currentValue & 0xf;
124             sb.append(HEX_DIGITS[currentDigit]);
125             currentValue >>>= 4;
126         }
127 
128         return sb.reverse().toString();
129     }
130 
131     /**
132      * Converts a int value to a hexadecimal String of length 8. Includes
133      * leading zeros if necessary.
134      *
135      * @param value The int value to be converted.
136      * @return The hexadecimal string representation of the int value.
137      */
toFullHexString(int value)138     public static String toFullHexString(int value) {
139         int currentValue = value;
140         StringBuilder sb = new StringBuilder(8);
141         for(int i = 0; i < 8; i++) {
142             int currentDigit = currentValue & 0xf;
143             sb.append(HEX_DIGITS[currentDigit]);
144             currentValue >>>= 4;
145         }
146 
147         return sb.reverse().toString();
148     }
149 
150     /**
151      * converts a long value to a hexadecimal String
152      *
153      * @param value the long value to be converted
154      * @return the hexadecimal string representation of the long value
155      */
toHexString(long value)156     public static String toHexString(long value) {
157         return Long.toHexString(value);
158     }
159 
160     /**
161      * Converts a byte array to a hexadecimal String. Each byte is presented by
162      * its two digit hex-code; 0x0A -> "0a", 0x00 -> "00". No leading "0x" is
163      * included in the result.
164      *
165      * @param value the byte array to be converted
166      * @return the hexadecimal string representation of the byte array
167      */
toHexString(byte[] value)168     public static String toHexString(byte[] value) {
169         if (value == null) {
170             return null;
171         }
172 
173         StringBuilder sb = new StringBuilder(2 * value.length);
174         int          single;
175 
176         for (int i = 0; i < value.length; i++) {
177             single = value[i] & 0xFF;
178 
179             if (single < 0x10) {
180                 sb.append('0');
181             }
182 
183             sb.append(Integer.toString(single, 16));
184         }
185 
186         return sb.toString();
187     }
188 
189     /**
190      * converts a long value to a binary String
191      *
192      * @param value the long value to be converted
193      * @return the binary string representation of the long value
194      */
toBinaryString(long value)195     public static String toBinaryString(long value) {
196         return Long.toString(value, 2);
197     }
198 
199     /**
200      * converts a byte array to a binary String
201      *
202      * @param value the byte array to be converted
203      * @return the binary string representation of the byte array
204      */
toBinaryString(byte[] value)205     public static String toBinaryString(byte[] value) {
206         BigInteger helpBigInteger = new BigInteger(1, value);
207 
208         return helpBigInteger.toString(2);
209     }
210 
211     private static class Flags {
212         private final long[] flagIds;
213         private final String[] flagNames;
Flags(long[] flagIds, String[] flagNames)214         Flags(long[] flagIds, String[] flagNames) {
215             if (flagIds.length != flagNames.length) {
216                 throw new AssertionError("Array lengths do not match");
217             }
218             this.flagIds = flagIds;
219             this.flagNames = flagNames;
220         }
toString(long val)221         String toString(long val) {
222             StringBuilder sb = new StringBuilder();
223             boolean first = true;
224             for (int i = 0; i < flagIds.length; i++) {
225                 if ((val & flagIds[i]) != 0) {
226                     if (first == false) {
227                         sb.append(" | ");
228                     }
229                     sb.append(flagNames[i]);
230                     first = false;
231                 }
232             }
233             return sb.toString();
234         }
235     }
236 
237     private static final Flags slotInfoFlags = new Flags(new long[] {
238         CKF_TOKEN_PRESENT,
239         CKF_REMOVABLE_DEVICE,
240         CKF_HW_SLOT,
241     }, new String[] {
242         "CKF_TOKEN_PRESENT",
243         "CKF_REMOVABLE_DEVICE",
244         "CKF_HW_SLOT",
245     });
246 
247     /**
248      * converts the long value flags to a SlotInfoFlag string
249      *
250      * @param flags the flags to be converted
251      * @return the SlotInfoFlag string representation of the flags
252      */
slotInfoFlagsToString(long flags)253     public static String slotInfoFlagsToString(long flags) {
254         return slotInfoFlags.toString(flags);
255     }
256 
257     private static final Flags tokenInfoFlags = new Flags(new long[] {
258         CKF_RNG,
259         CKF_WRITE_PROTECTED,
260         CKF_LOGIN_REQUIRED,
261         CKF_USER_PIN_INITIALIZED,
262         CKF_RESTORE_KEY_NOT_NEEDED,
263         CKF_CLOCK_ON_TOKEN,
264         CKF_PROTECTED_AUTHENTICATION_PATH,
265         CKF_DUAL_CRYPTO_OPERATIONS,
266         CKF_TOKEN_INITIALIZED,
267         CKF_SECONDARY_AUTHENTICATION,
268         CKF_USER_PIN_COUNT_LOW,
269         CKF_USER_PIN_FINAL_TRY,
270         CKF_USER_PIN_LOCKED,
271         CKF_USER_PIN_TO_BE_CHANGED,
272         CKF_SO_PIN_COUNT_LOW,
273         CKF_SO_PIN_FINAL_TRY,
274         CKF_SO_PIN_LOCKED,
275         CKF_SO_PIN_TO_BE_CHANGED,
276     }, new String[] {
277         "CKF_RNG",
278         "CKF_WRITE_PROTECTED",
279         "CKF_LOGIN_REQUIRED",
280         "CKF_USER_PIN_INITIALIZED",
281         "CKF_RESTORE_KEY_NOT_NEEDED",
282         "CKF_CLOCK_ON_TOKEN",
283         "CKF_PROTECTED_AUTHENTICATION_PATH",
284         "CKF_DUAL_CRYPTO_OPERATIONS",
285         "CKF_TOKEN_INITIALIZED",
286         "CKF_SECONDARY_AUTHENTICATION",
287         "CKF_USER_PIN_COUNT_LOW",
288         "CKF_USER_PIN_FINAL_TRY",
289         "CKF_USER_PIN_LOCKED",
290         "CKF_USER_PIN_TO_BE_CHANGED",
291         "CKF_SO_PIN_COUNT_LOW",
292         "CKF_SO_PIN_FINAL_TRY",
293         "CKF_SO_PIN_LOCKED",
294         "CKF_SO_PIN_TO_BE_CHANGED",
295     });
296 
297     /**
298      * converts long value flags to a TokenInfoFlag string
299      *
300      * @param flags the flags to be converted
301      * @return the TokenInfoFlag string representation of the flags
302      */
tokenInfoFlagsToString(long flags)303     public static String tokenInfoFlagsToString(long flags) {
304         return tokenInfoFlags.toString(flags);
305     }
306 
307     private static final Flags sessionInfoFlags = new Flags(new long[] {
308         CKF_RW_SESSION,
309         CKF_SERIAL_SESSION,
310     }, new String[] {
311         "CKF_RW_SESSION",
312         "CKF_SERIAL_SESSION",
313     });
314 
315     /**
316      * converts the long value flags to a SessionInfoFlag string
317      *
318      * @param flags the flags to be converted
319      * @return the SessionInfoFlag string representation of the flags
320      */
sessionInfoFlagsToString(long flags)321     public static String sessionInfoFlagsToString(long flags) {
322         return sessionInfoFlags.toString(flags);
323     }
324 
325     /**
326      * converts the long value state to a SessionState string
327      *
328      * @param state the state to be converted
329      * @return the SessionState string representation of the state
330      */
sessionStateToString(long state)331     public static String sessionStateToString(long state) {
332         String name;
333 
334         if (state == CKS_RO_PUBLIC_SESSION) {
335             name = "CKS_RO_PUBLIC_SESSION";
336         } else if (state == CKS_RO_USER_FUNCTIONS) {
337             name = "CKS_RO_USER_FUNCTIONS";
338         } else if (state == CKS_RW_PUBLIC_SESSION) {
339             name = "CKS_RW_PUBLIC_SESSION";
340         } else if (state == CKS_RW_USER_FUNCTIONS) {
341             name = "CKS_RW_USER_FUNCTIONS";
342         } else if (state == CKS_RW_SO_FUNCTIONS) {
343             name = "CKS_RW_SO_FUNCTIONS";
344         } else {
345             name = "ERROR: unknown session state 0x" + toFullHexString(state);
346         }
347 
348         return name;
349     }
350 
351     private static final Flags mechanismInfoFlags = new Flags(new long[] {
352         CKF_HW,
353         CKF_MESSAGE_ENCRYPT,
354         CKF_MESSAGE_DECRYPT,
355         CKF_MESSAGE_SIGN,
356         CKF_MESSAGE_VERIFY,
357         CKF_MULTI_MESSAGE,
358         CKF_FIND_OBJECTS,
359         CKF_ENCRYPT,
360         CKF_DECRYPT,
361         CKF_DIGEST,
362         CKF_SIGN,
363         CKF_SIGN_RECOVER,
364         CKF_VERIFY,
365         CKF_VERIFY_RECOVER,
366         CKF_GENERATE,
367         CKF_GENERATE_KEY_PAIR,
368         CKF_WRAP,
369         CKF_UNWRAP,
370         CKF_DERIVE,
371         CKF_EC_F_P,
372         CKF_EC_F_2M,
373         CKF_EC_ECPARAMETERS,
374         CKF_EC_OID,
375         CKF_EC_UNCOMPRESS,
376         CKF_EC_COMPRESS,
377         CKF_EC_CURVENAME,
378         CKF_EXTENSION,
379     }, new String[] {
380         "CKF_HW",
381         "CKF_MESSAGE_ENCRYPT",
382         "CKF_MESSAGE_DECRYPT",
383         "CKF_MESSAGE_SIGN",
384         "CKF_MESSAGE_VERIFY",
385         "CKF_MULTI_MESSAGE",
386         "CKF_FIND_OBJECTS",
387         "CKF_ENCRYPT",
388         "CKF_DECRYPT",
389         "CKF_DIGEST",
390         "CKF_SIGN",
391         "CKF_SIGN_RECOVER",
392         "CKF_VERIFY",
393         "CKF_VERIFY_RECOVER",
394         "CKF_GENERATE",
395         "CKF_GENERATE_KEY_PAIR",
396         "CKF_WRAP",
397         "CKF_UNWRAP",
398         "CKF_DERIVE",
399         "CKF_EC_F_P",
400         "CKF_EC_F_2M",
401         "CKF_EC_ECPARAMETERS",
402         "CKF_EC_OID",
403         "CKF_EC_UNCOMPRESS",
404         "CKF_EC_COMPRESS",
405         "CKF_EC_CURVENAME",
406         "CKF_EXTENSION",
407     });
408 
409     /**
410      * converts the long value flags to a MechanismInfoFlag string
411      *
412      * @param flags the flags to be converted
413      * @return the MechanismInfoFlag string representation of the flags
414      */
mechanismInfoFlagsToString(long flags)415     public static String mechanismInfoFlagsToString(long flags) {
416         return mechanismInfoFlags.toString(flags);
417     }
418 
getName(Map<Integer,String> nameMap, long id)419     private static String getName(Map<Integer,String> nameMap, long id) {
420         String name = null;
421         if ((id >>> 32) == 0) {
422             name = nameMap.get(Integer.valueOf((int)id));
423         }
424         if (name == null) {
425             if ((id & CKM_VENDOR_DEFINED) != 0) {
426                 name = "(Vendor-Specific) 0x" + toFullHexString(id);
427             } else {
428                 name = "(Unknown) 0x" + toFullHexString(id);
429             }
430         }
431         return name;
432     }
433 
getId(Map<String,Integer> idMap, String name)434     public static long getId(Map<String,Integer> idMap, String name) {
435         Integer mech = idMap.get(name);
436         if (mech == null) {
437             throw new IllegalArgumentException("Unknown name " + name);
438         }
439         return mech.intValue() & 0xffffffffL;
440     }
441 
getMechanismName(long id)442     public static String getMechanismName(long id) {
443         return getName(mechNames, id);
444     }
445 
getMechanismId(String name)446     public static long getMechanismId(String name) {
447         return getId(mechIds, name);
448     }
449 
getKeyName(long id)450     public static String getKeyName(long id) {
451         return getName(keyNames, id);
452     }
453 
getKeyId(String name)454     public static long getKeyId(String name) {
455         return getId(keyIds, name);
456     }
457 
getAttributeName(long id)458     public static String getAttributeName(long id) {
459         return getName(attributeNames, id);
460     }
461 
getAttributeId(String name)462     public static long getAttributeId(String name) {
463         return getId(attributeIds, name);
464     }
465 
getObjectClassName(long id)466     public static String getObjectClassName(long id) {
467         return getName(objectClassNames, id);
468     }
469 
getObjectClassId(String name)470     public static long getObjectClassId(String name) {
471         return getId(objectClassIds, name);
472     }
473 
getHashMechId(String name)474     public static long getHashMechId(String name) {
475         return hashMechIds.get(name);
476     }
477 
getMGFName(long id)478     public static String getMGFName(long id) {
479         return getName(mgfNames, id);
480     }
481 
getMGFId(String name)482     public static long getMGFId(String name) {
483         return getId(mgfIds, name);
484     }
485 
486     /**
487      * Check the given arrays for equalitiy. This method considers both arrays as
488      * equal, if both are <code>null</code> or both have the same length and
489      * contain exactly the same char values.
490      *
491      * @param array1 The first array.
492      * @param array2 The second array.
493      * @return True, if both arrays are <code>null</code> or both have the same
494      *         length and contain exactly the same char values. False, otherwise.
495      * @preconditions
496      * @postconditions
497      */
equals(char[] array1, char[] array2)498     private static boolean equals(char[] array1, char[] array2) {
499         return Arrays.equals(array1, array2);
500     }
501 
502     /**
503      * Check the given dates for equalitiy. This method considers both dates as
504      * equal, if both are <code>null</code> or both contain exactly the same char
505      * values.
506      *
507      * @param date1 The first date.
508      * @param date2 The second date.
509      * @return True, if both dates are <code>null</code> or both contain the same
510      *         char values. False, otherwise.
511      * @preconditions
512      * @postconditions
513      */
equals(CK_DATE date1, CK_DATE date2)514     public static boolean equals(CK_DATE date1, CK_DATE date2) {
515         boolean equal = false;
516 
517         if (date1 == date2) {
518             equal = true;
519         } else if ((date1 != null) && (date2 != null)) {
520             equal = equals(date1.year, date2.year)
521               && equals(date1.month, date2.month)
522               && equals(date1.day, date2.day);
523         } else {
524             equal = false;
525         }
526 
527         return equal ;
528     }
529 
530     /**
531      * Calculate a hash code for the given byte array.
532      *
533      * @param array The byte array.
534      * @return A hash code for the given array.
535      * @preconditions
536      * @postconditions
537      */
hashCode(byte[] array)538     public static int hashCode(byte[] array) {
539         int hash = 0;
540 
541         if (array != null) {
542             for (int i = 0; (i < 4) && (i < array.length); i++) {
543                 hash ^= (0xFF & array[i]) << ((i%4) << 3);
544             }
545         }
546 
547         return hash ;
548     }
549 
550     /**
551      * Calculate a hash code for the given char array.
552      *
553      * @param array The char array.
554      * @return A hash code for the given array.
555      * @preconditions
556      * @postconditions
557      */
hashCode(char[] array)558     public static int hashCode(char[] array) {
559         int hash = 0;
560 
561         if (array != null) {
562             for (int i = 0; (i < 4) && (i < array.length); i++) {
563                 hash ^= (0xFFFF & array[i]) << ((i%2) << 4);
564             }
565         }
566 
567         return hash ;
568     }
569 
570     /**
571      * Calculate a hash code for the given date object.
572      *
573      * @param date The date object.
574      * @return A hash code for the given date.
575      * @preconditions
576      * @postconditions
577      */
hashCode(CK_DATE date)578     public static int hashCode(CK_DATE date) {
579         int hash = 0;
580 
581         if (date != null) {
582             if (date.year.length == 4) {
583                 hash ^= (0xFFFF & date.year[0]) << 16;
584                 hash ^= 0xFFFF & date.year[1];
585                 hash ^= (0xFFFF & date.year[2]) << 16;
586                 hash ^= 0xFFFF & date.year[3];
587             }
588             if (date.month.length == 2) {
589                 hash ^= (0xFFFF & date.month[0]) << 16;
590                 hash ^= 0xFFFF & date.month[1];
591             }
592             if (date.day.length == 2) {
593                 hash ^= (0xFFFF & date.day[0]) << 16;
594                 hash ^= 0xFFFF & date.day[1];
595             }
596         }
597 
598         return hash ;
599     }
600 
addMapping(Map<Integer,String> nameMap, Map<String,Integer> idMap, long id, String name)601     private static void addMapping(Map<Integer,String> nameMap,
602             Map<String,Integer> idMap, long id, String name) {
603         if ((id >>> 32) != 0) {
604             throw new AssertionError("Id has high bits set: " + id + ", " + name);
605         }
606         Integer intId = Integer.valueOf((int)id);
607         if (nameMap.put(intId, name) != null) {
608             throw new AssertionError("Duplicate id: " + id + ", " + name);
609         }
610         if (idMap.put(name, intId) != null) {
611             throw new AssertionError("Duplicate name: " + id + ", " + name);
612         }
613     }
614 
addMech(long id, String name)615     private static void addMech(long id, String name) {
616         addMapping(mechNames, mechIds, id, name);
617     }
618 
addKeyType(long id, String name)619     private static void addKeyType(long id, String name) {
620         addMapping(keyNames, keyIds, id, name);
621     }
622 
addAttribute(long id, String name)623     private static void addAttribute(long id, String name) {
624         addMapping(attributeNames, attributeIds, id, name);
625     }
626 
addObjectClass(long id, String name)627     private static void addObjectClass(long id, String name) {
628         addMapping(objectClassNames, objectClassIds, id, name);
629     }
630 
addHashMech(long id, String... names)631     private static void addHashMech(long id, String... names) {
632         for (String n : names) {
633             hashMechIds.put(n, id);
634         }
635     }
636 
addMGF(long id, String name)637     private static void addMGF(long id, String name) {
638         addMapping(mgfNames, mgfIds, id, name);
639     }
640 
641     // The ordering here follows the PKCS11Constants class
642     static {
addMech(CKM_RSA_PKCS_KEY_PAIR_GEN, R)643         addMech(CKM_RSA_PKCS_KEY_PAIR_GEN,      "CKM_RSA_PKCS_KEY_PAIR_GEN");
addMech(CKM_RSA_PKCS, R)644         addMech(CKM_RSA_PKCS,                   "CKM_RSA_PKCS");
addMech(CKM_RSA_9796, R)645         addMech(CKM_RSA_9796,                   "CKM_RSA_9796");
addMech(CKM_RSA_X_509, R)646         addMech(CKM_RSA_X_509,                  "CKM_RSA_X_509");
addMech(CKM_MD2_RSA_PKCS, R)647         addMech(CKM_MD2_RSA_PKCS,               "CKM_MD2_RSA_PKCS");
addMech(CKM_MD5_RSA_PKCS, R)648         addMech(CKM_MD5_RSA_PKCS,               "CKM_MD5_RSA_PKCS");
addMech(CKM_SHA1_RSA_PKCS, R)649         addMech(CKM_SHA1_RSA_PKCS,              "CKM_SHA1_RSA_PKCS");
addMech(CKM_RIPEMD128_RSA_PKCS, R)650         addMech(CKM_RIPEMD128_RSA_PKCS,         "CKM_RIPEMD128_RSA_PKCS");
addMech(CKM_RIPEMD160_RSA_PKCS, R)651         addMech(CKM_RIPEMD160_RSA_PKCS,         "CKM_RIPEMD160_RSA_PKCS");
addMech(CKM_RSA_PKCS_OAEP, R)652         addMech(CKM_RSA_PKCS_OAEP,              "CKM_RSA_PKCS_OAEP");
addMech(CKM_RSA_X9_31_KEY_PAIR_GEN, R)653         addMech(CKM_RSA_X9_31_KEY_PAIR_GEN,     "CKM_RSA_X9_31_KEY_PAIR_GEN");
addMech(CKM_RSA_X9_31, R)654         addMech(CKM_RSA_X9_31,                  "CKM_RSA_X9_31");
addMech(CKM_SHA1_RSA_X9_31, R)655         addMech(CKM_SHA1_RSA_X9_31,             "CKM_SHA1_RSA_X9_31");
addMech(CKM_RSA_PKCS_PSS, R)656         addMech(CKM_RSA_PKCS_PSS,               "CKM_RSA_PKCS_PSS");
addMech(CKM_SHA1_RSA_PKCS_PSS, R)657         addMech(CKM_SHA1_RSA_PKCS_PSS,          "CKM_SHA1_RSA_PKCS_PSS");
addMech(CKM_DSA_KEY_PAIR_GEN, R)658         addMech(CKM_DSA_KEY_PAIR_GEN,           "CKM_DSA_KEY_PAIR_GEN");
addMech(CKM_DSA, R)659         addMech(CKM_DSA,                        "CKM_DSA");
addMech(CKM_DSA_SHA1, R)660         addMech(CKM_DSA_SHA1,                   "CKM_DSA_SHA1");
addMech(CKM_DSA_SHA224, R)661         addMech(CKM_DSA_SHA224,                 "CKM_DSA_SHA224");
addMech(CKM_DSA_SHA256, R)662         addMech(CKM_DSA_SHA256,                 "CKM_DSA_SHA256");
addMech(CKM_DSA_SHA384, R)663         addMech(CKM_DSA_SHA384,                 "CKM_DSA_SHA384");
addMech(CKM_DSA_SHA512, R)664         addMech(CKM_DSA_SHA512,                 "CKM_DSA_SHA512");
addMech(CKM_DSA_SHA3_224, R)665         addMech(CKM_DSA_SHA3_224,               "CKM_DSA_SHA3_224");
addMech(CKM_DSA_SHA3_256, R)666         addMech(CKM_DSA_SHA3_256,               "CKM_DSA_SHA3_256");
addMech(CKM_DSA_SHA3_384, R)667         addMech(CKM_DSA_SHA3_384,               "CKM_DSA_SHA3_384");
addMech(CKM_DSA_SHA3_512, R)668         addMech(CKM_DSA_SHA3_512,               "CKM_DSA_SHA3_512");
669 
addMech(CKM_DH_PKCS_KEY_PAIR_GEN, R)670         addMech(CKM_DH_PKCS_KEY_PAIR_GEN,       "CKM_DH_PKCS_KEY_PAIR_GEN");
addMech(CKM_DH_PKCS_DERIVE, R)671         addMech(CKM_DH_PKCS_DERIVE,             "CKM_DH_PKCS_DERIVE");
addMech(CKM_X9_42_DH_KEY_PAIR_GEN, R)672         addMech(CKM_X9_42_DH_KEY_PAIR_GEN,      "CKM_X9_42_DH_KEY_PAIR_GEN");
addMech(CKM_X9_42_DH_DERIVE, R)673         addMech(CKM_X9_42_DH_DERIVE,            "CKM_X9_42_DH_DERIVE");
addMech(CKM_X9_42_DH_HYBRID_DERIVE, R)674         addMech(CKM_X9_42_DH_HYBRID_DERIVE,     "CKM_X9_42_DH_HYBRID_DERIVE");
addMech(CKM_X9_42_MQV_DERIVE, R)675         addMech(CKM_X9_42_MQV_DERIVE,           "CKM_X9_42_MQV_DERIVE");
676 
addMech(CKM_SHA256_RSA_PKCS, R)677         addMech(CKM_SHA256_RSA_PKCS,            "CKM_SHA256_RSA_PKCS");
addMech(CKM_SHA384_RSA_PKCS, R)678         addMech(CKM_SHA384_RSA_PKCS,            "CKM_SHA384_RSA_PKCS");
addMech(CKM_SHA512_RSA_PKCS, R)679         addMech(CKM_SHA512_RSA_PKCS,            "CKM_SHA512_RSA_PKCS");
addMech(CKM_SHA256_RSA_PKCS_PSS, R)680         addMech(CKM_SHA256_RSA_PKCS_PSS,        "CKM_SHA256_RSA_PKCS_PSS");
addMech(CKM_SHA384_RSA_PKCS_PSS, R)681         addMech(CKM_SHA384_RSA_PKCS_PSS,        "CKM_SHA384_RSA_PKCS_PSS");
addMech(CKM_SHA512_RSA_PKCS_PSS, R)682         addMech(CKM_SHA512_RSA_PKCS_PSS,        "CKM_SHA512_RSA_PKCS_PSS");
addMech(CKM_SHA224_RSA_PKCS, R)683         addMech(CKM_SHA224_RSA_PKCS,            "CKM_SHA224_RSA_PKCS");
addMech(CKM_SHA224_RSA_PKCS_PSS, R)684         addMech(CKM_SHA224_RSA_PKCS_PSS,        "CKM_SHA224_RSA_PKCS_PSS");
685 
addMech(CKM_SHA512_224, R)686         addMech(CKM_SHA512_224,                 "CKM_SHA512_224");
addMech(CKM_SHA512_224_HMAC, R)687         addMech(CKM_SHA512_224_HMAC,            "CKM_SHA512_224_HMAC");
addMech(CKM_SHA512_224_HMAC_GENERAL, R)688         addMech(CKM_SHA512_224_HMAC_GENERAL,    "CKM_SHA512_224_HMAC_GENERAL");
addMech(CKM_SHA512_224_KEY_DERIVATION, R)689         addMech(CKM_SHA512_224_KEY_DERIVATION,  "CKM_SHA512_224_KEY_DERIVATION");
addMech(CKM_SHA512_256, R)690         addMech(CKM_SHA512_256,                 "CKM_SHA512_256");
addMech(CKM_SHA512_256_HMAC, R)691         addMech(CKM_SHA512_256_HMAC,            "CKM_SHA512_256_HMAC");
addMech(CKM_SHA512_256_HMAC_GENERAL, R)692         addMech(CKM_SHA512_256_HMAC_GENERAL,    "CKM_SHA512_256_HMAC_GENERAL");
addMech(CKM_SHA512_256_KEY_DERIVATION, R)693         addMech(CKM_SHA512_256_KEY_DERIVATION,  "CKM_SHA512_256_KEY_DERIVATION");
addMech(CKM_SHA512_T, R)694         addMech(CKM_SHA512_T,                   "CKM_SHA512_T");
addMech(CKM_SHA512_T_HMAC, R)695         addMech(CKM_SHA512_T_HMAC,              "CKM_SHA512_T_HMAC");
addMech(CKM_SHA512_T_HMAC_GENERAL, R)696         addMech(CKM_SHA512_T_HMAC_GENERAL,      "CKM_SHA512_T_HMAC_GENERAL");
addMech(CKM_SHA512_T_KEY_DERIVATION, R)697         addMech(CKM_SHA512_T_KEY_DERIVATION,    "CKM_SHA512_T_KEY_DERIVATION");
698 
addMech(CKM_SHA3_256_RSA_PKCS, R)699         addMech(CKM_SHA3_256_RSA_PKCS,          "CKM_SHA3_256_RSA_PKCS");
addMech(CKM_SHA3_384_RSA_PKCS, R)700         addMech(CKM_SHA3_384_RSA_PKCS,          "CKM_SHA3_384_RSA_PKCS");
addMech(CKM_SHA3_512_RSA_PKCS, R)701         addMech(CKM_SHA3_512_RSA_PKCS,          "CKM_SHA3_512_RSA_PKCS");
addMech(CKM_SHA3_256_RSA_PKCS_PSS, R)702         addMech(CKM_SHA3_256_RSA_PKCS_PSS,      "CKM_SHA3_256_RSA_PKCS_PSS");
addMech(CKM_SHA3_384_RSA_PKCS_PSS, R)703         addMech(CKM_SHA3_384_RSA_PKCS_PSS,      "CKM_SHA3_384_RSA_PKCS_PSS");
addMech(CKM_SHA3_512_RSA_PKCS_PSS, R)704         addMech(CKM_SHA3_512_RSA_PKCS_PSS,      "CKM_SHA3_512_RSA_PKCS_PSS");
addMech(CKM_SHA3_224_RSA_PKCS, R)705         addMech(CKM_SHA3_224_RSA_PKCS,          "CKM_SHA3_224_RSA_PKCS");
addMech(CKM_SHA3_224_RSA_PKCS_PSS, R)706         addMech(CKM_SHA3_224_RSA_PKCS_PSS,      "CKM_SHA3_224_RSA_PKCS_PSS");
707 
addMech(CKM_RC2_KEY_GEN, R)708         addMech(CKM_RC2_KEY_GEN,                "CKM_RC2_KEY_GEN");
addMech(CKM_RC2_ECB, R)709         addMech(CKM_RC2_ECB,                    "CKM_RC2_ECB");
addMech(CKM_RC2_CBC, R)710         addMech(CKM_RC2_CBC,                    "CKM_RC2_CBC");
addMech(CKM_RC2_MAC, R)711         addMech(CKM_RC2_MAC,                    "CKM_RC2_MAC");
addMech(CKM_RC2_MAC_GENERAL, R)712         addMech(CKM_RC2_MAC_GENERAL,            "CKM_RC2_MAC_GENERAL");
addMech(CKM_RC2_CBC_PAD, R)713         addMech(CKM_RC2_CBC_PAD,                "CKM_RC2_CBC_PAD");
addMech(CKM_RC4_KEY_GEN, R)714         addMech(CKM_RC4_KEY_GEN,                "CKM_RC4_KEY_GEN");
addMech(CKM_RC4, R)715         addMech(CKM_RC4,                        "CKM_RC4");
addMech(CKM_DES_KEY_GEN, R)716         addMech(CKM_DES_KEY_GEN,                "CKM_DES_KEY_GEN");
addMech(CKM_DES_ECB, R)717         addMech(CKM_DES_ECB,                    "CKM_DES_ECB");
addMech(CKM_DES_CBC, R)718         addMech(CKM_DES_CBC,                    "CKM_DES_CBC");
addMech(CKM_DES_MAC, R)719         addMech(CKM_DES_MAC,                    "CKM_DES_MAC");
addMech(CKM_DES_MAC_GENERAL, R)720         addMech(CKM_DES_MAC_GENERAL,            "CKM_DES_MAC_GENERAL");
addMech(CKM_DES_CBC_PAD, R)721         addMech(CKM_DES_CBC_PAD,                "CKM_DES_CBC_PAD");
addMech(CKM_DES2_KEY_GEN, R)722         addMech(CKM_DES2_KEY_GEN,               "CKM_DES2_KEY_GEN");
addMech(CKM_DES3_KEY_GEN, R)723         addMech(CKM_DES3_KEY_GEN,               "CKM_DES3_KEY_GEN");
addMech(CKM_DES3_ECB, R)724         addMech(CKM_DES3_ECB,                   "CKM_DES3_ECB");
addMech(CKM_DES3_CBC, R)725         addMech(CKM_DES3_CBC,                   "CKM_DES3_CBC");
addMech(CKM_DES3_MAC, R)726         addMech(CKM_DES3_MAC,                   "CKM_DES3_MAC");
addMech(CKM_DES3_MAC_GENERAL, R)727         addMech(CKM_DES3_MAC_GENERAL,           "CKM_DES3_MAC_GENERAL");
addMech(CKM_DES3_CBC_PAD, R)728         addMech(CKM_DES3_CBC_PAD,               "CKM_DES3_CBC_PAD");
addMech(CKM_DES3_CMAC_GENERAL, R)729         addMech(CKM_DES3_CMAC_GENERAL,          "CKM_DES3_CMAC_GENERAL");
addMech(CKM_DES3_CMAC, R)730         addMech(CKM_DES3_CMAC,                  "CKM_DES3_CMAC");
731 
addMech(CKM_CDMF_KEY_GEN, R)732         addMech(CKM_CDMF_KEY_GEN,               "CKM_CDMF_KEY_GEN");
addMech(CKM_CDMF_ECB, R)733         addMech(CKM_CDMF_ECB,                   "CKM_CDMF_ECB");
addMech(CKM_CDMF_CBC, R)734         addMech(CKM_CDMF_CBC,                   "CKM_CDMF_CBC");
addMech(CKM_CDMF_MAC, R)735         addMech(CKM_CDMF_MAC,                   "CKM_CDMF_MAC");
addMech(CKM_CDMF_MAC_GENERAL, R)736         addMech(CKM_CDMF_MAC_GENERAL,           "CKM_CDMF_MAC_GENERAL");
addMech(CKM_CDMF_CBC_PAD, R)737         addMech(CKM_CDMF_CBC_PAD,               "CKM_CDMF_CBC_PAD");
738 
addMech(CKM_DES_OFB64, R)739         addMech(CKM_DES_OFB64,                  "CKM_DES_OFB64");
addMech(CKM_DES_OFB8, R)740         addMech(CKM_DES_OFB8,                   "CKM_DES_OFB8");
addMech(CKM_DES_CFB64, R)741         addMech(CKM_DES_CFB64,                  "CKM_DES_CFB64");
addMech(CKM_DES_CFB8, R)742         addMech(CKM_DES_CFB8,                   "CKM_DES_CFB8");
743 
addMech(CKM_MD2, R)744         addMech(CKM_MD2,                        "CKM_MD2");
addMech(CKM_MD2_HMAC, R)745         addMech(CKM_MD2_HMAC,                   "CKM_MD2_HMAC");
addMech(CKM_MD2_HMAC_GENERAL, R)746         addMech(CKM_MD2_HMAC_GENERAL,           "CKM_MD2_HMAC_GENERAL");
addMech(CKM_MD5, R)747         addMech(CKM_MD5,                        "CKM_MD5");
addMech(CKM_MD5_HMAC, R)748         addMech(CKM_MD5_HMAC,                   "CKM_MD5_HMAC");
addMech(CKM_MD5_HMAC_GENERAL, R)749         addMech(CKM_MD5_HMAC_GENERAL,           "CKM_MD5_HMAC_GENERAL");
addMech(CKM_SHA_1, R)750         addMech(CKM_SHA_1,                      "CKM_SHA_1");
addMech(CKM_SHA_1_HMAC, R)751         addMech(CKM_SHA_1_HMAC,                 "CKM_SHA_1_HMAC");
addMech(CKM_SHA_1_HMAC_GENERAL, R)752         addMech(CKM_SHA_1_HMAC_GENERAL,         "CKM_SHA_1_HMAC_GENERAL");
addMech(CKM_RIPEMD128, R)753         addMech(CKM_RIPEMD128,                  "CKM_RIPEMD128");
addMech(CKM_RIPEMD128_HMAC, R)754         addMech(CKM_RIPEMD128_HMAC,             "CKM_RIPEMD128_HMAC");
addMech(CKM_RIPEMD128_HMAC_GENERAL, R)755         addMech(CKM_RIPEMD128_HMAC_GENERAL,     "CKM_RIPEMD128_HMAC_GENERAL");
addMech(CKM_RIPEMD160, R)756         addMech(CKM_RIPEMD160,                  "CKM_RIPEMD160");
addMech(CKM_RIPEMD160_HMAC, R)757         addMech(CKM_RIPEMD160_HMAC,             "CKM_RIPEMD160_HMAC");
addMech(CKM_RIPEMD160_HMAC_GENERAL, R)758         addMech(CKM_RIPEMD160_HMAC_GENERAL,     "CKM_RIPEMD160_HMAC_GENERAL");
addMech(CKM_SHA256, R)759         addMech(CKM_SHA256,                     "CKM_SHA256");
addMech(CKM_SHA256_HMAC, R)760         addMech(CKM_SHA256_HMAC,                "CKM_SHA256_HMAC");
addMech(CKM_SHA256_HMAC_GENERAL, R)761         addMech(CKM_SHA256_HMAC_GENERAL,        "CKM_SHA256_HMAC_GENERAL");
addMech(CKM_SHA224, R)762         addMech(CKM_SHA224,                     "CKM_SHA224");
addMech(CKM_SHA224_HMAC, R)763         addMech(CKM_SHA224_HMAC,                "CKM_SHA224_HMAC");
addMech(CKM_SHA224_HMAC_GENERAL, R)764         addMech(CKM_SHA224_HMAC_GENERAL,        "CKM_SHA224_HMAC_GENERAL");
addMech(CKM_SHA384, R)765         addMech(CKM_SHA384,                     "CKM_SHA384");
addMech(CKM_SHA384_HMAC, R)766         addMech(CKM_SHA384_HMAC,                "CKM_SHA384_HMAC");
addMech(CKM_SHA384_HMAC_GENERAL, R)767         addMech(CKM_SHA384_HMAC_GENERAL,        "CKM_SHA384_HMAC_GENERAL");
addMech(CKM_SHA512, R)768         addMech(CKM_SHA512,                     "CKM_SHA512");
addMech(CKM_SHA512_HMAC, R)769         addMech(CKM_SHA512_HMAC,                "CKM_SHA512_HMAC");
addMech(CKM_SHA512_HMAC_GENERAL, R)770         addMech(CKM_SHA512_HMAC_GENERAL,        "CKM_SHA512_HMAC_GENERAL");
771 
addMech(CKM_SECURID_KEY_GEN, R)772         addMech(CKM_SECURID_KEY_GEN,            "CKM_SECURID_KEY_GEN");
addMech(CKM_SECURID, R)773         addMech(CKM_SECURID,                    "CKM_SECURID");
addMech(CKM_HOTP_KEY_GEN, R)774         addMech(CKM_HOTP_KEY_GEN,               "CKM_HOTP_KEY_GEN");
addMech(CKM_HOTP, R)775         addMech(CKM_HOTP,                       "CKM_HOTP");
addMech(CKM_ACTI, R)776         addMech(CKM_ACTI,                       "CKM_ACTI");
addMech(CKM_ACTI_KEY_GEN, R)777         addMech(CKM_ACTI_KEY_GEN,               "CKM_ACTI_KEY_GEN");
778 
addMech(CKM_SHA3_256, R)779         addMech(CKM_SHA3_256,                   "CKM_SHA3_256");
addMech(CKM_SHA3_256_HMAC, R)780         addMech(CKM_SHA3_256_HMAC,              "CKM_SHA3_256_HMAC");
addMech(CKM_SHA3_256_HMAC_GENERAL, R)781         addMech(CKM_SHA3_256_HMAC_GENERAL,      "CKM_SHA3_256_HMAC_GENERAL");
addMech(CKM_SHA3_256_KEY_GEN, R)782         addMech(CKM_SHA3_256_KEY_GEN,           "CKM_SHA3_256_KEY_GEN");
addMech(CKM_SHA3_224, R)783         addMech(CKM_SHA3_224,                   "CKM_SHA3_224");
addMech(CKM_SHA3_224_HMAC, R)784         addMech(CKM_SHA3_224_HMAC,              "CKM_SHA3_224_HMAC");
addMech(CKM_SHA3_224_HMAC_GENERAL, R)785         addMech(CKM_SHA3_224_HMAC_GENERAL,      "CKM_SHA3_224_HMAC_GENERAL");
addMech(CKM_SHA3_224_KEY_GEN, R)786         addMech(CKM_SHA3_224_KEY_GEN,           "CKM_SHA3_224_KEY_GEN");
addMech(CKM_SHA3_384, R)787         addMech(CKM_SHA3_384,                   "CKM_SHA3_384");
addMech(CKM_SHA3_384_HMAC, R)788         addMech(CKM_SHA3_384_HMAC,              "CKM_SHA3_384_HMAC");
addMech(CKM_SHA3_384_HMAC_GENERAL, R)789         addMech(CKM_SHA3_384_HMAC_GENERAL,      "CKM_SHA3_384_HMAC_GENERAL");
addMech(CKM_SHA3_384_KEY_GEN, R)790         addMech(CKM_SHA3_384_KEY_GEN,           "CKM_SHA3_384_KEY_GEN");
addMech(CKM_SHA3_512, R)791         addMech(CKM_SHA3_512,                   "CKM_SHA3_512");
addMech(CKM_SHA3_512_HMAC, R)792         addMech(CKM_SHA3_512_HMAC,              "CKM_SHA3_512_HMAC");
addMech(CKM_SHA3_512_HMAC_GENERAL, R)793         addMech(CKM_SHA3_512_HMAC_GENERAL,      "CKM_SHA3_512_HMAC_GENERAL");
addMech(CKM_SHA3_512_KEY_GEN, R)794         addMech(CKM_SHA3_512_KEY_GEN,           "CKM_SHA3_512_KEY_GEN");
795 
addMech(CKM_CAST_KEY_GEN, R)796         addMech(CKM_CAST_KEY_GEN,               "CKM_CAST_KEY_GEN");
addMech(CKM_CAST_ECB, R)797         addMech(CKM_CAST_ECB,                   "CKM_CAST_ECB");
addMech(CKM_CAST_CBC, R)798         addMech(CKM_CAST_CBC,                   "CKM_CAST_CBC");
addMech(CKM_CAST_MAC, R)799         addMech(CKM_CAST_MAC,                   "CKM_CAST_MAC");
addMech(CKM_CAST_MAC_GENERAL, R)800         addMech(CKM_CAST_MAC_GENERAL,           "CKM_CAST_MAC_GENERAL");
addMech(CKM_CAST_CBC_PAD, R)801         addMech(CKM_CAST_CBC_PAD,               "CKM_CAST_CBC_PAD");
addMech(CKM_CAST3_KEY_GEN, R)802         addMech(CKM_CAST3_KEY_GEN,              "CKM_CAST3_KEY_GEN");
addMech(CKM_CAST3_ECB, R)803         addMech(CKM_CAST3_ECB,                  "CKM_CAST3_ECB");
addMech(CKM_CAST3_CBC, R)804         addMech(CKM_CAST3_CBC,                  "CKM_CAST3_CBC");
addMech(CKM_CAST3_MAC, R)805         addMech(CKM_CAST3_MAC,                  "CKM_CAST3_MAC");
addMech(CKM_CAST3_MAC_GENERAL, R)806         addMech(CKM_CAST3_MAC_GENERAL,          "CKM_CAST3_MAC_GENERAL");
addMech(CKM_CAST3_CBC_PAD, R)807         addMech(CKM_CAST3_CBC_PAD,              "CKM_CAST3_CBC_PAD");
addMech(CKM_CAST128_KEY_GEN, R)808         addMech(CKM_CAST128_KEY_GEN,            "CKM_CAST128_KEY_GEN");
addMech(CKM_CAST128_ECB, R)809         addMech(CKM_CAST128_ECB,                "CKM_CAST128_ECB");
addMech(CKM_CAST128_CBC, R)810         addMech(CKM_CAST128_CBC,                "CKM_CAST128_CBC");
addMech(CKM_CAST128_MAC, R)811         addMech(CKM_CAST128_MAC,                "CKM_CAST128_MAC");
addMech(CKM_CAST128_MAC_GENERAL, R)812         addMech(CKM_CAST128_MAC_GENERAL,        "CKM_CAST128_MAC_GENERAL");
addMech(CKM_CAST128_CBC_PAD, R)813         addMech(CKM_CAST128_CBC_PAD,            "CKM_CAST128_CBC_PAD");
addMech(CKM_RC5_KEY_GEN, R)814         addMech(CKM_RC5_KEY_GEN,                "CKM_RC5_KEY_GEN");
addMech(CKM_RC5_ECB, R)815         addMech(CKM_RC5_ECB,                    "CKM_RC5_ECB");
addMech(CKM_RC5_CBC, R)816         addMech(CKM_RC5_CBC,                    "CKM_RC5_CBC");
addMech(CKM_RC5_MAC, R)817         addMech(CKM_RC5_MAC,                    "CKM_RC5_MAC");
addMech(CKM_RC5_MAC_GENERAL, R)818         addMech(CKM_RC5_MAC_GENERAL,            "CKM_RC5_MAC_GENERAL");
addMech(CKM_RC5_CBC_PAD, R)819         addMech(CKM_RC5_CBC_PAD,                "CKM_RC5_CBC_PAD");
addMech(CKM_IDEA_KEY_GEN, R)820         addMech(CKM_IDEA_KEY_GEN,               "CKM_IDEA_KEY_GEN");
addMech(CKM_IDEA_ECB, R)821         addMech(CKM_IDEA_ECB,                   "CKM_IDEA_ECB");
addMech(CKM_IDEA_CBC, R)822         addMech(CKM_IDEA_CBC,                   "CKM_IDEA_CBC");
addMech(CKM_IDEA_MAC, R)823         addMech(CKM_IDEA_MAC,                   "CKM_IDEA_MAC");
addMech(CKM_IDEA_MAC_GENERAL, R)824         addMech(CKM_IDEA_MAC_GENERAL,           "CKM_IDEA_MAC_GENERAL");
addMech(CKM_IDEA_CBC_PAD, R)825         addMech(CKM_IDEA_CBC_PAD,               "CKM_IDEA_CBC_PAD");
addMech(CKM_GENERIC_SECRET_KEY_GEN, R)826         addMech(CKM_GENERIC_SECRET_KEY_GEN,     "CKM_GENERIC_SECRET_KEY_GEN");
addMech(CKM_CONCATENATE_BASE_AND_KEY, R)827         addMech(CKM_CONCATENATE_BASE_AND_KEY,   "CKM_CONCATENATE_BASE_AND_KEY");
addMech(CKM_CONCATENATE_BASE_AND_DATA, R)828         addMech(CKM_CONCATENATE_BASE_AND_DATA,  "CKM_CONCATENATE_BASE_AND_DATA");
addMech(CKM_CONCATENATE_DATA_AND_BASE, R)829         addMech(CKM_CONCATENATE_DATA_AND_BASE,  "CKM_CONCATENATE_DATA_AND_BASE");
addMech(CKM_XOR_BASE_AND_DATA, R)830         addMech(CKM_XOR_BASE_AND_DATA,          "CKM_XOR_BASE_AND_DATA");
addMech(CKM_EXTRACT_KEY_FROM_KEY, R)831         addMech(CKM_EXTRACT_KEY_FROM_KEY,       "CKM_EXTRACT_KEY_FROM_KEY");
addMech(CKM_SSL3_PRE_MASTER_KEY_GEN, R)832         addMech(CKM_SSL3_PRE_MASTER_KEY_GEN,    "CKM_SSL3_PRE_MASTER_KEY_GEN");
addMech(CKM_SSL3_MASTER_KEY_DERIVE, R)833         addMech(CKM_SSL3_MASTER_KEY_DERIVE,     "CKM_SSL3_MASTER_KEY_DERIVE");
addMech(CKM_SSL3_KEY_AND_MAC_DERIVE, R)834         addMech(CKM_SSL3_KEY_AND_MAC_DERIVE,    "CKM_SSL3_KEY_AND_MAC_DERIVE");
addMech(CKM_SSL3_MASTER_KEY_DERIVE_DH, R)835         addMech(CKM_SSL3_MASTER_KEY_DERIVE_DH,  "CKM_SSL3_MASTER_KEY_DERIVE_DH");
addMech(CKM_TLS_PRE_MASTER_KEY_GEN, R)836         addMech(CKM_TLS_PRE_MASTER_KEY_GEN,     "CKM_TLS_PRE_MASTER_KEY_GEN");
addMech(CKM_TLS_MASTER_KEY_DERIVE, R)837         addMech(CKM_TLS_MASTER_KEY_DERIVE,      "CKM_TLS_MASTER_KEY_DERIVE");
addMech(CKM_TLS_KEY_AND_MAC_DERIVE, R)838         addMech(CKM_TLS_KEY_AND_MAC_DERIVE,     "CKM_TLS_KEY_AND_MAC_DERIVE");
addMech(CKM_TLS_MASTER_KEY_DERIVE_DH, R)839         addMech(CKM_TLS_MASTER_KEY_DERIVE_DH,   "CKM_TLS_MASTER_KEY_DERIVE_DH");
addMech(CKM_TLS_PRF, R)840         addMech(CKM_TLS_PRF,                    "CKM_TLS_PRF");
addMech(CKM_SSL3_MD5_MAC, R)841         addMech(CKM_SSL3_MD5_MAC,               "CKM_SSL3_MD5_MAC");
addMech(CKM_SSL3_SHA1_MAC, R)842         addMech(CKM_SSL3_SHA1_MAC,              "CKM_SSL3_SHA1_MAC");
843 
addMech(CKM_MD5_KEY_DERIVATION, R)844         addMech(CKM_MD5_KEY_DERIVATION,         "CKM_MD5_KEY_DERIVATION");
addMech(CKM_MD2_KEY_DERIVATION, R)845         addMech(CKM_MD2_KEY_DERIVATION,         "CKM_MD2_KEY_DERIVATION");
addMech(CKM_SHA1_KEY_DERIVATION, R)846         addMech(CKM_SHA1_KEY_DERIVATION,        "CKM_SHA1_KEY_DERIVATION");
addMech(CKM_SHA256_KEY_DERIVATION, R)847         addMech(CKM_SHA256_KEY_DERIVATION,      "CKM_SHA256_KEY_DERIVATION");
addMech(CKM_SHA384_KEY_DERIVATION, R)848         addMech(CKM_SHA384_KEY_DERIVATION,      "CKM_SHA384_KEY_DERIVATION");
addMech(CKM_SHA512_KEY_DERIVATION, R)849         addMech(CKM_SHA512_KEY_DERIVATION,      "CKM_SHA512_KEY_DERIVATION");
addMech(CKM_SHA224_KEY_DERIVATION, R)850         addMech(CKM_SHA224_KEY_DERIVATION,      "CKM_SHA224_KEY_DERIVATION");
addMech(CKM_SHA3_256_KEY_DERIVATION, R)851         addMech(CKM_SHA3_256_KEY_DERIVATION,    "CKM_SHA3_256_KEY_DERIVATION");
addMech(CKM_SHA3_224_KEY_DERIVATION, R)852         addMech(CKM_SHA3_224_KEY_DERIVATION,    "CKM_SHA3_224_KEY_DERIVATION");
addMech(CKM_SHA3_384_KEY_DERIVATION, R)853         addMech(CKM_SHA3_384_KEY_DERIVATION,    "CKM_SHA3_384_KEY_DERIVATION");
addMech(CKM_SHA3_512_KEY_DERIVATION, R)854         addMech(CKM_SHA3_512_KEY_DERIVATION,    "CKM_SHA3_512_KEY_DERIVATION");
addMech(CKM_SHAKE_128_KEY_DERIVATION, R)855         addMech(CKM_SHAKE_128_KEY_DERIVATION,   "CKM_SHAKE_128_KEY_DERIVATION");
addMech(CKM_SHAKE_256_KEY_DERIVATION, R)856         addMech(CKM_SHAKE_256_KEY_DERIVATION,   "CKM_SHAKE_256_KEY_DERIVATION");
857 
addMech(CKM_PBE_MD2_DES_CBC, R)858         addMech(CKM_PBE_MD2_DES_CBC,            "CKM_PBE_MD2_DES_CBC");
addMech(CKM_PBE_MD5_DES_CBC, R)859         addMech(CKM_PBE_MD5_DES_CBC,            "CKM_PBE_MD5_DES_CBC");
addMech(CKM_PBE_MD5_CAST_CBC, R)860         addMech(CKM_PBE_MD5_CAST_CBC,           "CKM_PBE_MD5_CAST_CBC");
addMech(CKM_PBE_MD5_CAST3_CBC, R)861         addMech(CKM_PBE_MD5_CAST3_CBC,          "CKM_PBE_MD5_CAST3_CBC");
addMech(CKM_PBE_MD5_CAST128_CBC, R)862         addMech(CKM_PBE_MD5_CAST128_CBC,        "CKM_PBE_MD5_CAST128_CBC");
addMech(CKM_PBE_SHA1_CAST128_CBC, R)863         addMech(CKM_PBE_SHA1_CAST128_CBC,       "CKM_PBE_SHA1_CAST128_CBC");
addMech(CKM_PBE_SHA1_RC4_128, R)864         addMech(CKM_PBE_SHA1_RC4_128,           "CKM_PBE_SHA1_RC4_128");
addMech(CKM_PBE_SHA1_RC4_40, R)865         addMech(CKM_PBE_SHA1_RC4_40,            "CKM_PBE_SHA1_RC4_40");
addMech(CKM_PBE_SHA1_DES3_EDE_CBC, R)866         addMech(CKM_PBE_SHA1_DES3_EDE_CBC,      "CKM_PBE_SHA1_DES3_EDE_CBC");
addMech(CKM_PBE_SHA1_DES2_EDE_CBC, R)867         addMech(CKM_PBE_SHA1_DES2_EDE_CBC,      "CKM_PBE_SHA1_DES2_EDE_CBC");
addMech(CKM_PBE_SHA1_RC2_128_CBC, R)868         addMech(CKM_PBE_SHA1_RC2_128_CBC,       "CKM_PBE_SHA1_RC2_128_CBC");
addMech(CKM_PBE_SHA1_RC2_40_CBC, R)869         addMech(CKM_PBE_SHA1_RC2_40_CBC,        "CKM_PBE_SHA1_RC2_40_CBC");
addMech(CKM_PKCS5_PBKD2, R)870         addMech(CKM_PKCS5_PBKD2,                "CKM_PKCS5_PBKD2");
addMech(CKM_PBA_SHA1_WITH_SHA1_HMAC, R)871         addMech(CKM_PBA_SHA1_WITH_SHA1_HMAC,    "CKM_PBA_SHA1_WITH_SHA1_HMAC");
872 
addMech(CKM_WTLS_PRE_MASTER_KEY_GEN, R)873         addMech(CKM_WTLS_PRE_MASTER_KEY_GEN,    "CKM_WTLS_PRE_MASTER_KEY_GEN");
addMech(CKM_WTLS_MASTER_KEY_DERIVE, R)874         addMech(CKM_WTLS_MASTER_KEY_DERIVE,     "CKM_WTLS_MASTER_KEY_DERIVE");
addMech(CKM_WTLS_MASTER_KEY_DERIVE_DH_ECC, R)875         addMech(CKM_WTLS_MASTER_KEY_DERIVE_DH_ECC,
876                                                 "CKM_WTLS_MASTER_KEY_DERIVE_DH_ECC");
addMech(CKM_WTLS_PRF, R)877         addMech(CKM_WTLS_PRF,                   "CKM_WTLS_PRF");
addMech(CKM_WTLS_SERVER_KEY_AND_MAC_DERIVE, R)878         addMech(CKM_WTLS_SERVER_KEY_AND_MAC_DERIVE,
879                                                 "CKM_WTLS_SERVER_KEY_AND_MAC_DERIVE");
addMech(CKM_WTLS_CLIENT_KEY_AND_MAC_DERIVE, R)880         addMech(CKM_WTLS_CLIENT_KEY_AND_MAC_DERIVE,
881                                                 "CKM_WTLS_CLIENT_KEY_AND_MAC_DERIVE");
addMech(CKM_TLS10_MAC_SERVER, R)882         addMech(CKM_TLS10_MAC_SERVER,           "CKM_TLS10_MAC_SERVER");
addMech(CKM_TLS10_MAC_CLIENT, R)883         addMech(CKM_TLS10_MAC_CLIENT,           "CKM_TLS10_MAC_CLIENT");
addMech(CKM_TLS12_MAC, R)884         addMech(CKM_TLS12_MAC,                  "CKM_TLS12_MAC");
addMech(CKM_TLS12_KDF, R)885         addMech(CKM_TLS12_KDF,                  "CKM_TLS12_KDF");
addMech(CKM_TLS12_MASTER_KEY_DERIVE, R)886         addMech(CKM_TLS12_MASTER_KEY_DERIVE,    "CKM_TLS12_MASTER_KEY_DERIVE");
addMech(CKM_TLS12_KEY_AND_MAC_DERIVE, R)887         addMech(CKM_TLS12_KEY_AND_MAC_DERIVE,   "CKM_TLS12_KEY_AND_MAC_DERIVE");
addMech(CKM_TLS12_MASTER_KEY_DERIVE_DH, R)888         addMech(CKM_TLS12_MASTER_KEY_DERIVE_DH, "CKM_TLS12_MASTER_KEY_DERIVE_DH");
addMech(CKM_TLS12_KEY_SAFE_DERIVE, R)889         addMech(CKM_TLS12_KEY_SAFE_DERIVE,      "CKM_TLS12_KEY_SAFE_DERIVE");
addMech(CKM_TLS_MAC, R)890         addMech(CKM_TLS_MAC,                    "CKM_TLS_MAC");
addMech(CKM_TLS_KDF, R)891         addMech(CKM_TLS_KDF,                    "CKM_TLS_KDF");
892 
addMech(CKM_KEY_WRAP_LYNKS, R)893         addMech(CKM_KEY_WRAP_LYNKS,             "CKM_KEY_WRAP_LYNKS");
addMech(CKM_KEY_WRAP_SET_OAEP, R)894         addMech(CKM_KEY_WRAP_SET_OAEP,          "CKM_KEY_WRAP_SET_OAEP");
895 
addMech(CKM_CMS_SIG, R)896         addMech(CKM_CMS_SIG,                    "CKM_CMS_SIG");
addMech(CKM_KIP_DERIVE, R)897         addMech(CKM_KIP_DERIVE,                 "CKM_KIP_DERIVE");
addMech(CKM_KIP_WRAP, R)898         addMech(CKM_KIP_WRAP,                   "CKM_KIP_WRAP");
addMech(CKM_KIP_MAC, R)899         addMech(CKM_KIP_MAC,                    "CKM_KIP_MAC");
addMech(CKM_CAMELLIA_KEY_GEN, R)900         addMech(CKM_CAMELLIA_KEY_GEN,           "CKM_CAMELLIA_KEY_GEN");
addMech(CKM_CAMELLIA_ECB, R)901         addMech(CKM_CAMELLIA_ECB,               "CKM_CAMELLIA_ECB");
addMech(CKM_CAMELLIA_CBC, R)902         addMech(CKM_CAMELLIA_CBC,               "CKM_CAMELLIA_CBC");
addMech(CKM_CAMELLIA_MAC, R)903         addMech(CKM_CAMELLIA_MAC,               "CKM_CAMELLIA_MAC");
addMech(CKM_CAMELLIA_MAC_GENERAL, R)904         addMech(CKM_CAMELLIA_MAC_GENERAL,       "CKM_CAMELLIA_MAC_GENERAL");
addMech(CKM_CAMELLIA_CBC_PAD, R)905         addMech(CKM_CAMELLIA_CBC_PAD,           "CKM_CAMELLIA_CBC_PAD");
addMech(CKM_CAMELLIA_ECB_ENCRYPT_DATA, R)906         addMech(CKM_CAMELLIA_ECB_ENCRYPT_DATA,  "CKM_CAMELLIA_ECB_ENCRYPT_DATA");
addMech(CKM_CAMELLIA_CBC_ENCRYPT_DATA, R)907         addMech(CKM_CAMELLIA_CBC_ENCRYPT_DATA,  "CKM_CAMELLIA_CBC_ENCRYPT_DATA");
addMech(CKM_CAMELLIA_CTR, R)908         addMech(CKM_CAMELLIA_CTR,               "CKM_CAMELLIA_CTR");
909 
addMech(CKM_ARIA_KEY_GEN, R)910         addMech(CKM_ARIA_KEY_GEN,               "CKM_ARIA_KEY_GEN");
addMech(CKM_ARIA_ECB, R)911         addMech(CKM_ARIA_ECB,                   "CKM_ARIA_ECB");
addMech(CKM_ARIA_CBC, R)912         addMech(CKM_ARIA_CBC,                   "CKM_ARIA_CBC");
addMech(CKM_ARIA_MAC, R)913         addMech(CKM_ARIA_MAC,                   "CKM_ARIA_MAC");
addMech(CKM_ARIA_MAC_GENERAL, R)914         addMech(CKM_ARIA_MAC_GENERAL,           "CKM_ARIA_MAC_GENERAL");
addMech(CKM_ARIA_CBC_PAD, R)915         addMech(CKM_ARIA_CBC_PAD,               "CKM_ARIA_CBC_PAD");
addMech(CKM_ARIA_ECB_ENCRYPT_DATA, R)916         addMech(CKM_ARIA_ECB_ENCRYPT_DATA,      "CKM_ARIA_ECB_ENCRYPT_DATA");
addMech(CKM_ARIA_CBC_ENCRYPT_DATA, R)917         addMech(CKM_ARIA_CBC_ENCRYPT_DATA,      "CKM_ARIA_CBC_ENCRYPT_DATA");
918 
addMech(CKM_SEED_KEY_GEN, R)919         addMech(CKM_SEED_KEY_GEN,               "CKM_SEED_KEY_GEN");
addMech(CKM_SEED_ECB, R)920         addMech(CKM_SEED_ECB,                   "CKM_SEED_ECB");
addMech(CKM_SEED_CBC, R)921         addMech(CKM_SEED_CBC,                   "CKM_SEED_CBC");
addMech(CKM_SEED_MAC, R)922         addMech(CKM_SEED_MAC,                   "CKM_SEED_MAC");
addMech(CKM_SEED_MAC_GENERAL, R)923         addMech(CKM_SEED_MAC_GENERAL,           "CKM_SEED_MAC_GENERAL");
addMech(CKM_SEED_CBC_PAD, R)924         addMech(CKM_SEED_CBC_PAD,               "CKM_SEED_CBC_PAD");
addMech(CKM_SEED_ECB_ENCRYPT_DATA, R)925         addMech(CKM_SEED_ECB_ENCRYPT_DATA,      "CKM_SEED_ECB_ENCRYPT_DATA");
addMech(CKM_SEED_CBC_ENCRYPT_DATA, R)926         addMech(CKM_SEED_CBC_ENCRYPT_DATA,      "CKM_SEED_CBC_ENCRYPT_DATA");
927 
addMech(CKM_SKIPJACK_KEY_GEN, R)928         addMech(CKM_SKIPJACK_KEY_GEN,           "CKM_SKIPJACK_KEY_GEN");
addMech(CKM_SKIPJACK_ECB64, R)929         addMech(CKM_SKIPJACK_ECB64,             "CKM_SKIPJACK_ECB64");
addMech(CKM_SKIPJACK_CBC64, R)930         addMech(CKM_SKIPJACK_CBC64,             "CKM_SKIPJACK_CBC64");
addMech(CKM_SKIPJACK_OFB64, R)931         addMech(CKM_SKIPJACK_OFB64,             "CKM_SKIPJACK_OFB64");
addMech(CKM_SKIPJACK_CFB64, R)932         addMech(CKM_SKIPJACK_CFB64,             "CKM_SKIPJACK_CFB64");
addMech(CKM_SKIPJACK_CFB32, R)933         addMech(CKM_SKIPJACK_CFB32,             "CKM_SKIPJACK_CFB32");
addMech(CKM_SKIPJACK_CFB16, R)934         addMech(CKM_SKIPJACK_CFB16,             "CKM_SKIPJACK_CFB16");
addMech(CKM_SKIPJACK_CFB8, R)935         addMech(CKM_SKIPJACK_CFB8,              "CKM_SKIPJACK_CFB8");
addMech(CKM_SKIPJACK_WRAP, R)936         addMech(CKM_SKIPJACK_WRAP,              "CKM_SKIPJACK_WRAP");
addMech(CKM_SKIPJACK_PRIVATE_WRAP, R)937         addMech(CKM_SKIPJACK_PRIVATE_WRAP,      "CKM_SKIPJACK_PRIVATE_WRAP");
addMech(CKM_SKIPJACK_RELAYX, R)938         addMech(CKM_SKIPJACK_RELAYX,            "CKM_SKIPJACK_RELAYX");
addMech(CKM_KEA_KEY_PAIR_GEN, R)939         addMech(CKM_KEA_KEY_PAIR_GEN,           "CKM_KEA_KEY_PAIR_GEN");
addMech(CKM_KEA_KEY_DERIVE, R)940         addMech(CKM_KEA_KEY_DERIVE,             "CKM_KEA_KEY_DERIVE");
addMech(CKM_FORTEZZA_TIMESTAMP, R)941         addMech(CKM_FORTEZZA_TIMESTAMP,         "CKM_FORTEZZA_TIMESTAMP");
addMech(CKM_BATON_KEY_GEN, R)942         addMech(CKM_BATON_KEY_GEN,              "CKM_BATON_KEY_GEN");
addMech(CKM_BATON_ECB128, R)943         addMech(CKM_BATON_ECB128,               "CKM_BATON_ECB128");
addMech(CKM_BATON_ECB96, R)944         addMech(CKM_BATON_ECB96,                "CKM_BATON_ECB96");
addMech(CKM_BATON_CBC128, R)945         addMech(CKM_BATON_CBC128,               "CKM_BATON_CBC128");
addMech(CKM_BATON_COUNTER, R)946         addMech(CKM_BATON_COUNTER,              "CKM_BATON_COUNTER");
addMech(CKM_BATON_SHUFFLE, R)947         addMech(CKM_BATON_SHUFFLE,              "CKM_BATON_SHUFFLE");
addMech(CKM_BATON_WRAP, R)948         addMech(CKM_BATON_WRAP,                 "CKM_BATON_WRAP");
addMech(CKM_EC_KEY_PAIR_GEN, R)949         addMech(CKM_EC_KEY_PAIR_GEN,            "CKM_EC_KEY_PAIR_GEN");
addMech(CKM_EC_KEY_PAIR_GEN_W_EXTRA_BITS, R)950         addMech(CKM_EC_KEY_PAIR_GEN_W_EXTRA_BITS,
951                                             "CKM_EC_KEY_PAIR_GEN_W_EXTRA_BITS");
952 
addMech(CKM_ECDSA, R)953         addMech(CKM_ECDSA,                      "CKM_ECDSA");
addMech(CKM_ECDSA_SHA1, R)954         addMech(CKM_ECDSA_SHA1,                 "CKM_ECDSA_SHA1");
addMech(CKM_ECDSA_SHA224, R)955         addMech(CKM_ECDSA_SHA224,               "CKM_ECDSA_SHA224");
addMech(CKM_ECDSA_SHA256, R)956         addMech(CKM_ECDSA_SHA256,               "CKM_ECDSA_SHA256");
addMech(CKM_ECDSA_SHA384, R)957         addMech(CKM_ECDSA_SHA384,               "CKM_ECDSA_SHA384");
addMech(CKM_ECDSA_SHA512, R)958         addMech(CKM_ECDSA_SHA512,               "CKM_ECDSA_SHA512");
addMech(CKM_ECDSA_SHA3_224, R)959         addMech(CKM_ECDSA_SHA3_224,             "CKM_ECDSA_SHA3_224");
addMech(CKM_ECDSA_SHA3_256, R)960         addMech(CKM_ECDSA_SHA3_256,             "CKM_ECDSA_SHA3_256");
addMech(CKM_ECDSA_SHA3_384, R)961         addMech(CKM_ECDSA_SHA3_384,             "CKM_ECDSA_SHA3_384");
addMech(CKM_ECDSA_SHA3_512, R)962         addMech(CKM_ECDSA_SHA3_512,             "CKM_ECDSA_SHA3_512");
963 
addMech(CKM_ECDH1_DERIVE, R)964         addMech(CKM_ECDH1_DERIVE,               "CKM_ECDH1_DERIVE");
addMech(CKM_ECDH1_COFACTOR_DERIVE, R)965         addMech(CKM_ECDH1_COFACTOR_DERIVE,      "CKM_ECDH1_COFACTOR_DERIVE");
addMech(CKM_ECMQV_DERIVE, R)966         addMech(CKM_ECMQV_DERIVE,               "CKM_ECMQV_DERIVE");
addMech(CKM_ECDH_AES_KEY_WRAP, R)967         addMech(CKM_ECDH_AES_KEY_WRAP,          "CKM_ECDH_AES_KEY_WRAP");
addMech(CKM_RSA_AES_KEY_WRAP, R)968         addMech(CKM_RSA_AES_KEY_WRAP,           "CKM_RSA_AES_KEY_WRAP");
addMech(CKM_EC_EDWARDS_KEY_PAIR_GEN, R)969         addMech(CKM_EC_EDWARDS_KEY_PAIR_GEN,    "CKM_EC_EDWARDS_KEY_PAIR_GEN");
addMech(CKM_EC_MONTGOMERY_KEY_PAIR_GEN, R)970         addMech(CKM_EC_MONTGOMERY_KEY_PAIR_GEN,
971                                             "CKM_EC_MONTGOMERY_KEY_PAIR_GEN");
addMech(CKM_EDDSA, R)972         addMech(CKM_EDDSA,                      "CKM_EDDSA");
973 
addMech(CKM_JUNIPER_KEY_GEN, R)974         addMech(CKM_JUNIPER_KEY_GEN,            "CKM_JUNIPER_KEY_GEN");
addMech(CKM_JUNIPER_ECB128, R)975         addMech(CKM_JUNIPER_ECB128,             "CKM_JUNIPER_ECB128");
addMech(CKM_JUNIPER_CBC128, R)976         addMech(CKM_JUNIPER_CBC128,             "CKM_JUNIPER_CBC128");
addMech(CKM_JUNIPER_COUNTER, R)977         addMech(CKM_JUNIPER_COUNTER,            "CKM_JUNIPER_COUNTER");
addMech(CKM_JUNIPER_SHUFFLE, R)978         addMech(CKM_JUNIPER_SHUFFLE,            "CKM_JUNIPER_SHUFFLE");
addMech(CKM_JUNIPER_WRAP, R)979         addMech(CKM_JUNIPER_WRAP,               "CKM_JUNIPER_WRAP");
addMech(CKM_FASTHASH, R)980         addMech(CKM_FASTHASH,                   "CKM_FASTHASH");
addMech(CKM_AES_XTS, R)981         addMech(CKM_AES_XTS,                    "CKM_AES_XTS");
addMech(CKM_AES_XTS_KEY_GEN, R)982         addMech(CKM_AES_XTS_KEY_GEN,            "CKM_AES_XTS_KEY_GEN");
983 
addMech(CKM_AES_KEY_GEN, R)984         addMech(CKM_AES_KEY_GEN,                "CKM_AES_KEY_GEN");
addMech(CKM_AES_ECB, R)985         addMech(CKM_AES_ECB,                    "CKM_AES_ECB");
addMech(CKM_AES_CBC, R)986         addMech(CKM_AES_CBC,                    "CKM_AES_CBC");
addMech(CKM_AES_MAC, R)987         addMech(CKM_AES_MAC,                    "CKM_AES_MAC");
addMech(CKM_AES_MAC_GENERAL, R)988         addMech(CKM_AES_MAC_GENERAL,            "CKM_AES_MAC_GENERAL");
addMech(CKM_AES_CBC_PAD, R)989         addMech(CKM_AES_CBC_PAD,                "CKM_AES_CBC_PAD");
addMech(CKM_AES_CTR, R)990         addMech(CKM_AES_CTR,                    "CKM_AES_CTR");
addMech(CKM_AES_GCM, R)991         addMech(CKM_AES_GCM,                    "CKM_AES_GCM");
addMech(CKM_AES_CCM, R)992         addMech(CKM_AES_CCM,                    "CKM_AES_CCM");
addMech(CKM_AES_CTS, R)993         addMech(CKM_AES_CTS,                    "CKM_AES_CTS");
addMech(CKM_AES_CMAC, R)994         addMech(CKM_AES_CMAC,                   "CKM_AES_CMAC");
addMech(CKM_AES_CMAC_GENERAL, R)995         addMech(CKM_AES_CMAC_GENERAL,           "CKM_AES_CMAC_GENERAL");
addMech(CKM_AES_XCBC_MAC, R)996         addMech(CKM_AES_XCBC_MAC,               "CKM_AES_XCBC_MAC");
addMech(CKM_AES_XCBC_MAC_96, R)997         addMech(CKM_AES_XCBC_MAC_96,            "CKM_AES_XCBC_MAC_96");
addMech(CKM_AES_GMAC, R)998         addMech(CKM_AES_GMAC,                   "CKM_AES_GMAC");
999 
addMech(CKM_BLOWFISH_KEY_GEN, R)1000         addMech(CKM_BLOWFISH_KEY_GEN,           "CKM_BLOWFISH_KEY_GEN");
addMech(CKM_BLOWFISH_CBC, R)1001         addMech(CKM_BLOWFISH_CBC,               "CKM_BLOWFISH_CBC");
addMech(CKM_TWOFISH_KEY_GEN, R)1002         addMech(CKM_TWOFISH_KEY_GEN,            "CKM_TWOFISH_KEY_GEN");
addMech(CKM_TWOFISH_CBC, R)1003         addMech(CKM_TWOFISH_CBC,                "CKM_TWOFISH_CBC");
addMech(CKM_BLOWFISH_CBC_PAD, R)1004         addMech(CKM_BLOWFISH_CBC_PAD,           "CKM_BLOWFISH_CBC_PAD");
addMech(CKM_TWOFISH_CBC_PAD, R)1005         addMech(CKM_TWOFISH_CBC_PAD,            "CKM_TWOFISH_CBC_PAD");
1006 
addMech(CKM_DES_ECB_ENCRYPT_DATA, R)1007         addMech(CKM_DES_ECB_ENCRYPT_DATA,       "CKM_DES_ECB_ENCRYPT_DATA");
addMech(CKM_DES_CBC_ENCRYPT_DATA, R)1008         addMech(CKM_DES_CBC_ENCRYPT_DATA,       "CKM_DES_CBC_ENCRYPT_DATA");
addMech(CKM_DES3_ECB_ENCRYPT_DATA, R)1009         addMech(CKM_DES3_ECB_ENCRYPT_DATA,      "CKM_DES3_ECB_ENCRYPT_DATA");
addMech(CKM_DES3_CBC_ENCRYPT_DATA, R)1010         addMech(CKM_DES3_CBC_ENCRYPT_DATA,      "CKM_DES3_CBC_ENCRYPT_DATA");
addMech(CKM_AES_ECB_ENCRYPT_DATA, R)1011         addMech(CKM_AES_ECB_ENCRYPT_DATA,       "CKM_AES_ECB_ENCRYPT_DATA");
addMech(CKM_AES_CBC_ENCRYPT_DATA, R)1012         addMech(CKM_AES_CBC_ENCRYPT_DATA,       "CKM_AES_CBC_ENCRYPT_DATA");
1013 
addMech(CKM_GOSTR3410_KEY_PAIR_GEN, R)1014         addMech(CKM_GOSTR3410_KEY_PAIR_GEN,     "CKM_GOSTR3410_KEY_PAIR_GEN");
addMech(CKM_GOSTR3410, R)1015         addMech(CKM_GOSTR3410,                  "CKM_GOSTR3410");
addMech(CKM_GOSTR3410_WITH_GOSTR3411, R)1016         addMech(CKM_GOSTR3410_WITH_GOSTR3411,   "CKM_GOSTR3410_WITH_GOSTR3411");
addMech(CKM_GOSTR3410_KEY_WRAP, R)1017         addMech(CKM_GOSTR3410_KEY_WRAP,         "CKM_GOSTR3410_KEY_WRAP");
addMech(CKM_GOSTR3410_DERIVE, R)1018         addMech(CKM_GOSTR3410_DERIVE,           "CKM_GOSTR3410_DERIVE");
addMech(CKM_GOSTR3411, R)1019         addMech(CKM_GOSTR3411,                  "CKM_GOSTR3411");
addMech(CKM_GOSTR3411_HMAC, R)1020         addMech(CKM_GOSTR3411_HMAC,             "CKM_GOSTR3411_HMAC");
addMech(CKM_GOST28147_KEY_GEN, R)1021         addMech(CKM_GOST28147_KEY_GEN,          "CKM_GOST28147_KEY_GEN");
addMech(CKM_GOST28147_ECB, R)1022         addMech(CKM_GOST28147_ECB,              "CKM_GOST28147_ECB");
addMech(CKM_GOST28147, R)1023         addMech(CKM_GOST28147,                  "CKM_GOST28147");
addMech(CKM_GOST28147_MAC, R)1024         addMech(CKM_GOST28147_MAC,              "CKM_GOST28147_MAC");
addMech(CKM_GOST28147_KEY_WRAP, R)1025         addMech(CKM_GOST28147_KEY_WRAP,         "CKM_GOST28147_KEY_WRAP");
addMech(CKM_CHACHA20_KEY_GEN, R)1026         addMech(CKM_CHACHA20_KEY_GEN,           "CKM_CHACHA20_KEY_GEN");
addMech(CKM_CHACHA20, R)1027         addMech(CKM_CHACHA20,                   "CKM_CHACHA20");
addMech(CKM_POLY1305_KEY_GEN, R)1028         addMech(CKM_POLY1305_KEY_GEN,           "CKM_POLY1305_KEY_GEN");
addMech(CKM_POLY1305, R)1029         addMech(CKM_POLY1305,                   "CKM_POLY1305");
1030 
addMech(CKM_DSA_PARAMETER_GEN, R)1031         addMech(CKM_DSA_PARAMETER_GEN,          "CKM_DSA_PARAMETER_GEN");
addMech(CKM_DH_PKCS_PARAMETER_GEN, R)1032         addMech(CKM_DH_PKCS_PARAMETER_GEN,      "CKM_DH_PKCS_PARAMETER_GEN");
addMech(CKM_X9_42_DH_PARAMETER_GEN, R)1033         addMech(CKM_X9_42_DH_PARAMETER_GEN,     "CKM_X9_42_DH_PARAMETER_GEN");
addMech(CKM_DSA_PROBABLISTIC_PARAMETER_GEN, R)1034         addMech(CKM_DSA_PROBABLISTIC_PARAMETER_GEN,
1035                                                 "CKM_DSA_PROBABLISTIC_PARAMETER_GEN");
addMech(CKM_DSA_SHAWE_TAYLOR_PARAMETER_GEN, R)1036         addMech(CKM_DSA_SHAWE_TAYLOR_PARAMETER_GEN,
1037                                                 "CKM_DSA_SHAWE_TAYLOR_PARAMETER_GEN");
addMech(CKM_DSA_FIPS_G_GEN, R)1038         addMech(CKM_DSA_FIPS_G_GEN,             "CKM_DSA_FIPS_G_GEN");
1039 
addMech(CKM_AES_OFB, R)1040         addMech(CKM_AES_OFB,                    "CKM_AES_OFB");
addMech(CKM_AES_CFB64, R)1041         addMech(CKM_AES_CFB64,                  "CKM_AES_CFB64");
addMech(CKM_AES_CFB8, R)1042         addMech(CKM_AES_CFB8,                   "CKM_AES_CFB8");
addMech(CKM_AES_CFB128, R)1043         addMech(CKM_AES_CFB128,                 "CKM_AES_CFB128");
addMech(CKM_AES_CFB1, R)1044         addMech(CKM_AES_CFB1,                   "CKM_AES_CFB1");
addMech(CKM_AES_KEY_WRAP, R)1045         addMech(CKM_AES_KEY_WRAP,               "CKM_AES_KEY_WRAP");
addMech(CKM_AES_KEY_WRAP_PAD, R)1046         addMech(CKM_AES_KEY_WRAP_PAD,           "CKM_AES_KEY_WRAP_PAD");
addMech(CKM_AES_KEY_WRAP_KWP, R)1047         addMech(CKM_AES_KEY_WRAP_KWP,           "CKM_AES_KEY_WRAP_KWP");
addMech(CKM_RSA_PKCS_TPM_1_1, R)1048         addMech(CKM_RSA_PKCS_TPM_1_1,           "CKM_RSA_PKCS_TPM_1_1");
addMech(CKM_RSA_PKCS_OAEP_TPM_1_1, R)1049         addMech(CKM_RSA_PKCS_OAEP_TPM_1_1,      "CKM_RSA_PKCS_OAEP_TPM_1_1");
addMech(CKM_SHA_1_KEY_GEN, R)1050         addMech(CKM_SHA_1_KEY_GEN,              "CKM_SHA_1_KEY_GEN");
addMech(CKM_SHA224_KEY_GEN, R)1051         addMech(CKM_SHA224_KEY_GEN,             "CKM_SHA224_KEY_GEN");
addMech(CKM_SHA256_KEY_GEN, R)1052         addMech(CKM_SHA256_KEY_GEN,             "CKM_SHA256_KEY_GEN");
addMech(CKM_SHA384_KEY_GEN, R)1053         addMech(CKM_SHA384_KEY_GEN,             "CKM_SHA384_KEY_GEN");
addMech(CKM_SHA512_KEY_GEN, R)1054         addMech(CKM_SHA512_KEY_GEN,             "CKM_SHA512_KEY_GEN");
addMech(CKM_SHA512_224_KEY_GEN, R)1055         addMech(CKM_SHA512_224_KEY_GEN,         "CKM_SHA512_224_KEY_GEN");
addMech(CKM_SHA512_256_KEY_GEN, R)1056         addMech(CKM_SHA512_256_KEY_GEN,         "CKM_SHA512_256_KEY_GEN");
addMech(CKM_SHA512_T_KEY_GEN, R)1057         addMech(CKM_SHA512_T_KEY_GEN,           "CKM_SHA512_T_KEY_GEN");
addMech(CKM_NULL, R)1058         addMech(CKM_NULL,                       "CKM_NULL");
addMech(CKM_BLAKE2B_160, R)1059         addMech(CKM_BLAKE2B_160,                "CKM_BLAKE2B_160");
addMech(CKM_BLAKE2B_160_HMAC, R)1060         addMech(CKM_BLAKE2B_160_HMAC,           "CKM_BLAKE2B_160_HMAC");
addMech(CKM_BLAKE2B_160_HMAC_GENERAL, R)1061         addMech(CKM_BLAKE2B_160_HMAC_GENERAL,   "CKM_BLAKE2B_160_HMAC_GENERAL");
addMech(CKM_BLAKE2B_160_KEY_DERIVE, R)1062         addMech(CKM_BLAKE2B_160_KEY_DERIVE,     "CKM_BLAKE2B_160_KEY_DERIVE");
addMech(CKM_BLAKE2B_160_KEY_GEN, R)1063         addMech(CKM_BLAKE2B_160_KEY_GEN,        "CKM_BLAKE2B_160_KEY_GEN");
addMech(CKM_BLAKE2B_256, R)1064         addMech(CKM_BLAKE2B_256,                "CKM_BLAKE2B_256");
addMech(CKM_BLAKE2B_256_HMAC, R)1065         addMech(CKM_BLAKE2B_256_HMAC,           "CKM_BLAKE2B_256_HMAC");
addMech(CKM_BLAKE2B_256_HMAC_GENERAL, R)1066         addMech(CKM_BLAKE2B_256_HMAC_GENERAL,   "CKM_BLAKE2B_256_HMAC_GENERAL");
addMech(CKM_BLAKE2B_256_KEY_DERIVE, R)1067         addMech(CKM_BLAKE2B_256_KEY_DERIVE,     "CKM_BLAKE2B_256_KEY_DERIVE");
addMech(CKM_BLAKE2B_256_KEY_GEN, R)1068         addMech(CKM_BLAKE2B_256_KEY_GEN,        "CKM_BLAKE2B_256_KEY_GEN");
addMech(CKM_BLAKE2B_384, R)1069         addMech(CKM_BLAKE2B_384,                "CKM_BLAKE2B_384");
addMech(CKM_BLAKE2B_384_HMAC, R)1070         addMech(CKM_BLAKE2B_384_HMAC,           "CKM_BLAKE2B_384_HMAC");
addMech(CKM_BLAKE2B_384_HMAC_GENERAL, R)1071         addMech(CKM_BLAKE2B_384_HMAC_GENERAL,   "CKM_BLAKE2B_384_HMAC_GENERAL");
addMech(CKM_BLAKE2B_384_KEY_DERIVE, R)1072         addMech(CKM_BLAKE2B_384_KEY_DERIVE,     "CKM_BLAKE2B_384_KEY_DERIVE");
addMech(CKM_BLAKE2B_384_KEY_GEN, R)1073         addMech(CKM_BLAKE2B_384_KEY_GEN,        "CKM_BLAKE2B_384_KEY_GEN");
addMech(CKM_BLAKE2B_512, R)1074         addMech(CKM_BLAKE2B_512,                "CKM_BLAKE2B_512");
addMech(CKM_BLAKE2B_512_HMAC, R)1075         addMech(CKM_BLAKE2B_512_HMAC,           "CKM_BLAKE2B_512_HMAC");
addMech(CKM_BLAKE2B_512_HMAC_GENERAL, R)1076         addMech(CKM_BLAKE2B_512_HMAC_GENERAL,   "CKM_BLAKE2B_512_HMAC_GENERAL");
addMech(CKM_BLAKE2B_512_KEY_DERIVE, R)1077         addMech(CKM_BLAKE2B_512_KEY_DERIVE,     "CKM_BLAKE2B_512_KEY_DERIVE");
addMech(CKM_BLAKE2B_512_KEY_GEN, R)1078         addMech(CKM_BLAKE2B_512_KEY_GEN,        "CKM_BLAKE2B_512_KEY_GEN");
addMech(CKM_SALSA20, R)1079         addMech(CKM_SALSA20,                    "CKM_SALSA20");
addMech(CKM_CHACHA20_POLY1305, R)1080         addMech(CKM_CHACHA20_POLY1305,          "CKM_CHACHA20_POLY1305");
addMech(CKM_SALSA20_POLY1305, R)1081         addMech(CKM_SALSA20_POLY1305,           "CKM_SALSA20_POLY1305");
addMech(CKM_X3DH_INITIALIZE, R)1082         addMech(CKM_X3DH_INITIALIZE,            "CKM_X3DH_INITIALIZE");
addMech(CKM_X3DH_RESPOND, R)1083         addMech(CKM_X3DH_RESPOND,               "CKM_X3DH_RESPOND");
addMech(CKM_X2RATCHET_INITIALIZE, R)1084         addMech(CKM_X2RATCHET_INITIALIZE,       "CKM_X2RATCHET_INITIALIZE");
addMech(CKM_X2RATCHET_RESPOND, R)1085         addMech(CKM_X2RATCHET_RESPOND,          "CKM_X2RATCHET_RESPOND");
addMech(CKM_X2RATCHET_ENCRYPT, R)1086         addMech(CKM_X2RATCHET_ENCRYPT,          "CKM_X2RATCHET_ENCRYPT");
addMech(CKM_X2RATCHET_DECRYPT, R)1087         addMech(CKM_X2RATCHET_DECRYPT,          "CKM_X2RATCHET_DECRYPT");
addMech(CKM_XEDDSA, R)1088         addMech(CKM_XEDDSA,                     "CKM_XEDDSA");
addMech(CKM_HKDF_DERIVE, R)1089         addMech(CKM_HKDF_DERIVE,                "CKM_HKDF_DERIVE");
addMech(CKM_HKDF_DATA, R)1090         addMech(CKM_HKDF_DATA,                  "CKM_HKDF_DATA");
addMech(CKM_HKDF_KEY_GEN, R)1091         addMech(CKM_HKDF_KEY_GEN,               "CKM_HKDF_KEY_GEN");
addMech(CKM_SALSA20_KEY_GEN, R)1092         addMech(CKM_SALSA20_KEY_GEN,            "CKM_SALSA20_KEY_GEN");
addMech(CKM_SP800_108_COUNTER_KDF, R)1093         addMech(CKM_SP800_108_COUNTER_KDF,      "CKM_SP800_108_COUNTER_KDF");
addMech(CKM_SP800_108_FEEDBACK_KDF, R)1094         addMech(CKM_SP800_108_FEEDBACK_KDF,     "CKM_SP800_108_FEEDBACK_KDF");
addMech(CKM_SP800_108_DOUBLE_PIPELINE_KDF, R)1095         addMech(CKM_SP800_108_DOUBLE_PIPELINE_KDF,
1096                                          "CKM_SP800_108_DOUBLE_PIPELINE_KDF");
1097 
addMech(CKM_VENDOR_DEFINED, R)1098         addMech(CKM_VENDOR_DEFINED,             "CKM_VENDOR_DEFINED");
1099 
addMech(CKM_NSS_TLS_PRF_GENERAL, R)1100         addMech(CKM_NSS_TLS_PRF_GENERAL,        "CKM_NSS_TLS_PRF_GENERAL");
1101 
addMech(PCKM_SECURERANDOM, R)1102         addMech(PCKM_SECURERANDOM,              "SecureRandom");
addMech(PCKM_KEYSTORE, R)1103         addMech(PCKM_KEYSTORE,                  "KeyStore");
1104 
addHashMech(CKM_SHA_1, R, R, R)1105         addHashMech(CKM_SHA_1,                  "SHA-1", "SHA", "SHA1");
addHashMech(CKM_SHA224, R, R)1106         addHashMech(CKM_SHA224,                 "SHA-224", "SHA224");
addHashMech(CKM_SHA256, R, R)1107         addHashMech(CKM_SHA256,                 "SHA-256", "SHA256");
addHashMech(CKM_SHA384, R, R)1108         addHashMech(CKM_SHA384,                 "SHA-384", "SHA384");
addHashMech(CKM_SHA512, R, R)1109         addHashMech(CKM_SHA512,                 "SHA-512", "SHA512");
addHashMech(CKM_SHA512_224, R, R)1110         addHashMech(CKM_SHA512_224,             "SHA-512/224", "SHA512/224");
addHashMech(CKM_SHA512_256, R, R)1111         addHashMech(CKM_SHA512_256,             "SHA-512/256", "SHA512/256");
addHashMech(CKM_SHA3_224, R)1112         addHashMech(CKM_SHA3_224,               "SHA3-224");
addHashMech(CKM_SHA3_256, R)1113         addHashMech(CKM_SHA3_256,               "SHA3-256");
addHashMech(CKM_SHA3_384, R)1114         addHashMech(CKM_SHA3_384,               "SHA3-384");
addHashMech(CKM_SHA3_512, R)1115         addHashMech(CKM_SHA3_512,               "SHA3-512");
1116 
addKeyType(CKK_RSA, R)1117         addKeyType(CKK_RSA,                     "CKK_RSA");
addKeyType(CKK_DSA, R)1118         addKeyType(CKK_DSA,                     "CKK_DSA");
addKeyType(CKK_DH, R)1119         addKeyType(CKK_DH,                      "CKK_DH");
addKeyType(CKK_EC, R)1120         addKeyType(CKK_EC,                      "CKK_EC");
addKeyType(CKK_X9_42_DH, R)1121         addKeyType(CKK_X9_42_DH,                "CKK_X9_42_DH");
addKeyType(CKK_KEA, R)1122         addKeyType(CKK_KEA,                     "CKK_KEA");
addKeyType(CKK_GENERIC_SECRET, R)1123         addKeyType(CKK_GENERIC_SECRET,          "CKK_GENERIC_SECRET");
addKeyType(CKK_RC2, R)1124         addKeyType(CKK_RC2,                     "CKK_RC2");
addKeyType(CKK_RC4, R)1125         addKeyType(CKK_RC4,                     "CKK_RC4");
addKeyType(CKK_DES, R)1126         addKeyType(CKK_DES,                     "CKK_DES");
addKeyType(CKK_DES2, R)1127         addKeyType(CKK_DES2,                    "CKK_DES2");
addKeyType(CKK_DES3, R)1128         addKeyType(CKK_DES3,                    "CKK_DES3");
addKeyType(CKK_CAST, R)1129         addKeyType(CKK_CAST,                    "CKK_CAST");
addKeyType(CKK_CAST3, R)1130         addKeyType(CKK_CAST3,                   "CKK_CAST3");
addKeyType(CKK_CAST128, R)1131         addKeyType(CKK_CAST128,                 "CKK_CAST128");
addKeyType(CKK_RC5, R)1132         addKeyType(CKK_RC5,                     "CKK_RC5");
addKeyType(CKK_IDEA, R)1133         addKeyType(CKK_IDEA,                    "CKK_IDEA");
addKeyType(CKK_SKIPJACK, R)1134         addKeyType(CKK_SKIPJACK,                "CKK_SKIPJACK");
addKeyType(CKK_BATON, R)1135         addKeyType(CKK_BATON,                   "CKK_BATON");
addKeyType(CKK_JUNIPER, R)1136         addKeyType(CKK_JUNIPER,                 "CKK_JUNIPER");
addKeyType(CKK_CDMF, R)1137         addKeyType(CKK_CDMF,                    "CKK_CDMF");
addKeyType(CKK_AES, R)1138         addKeyType(CKK_AES,                     "CKK_AES");
addKeyType(CKK_BLOWFISH, R)1139         addKeyType(CKK_BLOWFISH,                "CKK_BLOWFISH");
addKeyType(CKK_TWOFISH, R)1140         addKeyType(CKK_TWOFISH,                 "CKK_TWOFISH");
addKeyType(CKK_SECURID, R)1141         addKeyType(CKK_SECURID,                 "CKK_SECURID");
addKeyType(CKK_HOTP, R)1142         addKeyType(CKK_HOTP,                    "CKK_HOTP");
addKeyType(CKK_ACTI, R)1143         addKeyType(CKK_ACTI,                    "CKK_ACTI");
addKeyType(CKK_CAMELLIA, R)1144         addKeyType(CKK_CAMELLIA,                "CKK_CAMELLIA");
addKeyType(CKK_ARIA, R)1145         addKeyType(CKK_ARIA,                    "CKK_ARIA");
addKeyType(CKK_MD5_HMAC, R)1146         addKeyType(CKK_MD5_HMAC,                "CKK_MD5_HMAC");
addKeyType(CKK_SHA_1_HMAC, R)1147         addKeyType(CKK_SHA_1_HMAC,              "CKK_SHA_1_HMAC");
addKeyType(CKK_RIPEMD128_HMAC, R)1148         addKeyType(CKK_RIPEMD128_HMAC,          "CKK_RIPEMD128_HMAC");
addKeyType(CKK_RIPEMD160_HMAC, R)1149         addKeyType(CKK_RIPEMD160_HMAC,          "CKK_RIPEMD160_HMAC");
addKeyType(CKK_SHA256_HMAC, R)1150         addKeyType(CKK_SHA256_HMAC,             "CKK_SHA256_HMAC");
addKeyType(CKK_SHA384_HMAC, R)1151         addKeyType(CKK_SHA384_HMAC,             "CKK_SHA384_HMAC");
addKeyType(CKK_SHA512_HMAC, R)1152         addKeyType(CKK_SHA512_HMAC,             "CKK_SHA512_HMAC");
addKeyType(CKK_SHA224_HMAC, R)1153         addKeyType(CKK_SHA224_HMAC,             "CKK_SHA224_HMAC");
addKeyType(CKK_SEED, R)1154         addKeyType(CKK_SEED,                    "CKK_SEED");
addKeyType(CKK_GOSTR3410, R)1155         addKeyType(CKK_GOSTR3410,               "CKK_GOSTR3410");
addKeyType(CKK_GOSTR3411, R)1156         addKeyType(CKK_GOSTR3411,               "CKK_GOSTR3411");
addKeyType(CKK_GOST28147, R)1157         addKeyType(CKK_GOST28147,               "CKK_GOST28147");
addKeyType(CKK_CHACHA20, R)1158         addKeyType(CKK_CHACHA20,                "CKK_CHACHA20");
addKeyType(CKK_POLY1305, R)1159         addKeyType(CKK_POLY1305,                "CKK_POLY1305");
addKeyType(CKK_AES_XTS, R)1160         addKeyType(CKK_AES_XTS,                 "CKK_AES_XTS");
1161 
addKeyType(CKK_SHA3_224_HMAC, R)1162         addKeyType(CKK_SHA3_224_HMAC,           "CKK_SHA3_224_HMAC");
addKeyType(CKK_SHA3_256_HMAC, R)1163         addKeyType(CKK_SHA3_256_HMAC,           "CKK_SHA3_256_HMAC");
addKeyType(CKK_SHA3_384_HMAC, R)1164         addKeyType(CKK_SHA3_384_HMAC,           "CKK_SHA3_384_HMAC");
addKeyType(CKK_SHA3_512_HMAC, R)1165         addKeyType(CKK_SHA3_512_HMAC,           "CKK_SHA3_512_HMAC");
addKeyType(CKK_BLAKE2B_160_HMAC, R)1166         addKeyType(CKK_BLAKE2B_160_HMAC,        "CKK_BLAKE2B_160_HMAC");
addKeyType(CKK_BLAKE2B_256_HMAC, R)1167         addKeyType(CKK_BLAKE2B_256_HMAC,        "CKK_BLAKE2B_256_HMAC");
addKeyType(CKK_BLAKE2B_384_HMAC, R)1168         addKeyType(CKK_BLAKE2B_384_HMAC,        "CKK_BLAKE2B_384_HMAC");
addKeyType(CKK_BLAKE2B_512_HMAC, R)1169         addKeyType(CKK_BLAKE2B_512_HMAC,        "CKK_BLAKE2B_512_HMAC");
addKeyType(CKK_SALSA20, R)1170         addKeyType(CKK_SALSA20,                 "CKK_SALSA20");
addKeyType(CKK_X2RATCHET, R)1171         addKeyType(CKK_X2RATCHET,               "CKK_X2RATCHET");
addKeyType(CKK_EC_EDWARDS, R)1172         addKeyType(CKK_EC_EDWARDS,              "CKK_EC_EDWARDS");
addKeyType(CKK_EC_MONTGOMERY, R)1173         addKeyType(CKK_EC_MONTGOMERY,           "CKK_EC_MONTGOMERY");
addKeyType(CKK_HKDF, R)1174         addKeyType(CKK_HKDF,                    "CKK_HKDF");
1175 
addKeyType(CKK_SHA512_224_HMAC, R)1176         addKeyType(CKK_SHA512_224_HMAC,         "CKK_SHA512_224_HMAC");
addKeyType(CKK_SHA512_256_HMAC, R)1177         addKeyType(CKK_SHA512_256_HMAC,         "CKK_SHA512_256_HMAC");
addKeyType(CKK_SHA512_T_HMAC, R)1178         addKeyType(CKK_SHA512_T_HMAC,           "CKK_SHA512_T_HMAC");
1179 
addKeyType(CKK_VENDOR_DEFINED, R)1180         addKeyType(CKK_VENDOR_DEFINED,          "CKK_VENDOR_DEFINED");
1181 
addKeyType(PCKK_ANY, R)1182         addKeyType(PCKK_ANY,                    "*");
1183 
addAttribute(CKA_CLASS, R)1184         addAttribute(CKA_CLASS,                 "CKA_CLASS");
addAttribute(CKA_TOKEN, R)1185         addAttribute(CKA_TOKEN,                 "CKA_TOKEN");
addAttribute(CKA_PRIVATE, R)1186         addAttribute(CKA_PRIVATE,               "CKA_PRIVATE");
addAttribute(CKA_LABEL, R)1187         addAttribute(CKA_LABEL,                 "CKA_LABEL");
addAttribute(CKA_UNIQUE_ID, R)1188         addAttribute(CKA_UNIQUE_ID,             "CKA_UNIQUE_ID");
addAttribute(CKA_APPLICATION, R)1189         addAttribute(CKA_APPLICATION,           "CKA_APPLICATION");
addAttribute(CKA_VALUE, R)1190         addAttribute(CKA_VALUE,                 "CKA_VALUE");
addAttribute(CKA_OBJECT_ID, R)1191         addAttribute(CKA_OBJECT_ID,             "CKA_OBJECT_ID");
addAttribute(CKA_CERTIFICATE_TYPE, R)1192         addAttribute(CKA_CERTIFICATE_TYPE,      "CKA_CERTIFICATE_TYPE");
addAttribute(CKA_ISSUER, R)1193         addAttribute(CKA_ISSUER,                "CKA_ISSUER");
addAttribute(CKA_SERIAL_NUMBER, R)1194         addAttribute(CKA_SERIAL_NUMBER,         "CKA_SERIAL_NUMBER");
addAttribute(CKA_AC_ISSUER, R)1195         addAttribute(CKA_AC_ISSUER,             "CKA_AC_ISSUER");
addAttribute(CKA_OWNER, R)1196         addAttribute(CKA_OWNER,                 "CKA_OWNER");
addAttribute(CKA_ATTR_TYPES, R)1197         addAttribute(CKA_ATTR_TYPES,            "CKA_ATTR_TYPES");
addAttribute(CKA_TRUSTED, R)1198         addAttribute(CKA_TRUSTED,               "CKA_TRUSTED");
addAttribute(CKA_CERTIFICATE_CATEGORY, R)1199         addAttribute(CKA_CERTIFICATE_CATEGORY,  "CKA_CERTIFICATE_CATEGORY");
addAttribute(CKA_JAVA_MIDP_SECURITY_DOMAIN, R)1200         addAttribute(CKA_JAVA_MIDP_SECURITY_DOMAIN,
1201                                                 "CKA_JAVA_MIDP_SECURITY_DOMAIN");
addAttribute(CKA_URL, R)1202         addAttribute(CKA_URL,                   "CKA_URL");
addAttribute(CKA_HASH_OF_SUBJECT_PUBLIC_KEY, R)1203         addAttribute(CKA_HASH_OF_SUBJECT_PUBLIC_KEY,
1204                                                 "CKA_HASH_OF_SUBJECT_PUBLIC_KEY");
addAttribute(CKA_HASH_OF_ISSUER_PUBLIC_KEY, R)1205         addAttribute(CKA_HASH_OF_ISSUER_PUBLIC_KEY,
1206                                                 "CKA_HASH_OF_ISSUER_PUBLIC_KEY");
addAttribute(CKA_NAME_HASH_ALGORITHM, R)1207         addAttribute(CKA_NAME_HASH_ALGORITHM,   "CKA_NAME_HASH_ALGORITHM");
addAttribute(CKA_CHECK_VALUE, R)1208         addAttribute(CKA_CHECK_VALUE,           "CKA_CHECK_VALUE");
addAttribute(CKA_KEY_TYPE, R)1209         addAttribute(CKA_KEY_TYPE,              "CKA_KEY_TYPE");
addAttribute(CKA_SUBJECT, R)1210         addAttribute(CKA_SUBJECT,               "CKA_SUBJECT");
addAttribute(CKA_ID, R)1211         addAttribute(CKA_ID,                    "CKA_ID");
addAttribute(CKA_SENSITIVE, R)1212         addAttribute(CKA_SENSITIVE,             "CKA_SENSITIVE");
addAttribute(CKA_ENCRYPT, R)1213         addAttribute(CKA_ENCRYPT,               "CKA_ENCRYPT");
addAttribute(CKA_DECRYPT, R)1214         addAttribute(CKA_DECRYPT,               "CKA_DECRYPT");
addAttribute(CKA_WRAP, R)1215         addAttribute(CKA_WRAP,                  "CKA_WRAP");
addAttribute(CKA_UNWRAP, R)1216         addAttribute(CKA_UNWRAP,                "CKA_UNWRAP");
addAttribute(CKA_SIGN, R)1217         addAttribute(CKA_SIGN,                  "CKA_SIGN");
addAttribute(CKA_SIGN_RECOVER, R)1218         addAttribute(CKA_SIGN_RECOVER,          "CKA_SIGN_RECOVER");
addAttribute(CKA_VERIFY, R)1219         addAttribute(CKA_VERIFY,                "CKA_VERIFY");
addAttribute(CKA_VERIFY_RECOVER, R)1220         addAttribute(CKA_VERIFY_RECOVER,        "CKA_VERIFY_RECOVER");
addAttribute(CKA_DERIVE, R)1221         addAttribute(CKA_DERIVE,                "CKA_DERIVE");
addAttribute(CKA_START_DATE, R)1222         addAttribute(CKA_START_DATE,            "CKA_START_DATE");
addAttribute(CKA_END_DATE, R)1223         addAttribute(CKA_END_DATE,              "CKA_END_DATE");
addAttribute(CKA_MODULUS, R)1224         addAttribute(CKA_MODULUS,               "CKA_MODULUS");
addAttribute(CKA_MODULUS_BITS, R)1225         addAttribute(CKA_MODULUS_BITS,          "CKA_MODULUS_BITS");
addAttribute(CKA_PUBLIC_EXPONENT, R)1226         addAttribute(CKA_PUBLIC_EXPONENT,       "CKA_PUBLIC_EXPONENT");
addAttribute(CKA_PRIVATE_EXPONENT, R)1227         addAttribute(CKA_PRIVATE_EXPONENT,      "CKA_PRIVATE_EXPONENT");
addAttribute(CKA_PRIME_1, R)1228         addAttribute(CKA_PRIME_1,               "CKA_PRIME_1");
addAttribute(CKA_PRIME_2, R)1229         addAttribute(CKA_PRIME_2,               "CKA_PRIME_2");
addAttribute(CKA_EXPONENT_1, R)1230         addAttribute(CKA_EXPONENT_1,            "CKA_EXPONENT_1");
addAttribute(CKA_EXPONENT_2, R)1231         addAttribute(CKA_EXPONENT_2,            "CKA_EXPONENT_2");
addAttribute(CKA_COEFFICIENT, R)1232         addAttribute(CKA_COEFFICIENT,           "CKA_COEFFICIENT");
addAttribute(CKA_PUBLIC_KEY_INFO, R)1233         addAttribute(CKA_PUBLIC_KEY_INFO,       "CKA_PUBLIC_KEY_INFO");
addAttribute(CKA_PRIME, R)1234         addAttribute(CKA_PRIME,                 "CKA_PRIME");
addAttribute(CKA_SUBPRIME, R)1235         addAttribute(CKA_SUBPRIME,              "CKA_SUBPRIME");
addAttribute(CKA_BASE, R)1236         addAttribute(CKA_BASE,                  "CKA_BASE");
addAttribute(CKA_PRIME_BITS, R)1237         addAttribute(CKA_PRIME_BITS,            "CKA_PRIME_BITS");
addAttribute(CKA_SUB_PRIME_BITS, R)1238         addAttribute(CKA_SUB_PRIME_BITS,        "CKA_SUB_PRIME_BITS");
addAttribute(CKA_VALUE_BITS, R)1239         addAttribute(CKA_VALUE_BITS,            "CKA_VALUE_BITS");
addAttribute(CKA_VALUE_LEN, R)1240         addAttribute(CKA_VALUE_LEN,             "CKA_VALUE_LEN");
1241 
addAttribute(CKA_EXTRACTABLE, R)1242         addAttribute(CKA_EXTRACTABLE,           "CKA_EXTRACTABLE");
addAttribute(CKA_LOCAL, R)1243         addAttribute(CKA_LOCAL,                 "CKA_LOCAL");
addAttribute(CKA_NEVER_EXTRACTABLE, R)1244         addAttribute(CKA_NEVER_EXTRACTABLE,     "CKA_NEVER_EXTRACTABLE");
addAttribute(CKA_ALWAYS_SENSITIVE, R)1245         addAttribute(CKA_ALWAYS_SENSITIVE,      "CKA_ALWAYS_SENSITIVE");
1246 
addAttribute(CKA_KEY_GEN_MECHANISM, R)1247         addAttribute(CKA_KEY_GEN_MECHANISM,     "CKA_KEY_GEN_MECHANISM");
addAttribute(CKA_MODIFIABLE, R)1248         addAttribute(CKA_MODIFIABLE,            "CKA_MODIFIABLE");
addAttribute(CKA_COPYABLE, R)1249         addAttribute(CKA_COPYABLE,              "CKA_COPYABLE");
addAttribute(CKA_DESTROYABLE, R)1250         addAttribute(CKA_DESTROYABLE,           "CKA_DESTROYABLE");
1251 
addAttribute(CKA_EC_PARAMS, R)1252         addAttribute(CKA_EC_PARAMS,             "CKA_EC_PARAMS");
addAttribute(CKA_EC_POINT, R)1253         addAttribute(CKA_EC_POINT,              "CKA_EC_POINT");
1254 
addAttribute(CKA_SECONDARY_AUTH, R)1255         addAttribute(CKA_SECONDARY_AUTH,        "CKA_SECONDARY_AUTH");
addAttribute(CKA_AUTH_PIN_FLAGS, R)1256         addAttribute(CKA_AUTH_PIN_FLAGS,        "CKA_AUTH_PIN_FLAGS");
addAttribute(CKA_ALWAYS_AUTHENTICATE, R)1257         addAttribute(CKA_ALWAYS_AUTHENTICATE,   "CKA_ALWAYS_AUTHENTICATE");
addAttribute(CKA_WRAP_WITH_TRUSTED, R)1258         addAttribute(CKA_WRAP_WITH_TRUSTED,     "CKA_WRAP_WITH_TRUSTED");
addAttribute(CKA_WRAP_TEMPLATE, R)1259         addAttribute(CKA_WRAP_TEMPLATE,         "CKA_WRAP_TEMPLATE");
addAttribute(CKA_UNWRAP_TEMPLATE, R)1260         addAttribute(CKA_UNWRAP_TEMPLATE,       "CKA_UNWRAP_TEMPLATE");
addAttribute(CKA_DERIVE_TEMPLATE, R)1261         addAttribute(CKA_DERIVE_TEMPLATE,       "CKA_DERIVE_TEMPLATE");
addAttribute(CKA_OTP_FORMAT, R)1262         addAttribute(CKA_OTP_FORMAT,            "CKA_OTP_FORMAT");
addAttribute(CKA_OTP_LENGTH, R)1263         addAttribute(CKA_OTP_LENGTH,            "CKA_OTP_LENGTH");
addAttribute(CKA_OTP_TIME_INTERVAL, R)1264         addAttribute(CKA_OTP_TIME_INTERVAL,     "CKA_OTP_TIME_INTERVAL");
addAttribute(CKA_OTP_USER_FRIENDLY_MODE,R)1265         addAttribute(CKA_OTP_USER_FRIENDLY_MODE,"CKA_OTP_USER_FRIENDLY_MODE");
addAttribute(CKA_OTP_CHALLENGE_REQUIREMENT, R)1266         addAttribute(CKA_OTP_CHALLENGE_REQUIREMENT,
1267                                                 "CKA_OTP_CHALLENGE_REQUIREMENT");
addAttribute(CKA_OTP_TIME_REQUIREMENT, R)1268         addAttribute(CKA_OTP_TIME_REQUIREMENT,  "CKA_OTP_TIME_REQUIREMENT");
addAttribute(CKA_OTP_COUNTER_REQUIREMENT, R)1269         addAttribute(CKA_OTP_COUNTER_REQUIREMENT,
1270                                                 "CKA_OTP_COUNTER_REQUIREMENT");
addAttribute(CKA_OTP_PIN_REQUIREMENT, R)1271         addAttribute(CKA_OTP_PIN_REQUIREMENT,   "CKA_OTP_PIN_REQUIREMENT");
addAttribute(CKA_OTP_COUNTER, R)1272         addAttribute(CKA_OTP_COUNTER,           "CKA_OTP_COUNTER");
addAttribute(CKA_OTP_TIME, R)1273         addAttribute(CKA_OTP_TIME,              "CKA_OTP_TIME");
addAttribute(CKA_OTP_USER_IDENTIFIER, R)1274         addAttribute(CKA_OTP_USER_IDENTIFIER,   "CKA_OTP_USER_IDENTIFIER");
addAttribute(CKA_OTP_SERVICE_IDENTIFIER,R)1275         addAttribute(CKA_OTP_SERVICE_IDENTIFIER,"CKA_OTP_SERVICE_IDENTIFIER");
addAttribute(CKA_OTP_SERVICE_LOGO, R)1276         addAttribute(CKA_OTP_SERVICE_LOGO,      "CKA_OTP_SERVICE_LOGO");
addAttribute(CKA_OTP_SERVICE_LOGO_TYPE, R)1277         addAttribute(CKA_OTP_SERVICE_LOGO_TYPE, "CKA_OTP_SERVICE_LOGO_TYPE");
addAttribute(CKA_GOSTR3410_PARAMS, R)1278         addAttribute(CKA_GOSTR3410_PARAMS,      "CKA_GOSTR3410_PARAMS");
addAttribute(CKA_GOSTR3411_PARAMS, R)1279         addAttribute(CKA_GOSTR3411_PARAMS,      "CKA_GOSTR3411_PARAMS");
addAttribute(CKA_GOST28147_PARAMS, R)1280         addAttribute(CKA_GOST28147_PARAMS,      "CKA_GOST28147_PARAMS");
1281 
addAttribute(CKA_HW_FEATURE_TYPE, R)1282         addAttribute(CKA_HW_FEATURE_TYPE,       "CKA_HW_FEATURE_TYPE");
addAttribute(CKA_RESET_ON_INIT, R)1283         addAttribute(CKA_RESET_ON_INIT,         "CKA_RESET_ON_INIT");
addAttribute(CKA_HAS_RESET, R)1284         addAttribute(CKA_HAS_RESET,             "CKA_HAS_RESET");
1285 
addAttribute(CKA_PIXEL_X, R)1286         addAttribute(CKA_PIXEL_X,               "CKA_PIXEL_X");
addAttribute(CKA_PIXEL_Y, R)1287         addAttribute(CKA_PIXEL_Y,               "CKA_PIXEL_Y");
addAttribute(CKA_RESOLUTION, R)1288         addAttribute(CKA_RESOLUTION,            "CKA_RESOLUTION");
addAttribute(CKA_CHAR_ROWS, R)1289         addAttribute(CKA_CHAR_ROWS,             "CKA_CHAR_ROWS");
addAttribute(CKA_CHAR_COLUMNS, R)1290         addAttribute(CKA_CHAR_COLUMNS,          "CKA_CHAR_COLUMNS");
addAttribute(CKA_COLOR, R)1291         addAttribute(CKA_COLOR,                 "CKA_COLOR");
addAttribute(CKA_BITS_PER_PIXEL, R)1292         addAttribute(CKA_BITS_PER_PIXEL,        "CKA_BITS_PER_PIXEL");
addAttribute(CKA_CHAR_SETS, R)1293         addAttribute(CKA_CHAR_SETS,             "CKA_CHAR_SETS");
addAttribute(CKA_ENCODING_METHODS, R)1294         addAttribute(CKA_ENCODING_METHODS,      "CKA_ENCODING_METHODS");
addAttribute(CKA_MIME_TYPES, R)1295         addAttribute(CKA_MIME_TYPES,            "CKA_MIME_TYPES");
addAttribute(CKA_MECHANISM_TYPE, R)1296         addAttribute(CKA_MECHANISM_TYPE,        "CKA_MECHANISM_TYPE");
addAttribute(CKA_REQUIRED_CMS_ATTRIBUTES, R)1297         addAttribute(CKA_REQUIRED_CMS_ATTRIBUTES,
1298                                                 "CKA_REQUIRED_CMS_ATTRIBUTES");
addAttribute(CKA_DEFAULT_CMS_ATTRIBUTES,R)1299         addAttribute(CKA_DEFAULT_CMS_ATTRIBUTES,"CKA_DEFAULT_CMS_ATTRIBUTES");
addAttribute(CKA_SUPPORTED_CMS_ATTRIBUTES, R)1300         addAttribute(CKA_SUPPORTED_CMS_ATTRIBUTES,
1301                                                 "CKA_SUPPORTED_CMS_ATTRIBUTES");
addAttribute(CKA_ALLOWED_MECHANISMS, R)1302         addAttribute(CKA_ALLOWED_MECHANISMS,    "CKA_ALLOWED_MECHANISMS");
addAttribute(CKA_PROFILE_ID, R)1303         addAttribute(CKA_PROFILE_ID,            "CKA_PROFILE_ID");
addAttribute(CKA_X2RATCHET_BAG, R)1304         addAttribute(CKA_X2RATCHET_BAG,         "CKA_X2RATCHET_BAG");
addAttribute(CKA_X2RATCHET_BAGSIZE, R)1305         addAttribute(CKA_X2RATCHET_BAGSIZE,     "CKA_X2RATCHET_BAGSIZE");
addAttribute(CKA_X2RATCHET_BOBS1STMSG, R)1306         addAttribute(CKA_X2RATCHET_BOBS1STMSG,  "CKA_X2RATCHET_BOBS1STMSG");
addAttribute(CKA_X2RATCHET_CKR, R)1307         addAttribute(CKA_X2RATCHET_CKR,         "CKA_X2RATCHET_CKR");
addAttribute(CKA_X2RATCHET_CKS, R)1308         addAttribute(CKA_X2RATCHET_CKS,         "CKA_X2RATCHET_CKS");
addAttribute(CKA_X2RATCHET_DHP, R)1309         addAttribute(CKA_X2RATCHET_DHP,         "CKA_X2RATCHET_DHP");
addAttribute(CKA_X2RATCHET_DHR, R)1310         addAttribute(CKA_X2RATCHET_DHR,         "CKA_X2RATCHET_DHR");
addAttribute(CKA_X2RATCHET_DHS, R)1311         addAttribute(CKA_X2RATCHET_DHS,         "CKA_X2RATCHET_DHS");
addAttribute(CKA_X2RATCHET_HKR, R)1312         addAttribute(CKA_X2RATCHET_HKR,         "CKA_X2RATCHET_HKR");
addAttribute(CKA_X2RATCHET_HKS, R)1313         addAttribute(CKA_X2RATCHET_HKS,         "CKA_X2RATCHET_HKS");
addAttribute(CKA_X2RATCHET_ISALICE, R)1314         addAttribute(CKA_X2RATCHET_ISALICE,     "CKA_X2RATCHET_ISALICE");
addAttribute(CKA_X2RATCHET_NHKR, R)1315         addAttribute(CKA_X2RATCHET_NHKR,        "CKA_X2RATCHET_NHKR");
addAttribute(CKA_X2RATCHET_NHKS, R)1316         addAttribute(CKA_X2RATCHET_NHKS,        "CKA_X2RATCHET_NHKS");
addAttribute(CKA_X2RATCHET_NR, R)1317         addAttribute(CKA_X2RATCHET_NR,          "CKA_X2RATCHET_NR");
addAttribute(CKA_X2RATCHET_NS, R)1318         addAttribute(CKA_X2RATCHET_NS,          "CKA_X2RATCHET_NS");
addAttribute(CKA_X2RATCHET_PNS, R)1319         addAttribute(CKA_X2RATCHET_PNS,         "CKA_X2RATCHET_PNS");
addAttribute(CKA_X2RATCHET_RK, R)1320         addAttribute(CKA_X2RATCHET_RK,          "CKA_X2RATCHET_RK");
1321 
addAttribute(CKA_VENDOR_DEFINED, R)1322         addAttribute(CKA_VENDOR_DEFINED,        "CKA_VENDOR_DEFINED");
addAttribute(CKA_NETSCAPE_DB, R)1323         addAttribute(CKA_NETSCAPE_DB,           "CKA_NETSCAPE_DB");
1324 
addAttribute(CKA_NETSCAPE_TRUST_SERVER_AUTH, R)1325         addAttribute(CKA_NETSCAPE_TRUST_SERVER_AUTH,      "CKA_NETSCAPE_TRUST_SERVER_AUTH");
addAttribute(CKA_NETSCAPE_TRUST_CLIENT_AUTH, R)1326         addAttribute(CKA_NETSCAPE_TRUST_CLIENT_AUTH,      "CKA_NETSCAPE_TRUST_CLIENT_AUTH");
addAttribute(CKA_NETSCAPE_TRUST_CODE_SIGNING, R)1327         addAttribute(CKA_NETSCAPE_TRUST_CODE_SIGNING,     "CKA_NETSCAPE_TRUST_CODE_SIGNING");
addAttribute(CKA_NETSCAPE_TRUST_EMAIL_PROTECTION, R)1328         addAttribute(CKA_NETSCAPE_TRUST_EMAIL_PROTECTION, "CKA_NETSCAPE_TRUST_EMAIL_PROTECTION");
addAttribute(CKA_NETSCAPE_CERT_SHA1_HASH, R)1329         addAttribute(CKA_NETSCAPE_CERT_SHA1_HASH,         "CKA_NETSCAPE_CERT_SHA1_HASH");
addAttribute(CKA_NETSCAPE_CERT_MD5_HASH, R)1330         addAttribute(CKA_NETSCAPE_CERT_MD5_HASH,          "CKA_NETSCAPE_CERT_MD5_HASH");
1331 
addObjectClass(CKO_DATA, R)1332         addObjectClass(CKO_DATA,                "CKO_DATA");
addObjectClass(CKO_CERTIFICATE, R)1333         addObjectClass(CKO_CERTIFICATE,         "CKO_CERTIFICATE");
addObjectClass(CKO_PUBLIC_KEY, R)1334         addObjectClass(CKO_PUBLIC_KEY,          "CKO_PUBLIC_KEY");
addObjectClass(CKO_PRIVATE_KEY, R)1335         addObjectClass(CKO_PRIVATE_KEY,         "CKO_PRIVATE_KEY");
addObjectClass(CKO_SECRET_KEY, R)1336         addObjectClass(CKO_SECRET_KEY,          "CKO_SECRET_KEY");
addObjectClass(CKO_HW_FEATURE, R)1337         addObjectClass(CKO_HW_FEATURE,          "CKO_HW_FEATURE");
addObjectClass(CKO_DOMAIN_PARAMETERS, R)1338         addObjectClass(CKO_DOMAIN_PARAMETERS,   "CKO_DOMAIN_PARAMETERS");
addObjectClass(CKO_MECHANISM, R)1339         addObjectClass(CKO_MECHANISM,           "CKO_MECHANISM");
addObjectClass(CKO_OTP_KEY, R)1340         addObjectClass(CKO_OTP_KEY,             "CKO_OTP_KEY");
addObjectClass(CKO_PROFILE, R)1341         addObjectClass(CKO_PROFILE,             "CKO_PROFILE");
addObjectClass(CKO_VENDOR_DEFINED, R)1342         addObjectClass(CKO_VENDOR_DEFINED,      "CKO_VENDOR_DEFINED");
1343 
addObjectClass(PCKO_ANY, R)1344         addObjectClass(PCKO_ANY,                "*");
1345 
addMGF(CKG_MGF1_SHA1, R)1346         addMGF(CKG_MGF1_SHA1,                   "CKG_MGF1_SHA1");
addMGF(CKG_MGF1_SHA256, R)1347         addMGF(CKG_MGF1_SHA256,                 "CKG_MGF1_SHA256");
addMGF(CKG_MGF1_SHA384, R)1348         addMGF(CKG_MGF1_SHA384,                 "CKG_MGF1_SHA384");
addMGF(CKG_MGF1_SHA512, R)1349         addMGF(CKG_MGF1_SHA512,                 "CKG_MGF1_SHA512");
addMGF(CKG_MGF1_SHA224, R)1350         addMGF(CKG_MGF1_SHA224,                 "CKG_MGF1_SHA224");
addMGF(CKG_MGF1_SHA3_224, R)1351         addMGF(CKG_MGF1_SHA3_224,               "CKG_MGF1_SHA3_224");
addMGF(CKG_MGF1_SHA3_256, R)1352         addMGF(CKG_MGF1_SHA3_256,               "CKG_MGF1_SHA3_256");
addMGF(CKG_MGF1_SHA3_384, R)1353         addMGF(CKG_MGF1_SHA3_384,               "CKG_MGF1_SHA3_384");
addMGF(CKG_MGF1_SHA3_512, R)1354         addMGF(CKG_MGF1_SHA3_512,               "CKG_MGF1_SHA3_512");
1355     }
1356 
1357 }
1358