t-support.h 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  1. /* t-support.h - Helper routines for regression tests.
  2. Copyright (C) 2006 g10 Code GmbH
  3. This file is part of scute[1].
  4. [1] Derived from the RSA Security Inc. PKCS #11 Cryptographic Token
  5. Interface (Cryptoki).
  6. Scute is free software; you can redistribute it and/or modify it
  7. under the terms of the GNU General Public License as published by
  8. the Free Software Foundation; either version 2 of the License, or
  9. (at your option) any later version.
  10. Scute is distributed in the hope that it will be useful, but
  11. WITHOUT ANY WARRANTY; without even the implied warranty of
  12. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. General Public License for more details.
  14. You should have received a copy of the GNU General Public License
  15. along with Scute; if not, write to the Free Software Foundation,
  16. Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
  17. In addition, as a special exception, g10 Code GmbH gives permission
  18. to link this library: with the Mozilla Fondations's code for
  19. Mozilla (or with modified versions of it that use the same license
  20. as the "Mozilla" code), and distribute the linked executables. You
  21. must obey the GNU General Public License in all respects for all of
  22. the code used other than "Mozilla". If you modify this file, you
  23. may extend this exception to your version of the file, but you are
  24. not obligated to do so. If you do not wish to do so, delete this
  25. exception statement from your version. */
  26. #include <unistd.h>
  27. #include <errno.h>
  28. #include <stdlib.h>
  29. #include <locale.h>
  30. #include <cryptoki.h>
  31. #define DIM(x) (sizeof (x) / sizeof (x[0]))
  32. /* Check for compiler features. */
  33. #if __GNUC__
  34. #define _GCC_VERSION (__GNUC__ * 10000 \
  35. + __GNUC_MINOR__ * 100 \
  36. + __GNUC_PATCHLEVEL__)
  37. #if _GCC_VERSION > 30100
  38. #define UNUSED __attribute__ ((__unused__))
  39. #endif
  40. #endif
  41. #ifndef UNUSED
  42. #define UNUSED
  43. #endif
  44. const char *msg[] =
  45. {
  46. "OK", "Cancel", "Host memory", "Slot ID invalid", "Flags invalid",
  47. "General error", "Function failed", "Arguments bad", "No event",
  48. "Need to create threads", "Can't lock", "0x0000000b", "0x0000000c",
  49. "0x0000000d", "0x0000000e", "0x0000000f", "Attribute read only",
  50. "Attribute sensitive", "Attribute type invalid", "Attribute value invalid",
  51. "0x00000014", "0x00000015", "0x00000016", "0x00000017", "0x00000018",
  52. "0x00000019", "0x0000001a", "0x0000001b", "0x0000001c", "0x0000001d",
  53. "0x0000001e", "0x0000001f", "Data invalid", "Data length range",
  54. "0x00000022", "0x00000023", "0x00000024", "0x00000025", "0x00000026",
  55. "0x00000027", "0x00000028", "0x00000029", "0x0000002a", "0x0000002b",
  56. "0x0000002c", "0x0000002d", "0x0000002e", "0x0000002f", "Device error",
  57. "Device memory", "Devire removed", "0x00000033", "0x00000034",
  58. "0x00000035", "0x00000036", "0x00000037", "0x00000038", "0x00000039",
  59. "0x0000003a", "0x0000003b", "0x0000003c", "0x0000003d", "0x0000003e",
  60. "0x0000003f", "Encrypted data invalid", "Encrypted data length range",
  61. "0x00000042", "0x00000043", "0x00000044", "0x00000045", "0x00000046",
  62. "0x00000047", "0x00000048", "0x00000049", "0x0000004a", "0x0000004b",
  63. "0x0000004c", "0x0000004d", "0x0000004e", "0x0000004f",
  64. "Function canceled", "Function not parallel",
  65. "0x00000052", "0x00000053", "Function not supported", "0x00000055",
  66. "0x00000056", "0x00000057", "0x00000058", "0x00000059", "0x0000005a",
  67. "0x0000005b", "0x0000005c", "0x0000005d", "0x0000005e", "0x0000005f",
  68. "Key handle invalid", "Key sensitive", "Key size range",
  69. "Key type inconsistent", "Key not needed", "Key changed", "Key needed",
  70. "Key indigestible", "Key function not permitted", "Key not wrappable",
  71. "Key unextractable", "0x0000006b", "0x0000006c", "0x0000006d",
  72. "0x0000006e", "0x0000006f", "Mechanism invalid",
  73. "Mechanism parameter invalid",
  74. "0x00000072", "0x00000073", "0x00000074", "0x00000075", "0x00000076",
  75. "0x00000077", "0x00000078", "0x00000079", "0x0000007a", "0x0000007b",
  76. "0x0000007c", "0x0000007d", "0x0000007e", "0x0000007f",
  77. "Object class inconsistent", "Object class invalid",
  78. "Object handle invalid",
  79. "0x00000083", "0x00000084", "0x00000085", "0x00000086",
  80. "0x00000087", "0x00000088", "0x00000089", "0x0000008a", "0x0000008b",
  81. "0x0000008c", "0x0000008d", "0x0000008e", "0x0000008f",
  82. "Operation active", "Operation not initialized",
  83. "0x00000092", "0x00000093", "0x00000094", "0x00000095", "0x00000096",
  84. "0x00000097", "0x00000098", "0x00000099", "0x0000009a", "0x0000009b",
  85. "0x0000009c", "0x0000009d", "0x0000009e", "0x0000009f",
  86. "PIN incorrect", "PIN invalid", "PIN length range", "PIN expired",
  87. "PIN locked", "0x000000a5", "0x000000a6", "0x000000a7", "0x000000a8",
  88. "0x000000a9", "0x000000aa", "0x000000ab", "0x000000ac", "0x000000ad",
  89. "0x000000ae", "0x000000af",
  90. "Session closed", "Session count", "0x000000b2", "Session handle invalid",
  91. "Session parallel not supported", "Session read only", "Session exists",
  92. "Session read only exists", "Session read write SO exists",
  93. "0x000000b9", "0x000000ba", "0x000000bb", "0x000000bc", "0x000000bd",
  94. "0x000000be", "0x000000bf",
  95. "Signature invalid", "Signature length range",
  96. "0x000000c2", "0x000000c3", "0x000000c4", "0x000000c5", "0x000000c6",
  97. "0x000000c7", "0x000000c8", "0x000000c9", "0x000000ca", "0x000000cb",
  98. "0x000000cc", "0x000000cd", "0x000000ce", "0x000000cf",
  99. "Template incomplete", "Template inconsistent",
  100. "0x000000d2", "0x000000d3", "0x000000d4", "0x000000d5", "0x000000d6",
  101. "0x000000d7", "0x000000d8", "0x000000d9", "0x000000da", "0x000000db",
  102. "0x000000dc", "0x000000dd", "0x000000de", "0x000000df",
  103. "Token not present", "Token not recognized", "Token write protected",
  104. "0x000000e3", "0x000000e4", "0x000000e5", "0x000000e6", "0x000000e7",
  105. "0x000000e8", "0x000000e9", "0x000000ea", "0x000000eb", "0x000000ec",
  106. "0x000000ed", "0x000000ee", "0x000000ef",
  107. "Unwrapping key handle invalid", "Unwrapping key size range",
  108. "Unwrapping key type inconsistent",
  109. "0x000000f3", "0x000000f4", "0x000000f5", "0x000000f6", "0x000000f7",
  110. "0x000000f8", "0x000000f9", "0x000000fa", "0x000000fb", "0x000000fc",
  111. "0x000000fd", "0x000000fe", "0x000000ff",
  112. "User already logged in", "User not logged in", "User PIN not initialized",
  113. "User type invalid", "Another user already logged in",
  114. "User too many types",
  115. "0x00000106", "0x00000107", "0x00000108", "0x00000109", "0x0000010a",
  116. "0x0000010b", "0x0000010c", "0x0000010d", "0x0000010e", "0x0000010f",
  117. "Wrapped key invalid", "0x00000110", "Wrapped key length range",
  118. "Wrapping key handle invalid", "Wrapping key size range",
  119. "Wrapping key type inconsistent",
  120. "0x00000116", "0x00000117", "0x00000118", "0x00000119", "0x0000011a",
  121. "0x0000011b", "0x0000011c", "0x0000011d", "0x0000011e", "0x0000011f",
  122. "Random seed not supported", "No random number generator",
  123. "0x00000122", "0x00000123", "0x00000124", "0x00000125", "0x00000126",
  124. "0x00000127", "0x00000128", "0x00000129", "0x0000012a", "0x0000012b",
  125. "0x0000012c", "0x0000012d", "0x0000012e", "0x0000012f",
  126. "Domain parameters invalid",
  127. "0x00000131", "0x00000132", "0x00000133", "0x00000134", "0x00000135",
  128. "0x00000136", "0x00000137", "0x00000138", "0x00000139", "0x0000013a",
  129. "0x0000013b", "0x0000013c", "0x0000013d", "0x0000013e", "0x0000013f",
  130. "0x00000140", "0x00000141", "0x00000142", "0x00000143", "0x00000144",
  131. "0x00000145", "0x00000146", "0x00000147", "0x00000148", "0x00000149",
  132. "0x0000014a", "0x0000014b", "0x0000014c", "0x0000014d", "0x0000014e",
  133. "0x0000014f",
  134. "Buffer too small",
  135. "0x00000151", "0x00000152", "0x00000153", "0x00000154", "0x00000155",
  136. "0x00000156", "0x00000157", "0x00000158", "0x00000159", "0x0000015a",
  137. "0x0000015b", "0x0000015c", "0x0000015d", "0x0000015e", "0x0000015f",
  138. "Saved state invalid",
  139. "0x00000161", "0x00000162", "0x00000163", "0x00000164", "0x00000165",
  140. "0x00000166", "0x00000167", "0x00000168", "0x00000169", "0x0000016a",
  141. "0x0000016b", "0x0000016c", "0x0000016d", "0x0000016e", "0x0000016f",
  142. "Information sensitive",
  143. "0x00000171", "0x00000172", "0x00000173", "0x00000174", "0x00000175",
  144. "0x00000176", "0x00000177", "0x00000178", "0x00000179", "0x0000017a",
  145. "0x0000017b", "0x0000017c", "0x0000017d", "0x0000017e", "0x0000017f",
  146. "State unsaveable",
  147. "0x00000181", "0x00000182", "0x00000183", "0x00000184", "0x00000185",
  148. "0x00000186", "0x00000187", "0x00000188", "0x00000189", "0x0000018a",
  149. "0x0000018b", "0x0000018c", "0x0000018d", "0x0000018e", "0x0000018f",
  150. "Cryptoki not initialized", "Cryptoki already initialized",
  151. "0x00000192", "0x00000193", "0x00000194", "0x00000195", "0x00000196",
  152. "0x00000197", "0x00000198", "0x00000199", "0x0000019a", "0x0000019b",
  153. "0x0000019c", "0x0000019d", "0x0000019e", "0x0000019f",
  154. "Mutex bad", "Mutex not locked",
  155. "0x000001a2", "0x000001a3", "0x000001a4", "0x000001a5", "0x000001a6",
  156. "0x000001a7", "0x000001a8", "0x000001a9", "0x000001aa", "0x000001ab",
  157. "0x000001ac", "0x000001ad", "0x000001ae", "0x000001af",
  158. "0x000001b0", "0x000001b1", "0x000001b2", "0x000001b3", "0x000001b4",
  159. "0x000001b5", "0x000001b6", "0x000001b7", "0x000001b8", "0x000001b9",
  160. "0x000001ba", "0x000001bb", "0x000001bc", "0x000001bd", "0x000001be",
  161. "0x000001bf",
  162. "0x000001c0", "0x000001c1", "0x000001c2", "0x000001c3", "0x000001c4",
  163. "0x000001c5", "0x000001c6", "0x000001c7", "0x000001c8", "0x000001c9",
  164. "0x000001ca", "0x000001cb", "0x000001cc", "0x000001cd", "0x000001ce",
  165. "0x000001cf",
  166. "0x000001d0", "0x000001d1", "0x000001d2", "0x000001d3", "0x000001d4",
  167. "0x000001d5", "0x000001d6", "0x000001d7", "0x000001d8", "0x000001d9",
  168. "0x000001da", "0x000001db", "0x000001dc", "0x000001dd", "0x000001de",
  169. "0x000001df",
  170. "0x000001e0", "0x000001e1", "0x000001e2", "0x000001e3", "0x000001e4",
  171. "0x000001e5", "0x000001e6", "0x000001e7", "0x000001e8", "0x000001e9",
  172. "0x000001ea", "0x000001eb", "0x000001ec", "0x000001ed", "0x000001ee",
  173. "0x000001ef",
  174. "0x000001f0", "0x000001f1", "0x000001f2", "0x000001f3", "0x000001f4",
  175. "0x000001f5", "0x000001f6", "0x000001f7", "0x000001f8", "0x000001f9",
  176. "0x000001fa", "0x000001fb", "0x000001fc", "0x000001fd", "0x000001fe",
  177. "0x000001ff",
  178. "Function rejected" };
  179. #define ERRMSG(nr) ((nr) == CKR_VENDOR_DEFINED ? "Vendor defined" : \
  180. (((nr) < 0 || (nr) > sizeof (msg) / sizeof (msg[0])) ? \
  181. "(unknown error code)" : msg[(nr)]))
  182. static const char *
  183. mechanism_type_str (CK_MECHANISM_TYPE mechanism_type) UNUSED;
  184. static const char *
  185. mechanism_type_str (CK_MECHANISM_TYPE mechanism_type)
  186. {
  187. switch (mechanism_type)
  188. {
  189. #define CKM_ONE(mechanism) \
  190. case mechanism: \
  191. return #mechanism;
  192. CKM_ONE (CKM_RSA_PKCS_KEY_PAIR_GEN);
  193. CKM_ONE (CKM_RSA_PKCS);
  194. CKM_ONE (CKM_RSA_9796);
  195. CKM_ONE (CKM_RSA_X_509);
  196. CKM_ONE (CKM_MD2_RSA_PKCS);
  197. CKM_ONE (CKM_MD5_RSA_PKCS);
  198. CKM_ONE (CKM_SHA1_RSA_PKCS);
  199. CKM_ONE (CKM_RIPEMD128_RSA_PKCS);
  200. CKM_ONE (CKM_RIPEMD160_RSA_PKCS);
  201. CKM_ONE (CKM_RSA_PKCS_OAEP);
  202. CKM_ONE (CKM_RSA_X9_31_KEY_PAIR_GEN);
  203. CKM_ONE (CKM_RSA_X9_31);
  204. CKM_ONE (CKM_SHA1_RSA_X9_31);
  205. CKM_ONE (CKM_RSA_PKCS_PSS);
  206. CKM_ONE (CKM_SHA1_RSA_PKCS_PSS);
  207. CKM_ONE (CKM_DSA_KEY_PAIR_GEN);
  208. CKM_ONE (CKM_DSA);
  209. CKM_ONE (CKM_DSA_SHA1);
  210. CKM_ONE (CKM_DH_PKCS_KEY_PAIR_GEN);
  211. CKM_ONE (CKM_DH_PKCS_DERIVE);
  212. CKM_ONE (CKM_X9_42_DH_KEY_PAIR_GEN);
  213. CKM_ONE (CKM_X9_42_DH_DERIVE);
  214. CKM_ONE (CKM_X9_42_DH_HYBRID_DERIVE);
  215. CKM_ONE (CKM_X9_42_MQV_DERIVE);
  216. CKM_ONE (CKM_SHA256_RSA_PKCS);
  217. CKM_ONE (CKM_SHA384_RSA_PKCS);
  218. CKM_ONE (CKM_SHA512_RSA_PKCS);
  219. CKM_ONE (CKM_SHA256_RSA_PKCS_PSS);
  220. CKM_ONE (CKM_SHA384_RSA_PKCS_PSS);
  221. CKM_ONE (CKM_SHA512_RSA_PKCS_PSS);
  222. CKM_ONE (CKM_RC2_KEY_GEN);
  223. CKM_ONE (CKM_RC2_ECB);
  224. CKM_ONE (CKM_RC2_CBC);
  225. CKM_ONE (CKM_RC2_MAC);
  226. CKM_ONE (CKM_RC2_MAC_GENERAL);
  227. CKM_ONE (CKM_RC2_CBC_PAD);
  228. CKM_ONE (CKM_RC4_KEY_GEN);
  229. CKM_ONE (CKM_RC4);
  230. CKM_ONE (CKM_DES_KEY_GEN);
  231. CKM_ONE (CKM_DES_ECB);
  232. CKM_ONE (CKM_DES_CBC);
  233. CKM_ONE (CKM_DES_MAC);
  234. CKM_ONE (CKM_DES_MAC_GENERAL);
  235. CKM_ONE (CKM_DES_CBC_PAD);
  236. CKM_ONE (CKM_DES2_KEY_GEN);
  237. CKM_ONE (CKM_DES3_KEY_GEN);
  238. CKM_ONE (CKM_DES3_ECB);
  239. CKM_ONE (CKM_DES3_CBC);
  240. CKM_ONE (CKM_DES3_MAC);
  241. CKM_ONE (CKM_DES3_MAC_GENERAL);
  242. CKM_ONE (CKM_DES3_CBC_PAD);
  243. CKM_ONE (CKM_CDMF_KEY_GEN);
  244. CKM_ONE (CKM_CDMF_ECB);
  245. CKM_ONE (CKM_CDMF_CBC);
  246. CKM_ONE (CKM_CDMF_MAC);
  247. CKM_ONE (CKM_CDMF_MAC_GENERAL);
  248. CKM_ONE (CKM_CDMF_CBC_PAD);
  249. CKM_ONE (CKM_DES_OFB64);
  250. CKM_ONE (CKM_DES_OFB8);
  251. CKM_ONE (CKM_DES_CFB64);
  252. CKM_ONE (CKM_DES_CFB8);
  253. CKM_ONE (CKM_MD2);
  254. CKM_ONE (CKM_MD2_HMAC);
  255. CKM_ONE (CKM_MD2_HMAC_GENERAL);
  256. CKM_ONE (CKM_MD5);
  257. CKM_ONE (CKM_MD5_HMAC);
  258. CKM_ONE (CKM_MD5_HMAC_GENERAL);
  259. CKM_ONE (CKM_SHA_1);
  260. CKM_ONE (CKM_SHA_1_HMAC);
  261. CKM_ONE (CKM_SHA_1_HMAC_GENERAL);
  262. CKM_ONE (CKM_RIPEMD128);
  263. CKM_ONE (CKM_RIPEMD128_HMAC);
  264. CKM_ONE (CKM_RIPEMD128_HMAC_GENERAL);
  265. CKM_ONE (CKM_RIPEMD160);
  266. CKM_ONE (CKM_RIPEMD160_HMAC);
  267. CKM_ONE (CKM_RIPEMD160_HMAC_GENERAL);
  268. CKM_ONE (CKM_SHA256);
  269. CKM_ONE (CKM_SHA256_HMAC);
  270. CKM_ONE (CKM_SHA256_HMAC_GENERAL);
  271. CKM_ONE (CKM_SHA384);
  272. CKM_ONE (CKM_SHA384_HMAC);
  273. CKM_ONE (CKM_SHA384_HMAC_GENERAL);
  274. CKM_ONE (CKM_SHA512);
  275. CKM_ONE (CKM_SHA512_HMAC);
  276. CKM_ONE (CKM_SHA512_HMAC_GENERAL);
  277. CKM_ONE (CKM_CAST_KEY_GEN);
  278. CKM_ONE (CKM_CAST_ECB);
  279. CKM_ONE (CKM_CAST_CBC);
  280. CKM_ONE (CKM_CAST_MAC);
  281. CKM_ONE (CKM_CAST_MAC_GENERAL);
  282. CKM_ONE (CKM_CAST_CBC_PAD);
  283. CKM_ONE (CKM_CAST3_KEY_GEN);
  284. CKM_ONE (CKM_CAST3_ECB);
  285. CKM_ONE (CKM_CAST3_CBC);
  286. CKM_ONE (CKM_CAST3_MAC);
  287. CKM_ONE (CKM_CAST3_MAC_GENERAL);
  288. CKM_ONE (CKM_CAST3_CBC_PAD);
  289. CKM_ONE (CKM_CAST5_KEY_GEN);
  290. CKM_ONE (CKM_CAST5_ECB);
  291. CKM_ONE (CKM_CAST5_CBC);
  292. CKM_ONE (CKM_CAST5_MAC);
  293. CKM_ONE (CKM_CAST5_MAC_GENERAL);
  294. CKM_ONE (CKM_CAST5_CBC_PAD);
  295. CKM_ONE (CKM_RC5_KEY_GEN);
  296. CKM_ONE (CKM_RC5_ECB);
  297. CKM_ONE (CKM_RC5_CBC);
  298. CKM_ONE (CKM_RC5_MAC);
  299. CKM_ONE (CKM_RC5_MAC_GENERAL);
  300. CKM_ONE (CKM_RC5_CBC_PAD);
  301. CKM_ONE (CKM_IDEA_KEY_GEN);
  302. CKM_ONE (CKM_IDEA_ECB);
  303. CKM_ONE (CKM_IDEA_CBC);
  304. CKM_ONE (CKM_IDEA_MAC);
  305. CKM_ONE (CKM_IDEA_MAC_GENERAL);
  306. CKM_ONE (CKM_IDEA_CBC_PAD);
  307. CKM_ONE (CKM_GENERIC_SECRET_KEY_GEN);
  308. CKM_ONE (CKM_CONCATENATE_BASE_AND_KEY);
  309. CKM_ONE (CKM_CONCATENATE_BASE_AND_DATA);
  310. CKM_ONE (CKM_CONCATENATE_DATA_AND_BASE);
  311. CKM_ONE (CKM_XOR_BASE_AND_DATA);
  312. CKM_ONE (CKM_EXTRACT_KEY_FROM_KEY);
  313. CKM_ONE (CKM_SSL3_PRE_MASTER_KEY_GEN);
  314. CKM_ONE (CKM_SSL3_MASTER_KEY_DERIVE);
  315. CKM_ONE (CKM_SSL3_KEY_AND_MAC_DERIVE);
  316. CKM_ONE (CKM_SSL3_MASTER_KEY_DERIVE_DH);
  317. CKM_ONE (CKM_TLS_PRE_MASTER_KEY_GEN);
  318. CKM_ONE (CKM_TLS_MASTER_KEY_DERIVE);
  319. CKM_ONE (CKM_TLS_KEY_AND_MAC_DERIVE);
  320. CKM_ONE (CKM_TLS_MASTER_KEY_DERIVE_DH);
  321. CKM_ONE (CKM_TLS_PRF);
  322. CKM_ONE (CKM_SSL3_MD5_MAC);
  323. CKM_ONE (CKM_SSL3_SHA1_MAC);
  324. CKM_ONE (CKM_MD5_KEY_DERIVATION);
  325. CKM_ONE (CKM_MD2_KEY_DERIVATION);
  326. CKM_ONE (CKM_SHA1_KEY_DERIVATION);
  327. CKM_ONE (CKM_SHA256_KEY_DERIVATION);
  328. CKM_ONE (CKM_SHA384_KEY_DERIVATION);
  329. CKM_ONE (CKM_SHA512_KEY_DERIVATION);
  330. CKM_ONE (CKM_PBE_MD2_DES_CBC);
  331. CKM_ONE (CKM_PBE_MD5_DES_CBC);
  332. CKM_ONE (CKM_PBE_MD5_CAST_CBC);
  333. CKM_ONE (CKM_PBE_MD5_CAST3_CBC);
  334. CKM_ONE (CKM_PBE_MD5_CAST5_CBC);
  335. CKM_ONE (CKM_PBE_SHA1_CAST5_CBC);
  336. CKM_ONE (CKM_PBE_SHA1_RC4_128);
  337. CKM_ONE (CKM_PBE_SHA1_RC4_40);
  338. CKM_ONE (CKM_PBE_SHA1_DES3_EDE_CBC);
  339. CKM_ONE (CKM_PBE_SHA1_DES2_EDE_CBC);
  340. CKM_ONE (CKM_PBE_SHA1_RC2_128_CBC);
  341. CKM_ONE (CKM_PBE_SHA1_RC2_40_CBC);
  342. CKM_ONE (CKM_PKCS5_PBKD2);
  343. CKM_ONE (CKM_PBA_SHA1_WITH_SHA1_HMAC);
  344. CKM_ONE (CKM_WTLS_PRE_MASTER_KEY_GEN);
  345. CKM_ONE (CKM_WTLS_MASTER_KEY_DERIVE);
  346. CKM_ONE (CKM_WTLS_MASTER_KEY_DERIVE_DH_ECC);
  347. CKM_ONE (CKM_WTLS_PRF);
  348. CKM_ONE (CKM_WTLS_SERVER_KEY_AND_MAC_DERIVE);
  349. CKM_ONE (CKM_WTLS_CLIENT_KEY_AND_MAC_DERIVE);
  350. CKM_ONE (CKM_KEY_WRAP_LYNKS);
  351. CKM_ONE (CKM_KEY_WRAP_SET_OAEP);
  352. CKM_ONE (CKM_CMS_SIG);
  353. CKM_ONE (CKM_SKIPJACK_KEY_GEN);
  354. CKM_ONE (CKM_SKIPJACK_ECB64);
  355. CKM_ONE (CKM_SKIPJACK_CBC64);
  356. CKM_ONE (CKM_SKIPJACK_OFB64);
  357. CKM_ONE (CKM_SKIPJACK_CFB64);
  358. CKM_ONE (CKM_SKIPJACK_CFB32);
  359. CKM_ONE (CKM_SKIPJACK_CFB16);
  360. CKM_ONE (CKM_SKIPJACK_CFB8);
  361. CKM_ONE (CKM_SKIPJACK_WRAP);
  362. CKM_ONE (CKM_SKIPJACK_PRIVATE_WRAP);
  363. CKM_ONE (CKM_SKIPJACK_RELAYX);
  364. CKM_ONE (CKM_KEA_KEY_PAIR_GEN);
  365. CKM_ONE (CKM_KEA_KEY_DERIVE);
  366. CKM_ONE (CKM_FORTEZZA_TIMESTAMP);
  367. CKM_ONE (CKM_BATON_KEY_GEN);
  368. CKM_ONE (CKM_BATON_ECB128);
  369. CKM_ONE (CKM_BATON_ECB96);
  370. CKM_ONE (CKM_BATON_CBC128);
  371. CKM_ONE (CKM_BATON_COUNTER);
  372. CKM_ONE (CKM_BATON_SHUFFLE);
  373. CKM_ONE (CKM_BATON_WRAP);
  374. CKM_ONE (CKM_EC_KEY_PAIR_GEN);
  375. CKM_ONE (CKM_ECDSA);
  376. CKM_ONE (CKM_ECDSA_SHA1);
  377. CKM_ONE (CKM_ECDH1_DERIVE);
  378. CKM_ONE (CKM_ECDH1_COFACTOR_DERIVE);
  379. CKM_ONE (CKM_ECMQV_DERIVE);
  380. CKM_ONE (CKM_JUNIPER_KEY_GEN);
  381. CKM_ONE (CKM_JUNIPER_ECB128);
  382. CKM_ONE (CKM_JUNIPER_CBC128);
  383. CKM_ONE (CKM_JUNIPER_COUNTER);
  384. CKM_ONE (CKM_JUNIPER_SHUFFLE);
  385. CKM_ONE (CKM_JUNIPER_WRAP);
  386. CKM_ONE (CKM_FASTHASH);
  387. CKM_ONE (CKM_AES_KEY_GEN);
  388. CKM_ONE (CKM_AES_ECB);
  389. CKM_ONE (CKM_AES_CBC);
  390. CKM_ONE (CKM_AES_MAC);
  391. CKM_ONE (CKM_AES_MAC_GENERAL);
  392. CKM_ONE (CKM_AES_CBC_PAD);
  393. CKM_ONE (CKM_BLOWFISH_KEY_GEN);
  394. CKM_ONE (CKM_BLOWFISH_CBC);
  395. CKM_ONE (CKM_TWOFISH_KEY_GEN);
  396. CKM_ONE (CKM_TWOFISH_CBC);
  397. CKM_ONE (CKM_DES_ECB_ENCRYPT_DATA);
  398. CKM_ONE (CKM_DES_CBC_ENCRYPT_DATA);
  399. CKM_ONE (CKM_DES3_ECB_ENCRYPT_DATA);
  400. CKM_ONE (CKM_DES3_CBC_ENCRYPT_DATA);
  401. CKM_ONE (CKM_AES_ECB_ENCRYPT_DATA);
  402. CKM_ONE (CKM_AES_CBC_ENCRYPT_DATA);
  403. CKM_ONE (CKM_DSA_PARAMETER_GEN);
  404. CKM_ONE (CKM_DH_PKCS_PARAMETER_GEN);
  405. CKM_ONE (CKM_X9_42_DH_PARAMETER_GEN);
  406. CKM_ONE (CKM_VENDOR_DEFINED);
  407. default:
  408. return NULL;
  409. }
  410. }
  411. static const char *session_state_str (CK_STATE state) UNUSED;
  412. static const char *
  413. session_state_str (CK_STATE state)
  414. {
  415. switch (state)
  416. {
  417. #define CKS_ONE(state) \
  418. case state: \
  419. return #state;
  420. CKS_ONE (CKS_RO_PUBLIC_SESSION);
  421. CKS_ONE (CKS_RO_USER_FUNCTIONS);
  422. CKS_ONE (CKS_RW_PUBLIC_SESSION);
  423. CKS_ONE (CKS_RW_USER_FUNCTIONS);
  424. CKS_ONE (CKS_RW_SO_FUNCTIONS);
  425. default:
  426. return NULL;
  427. }
  428. }
  429. #define fail_if_err(err) \
  430. do \
  431. { \
  432. if (err) \
  433. { \
  434. fprintf (stderr, "%s:%d: %s\n", \
  435. __FILE__, __LINE__, ERRMSG(err)); \
  436. exit (1); \
  437. } \
  438. } \
  439. while (0)
  440. #define fail(errmsg) \
  441. do \
  442. { \
  443. if (err) \
  444. { \
  445. fprintf (stderr, "%s:%d: %s\n", \
  446. __FILE__, __LINE__, errmsg); \
  447. exit (1); \
  448. } \
  449. } \
  450. while (0)
  451. void
  452. init_cryptoki (void)
  453. {
  454. CK_RV err;
  455. err = C_Initialize (NULL);
  456. fail_if_err (err);
  457. }