asn1_err.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. /* crypto/asn1/asn1_err.c */
  2. /* ====================================================================
  3. * Copyright (c) 1999 The OpenSSL Project. All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. *
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. *
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in
  14. * the documentation and/or other materials provided with the
  15. * distribution.
  16. *
  17. * 3. All advertising materials mentioning features or use of this
  18. * software must display the following acknowledgment:
  19. * "This product includes software developed by the OpenSSL Project
  20. * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
  21. *
  22. * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
  23. * endorse or promote products derived from this software without
  24. * prior written permission. For written permission, please contact
  25. * openssl-core@OpenSSL.org.
  26. *
  27. * 5. Products derived from this software may not be called "OpenSSL"
  28. * nor may "OpenSSL" appear in their names without prior written
  29. * permission of the OpenSSL Project.
  30. *
  31. * 6. Redistributions of any form whatsoever must retain the following
  32. * acknowledgment:
  33. * "This product includes software developed by the OpenSSL Project
  34. * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
  35. *
  36. * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
  37. * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  38. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  39. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
  40. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  41. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  42. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  43. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  44. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  45. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  46. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  47. * OF THE POSSIBILITY OF SUCH DAMAGE.
  48. * ====================================================================
  49. *
  50. * This product includes cryptographic software written by Eric Young
  51. * (eay@cryptsoft.com). This product includes software written by Tim
  52. * Hudson (tjh@cryptsoft.com).
  53. *
  54. */
  55. /* NOTE: this file was auto generated by the mkerr.pl script: any changes
  56. * made to it will be overwritten when the script next updates this file,
  57. * only reason strings will be preserved.
  58. */
  59. #include <stdio.h>
  60. #include <openssl/err.h>
  61. #include <openssl/asn1.h>
  62. /* BEGIN ERROR CODES */
  63. #ifndef OPENSSL_NO_ERR
  64. static ERR_STRING_DATA ASN1_str_functs[]=
  65. {
  66. {ERR_PACK(0,ASN1_F_A2D_ASN1_OBJECT,0), "a2d_ASN1_OBJECT"},
  67. {ERR_PACK(0,ASN1_F_A2I_ASN1_ENUMERATED,0), "a2i_ASN1_ENUMERATED"},
  68. {ERR_PACK(0,ASN1_F_A2I_ASN1_INTEGER,0), "a2i_ASN1_INTEGER"},
  69. {ERR_PACK(0,ASN1_F_A2I_ASN1_STRING,0), "a2i_ASN1_STRING"},
  70. {ERR_PACK(0,ASN1_F_ASN1_CHECK_TLEN,0), "ASN1_CHECK_TLEN"},
  71. {ERR_PACK(0,ASN1_F_ASN1_COLLATE_PRIMITIVE,0), "ASN1_COLLATE_PRIMITIVE"},
  72. {ERR_PACK(0,ASN1_F_ASN1_COLLECT,0), "ASN1_COLLECT"},
  73. {ERR_PACK(0,ASN1_F_ASN1_D2I_BIO,0), "ASN1_d2i_bio"},
  74. {ERR_PACK(0,ASN1_F_ASN1_D2I_EX_PRIMITIVE,0), "ASN1_D2I_EX_PRIMITIVE"},
  75. {ERR_PACK(0,ASN1_F_ASN1_D2I_FP,0), "ASN1_d2i_fp"},
  76. {ERR_PACK(0,ASN1_F_ASN1_DO_ADB,0), "ASN1_DO_ADB"},
  77. {ERR_PACK(0,ASN1_F_ASN1_DUP,0), "ASN1_dup"},
  78. {ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_SET,0), "ASN1_ENUMERATED_set"},
  79. {ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_TO_BN,0), "ASN1_ENUMERATED_to_BN"},
  80. {ERR_PACK(0,ASN1_F_ASN1_GET_OBJECT,0), "ASN1_get_object"},
  81. {ERR_PACK(0,ASN1_F_ASN1_HEADER_NEW,0), "ASN1_HEADER_new"},
  82. {ERR_PACK(0,ASN1_F_ASN1_I2D_BIO,0), "ASN1_i2d_bio"},
  83. {ERR_PACK(0,ASN1_F_ASN1_I2D_FP,0), "ASN1_i2d_fp"},
  84. {ERR_PACK(0,ASN1_F_ASN1_INTEGER_SET,0), "ASN1_INTEGER_set"},
  85. {ERR_PACK(0,ASN1_F_ASN1_INTEGER_TO_BN,0), "ASN1_INTEGER_to_BN"},
  86. {ERR_PACK(0,ASN1_F_ASN1_ITEM_EX_D2I,0), "ASN1_ITEM_EX_D2I"},
  87. {ERR_PACK(0,ASN1_F_ASN1_ITEM_NEW,0), "ASN1_item_new"},
  88. {ERR_PACK(0,ASN1_F_ASN1_MBSTRING_COPY,0), "ASN1_mbstring_copy"},
  89. {ERR_PACK(0,ASN1_F_ASN1_OBJECT_NEW,0), "ASN1_OBJECT_new"},
  90. {ERR_PACK(0,ASN1_F_ASN1_PACK_STRING,0), "ASN1_pack_string"},
  91. {ERR_PACK(0,ASN1_F_ASN1_PBE_SET,0), "ASN1_PBE_SET"},
  92. {ERR_PACK(0,ASN1_F_ASN1_SEQ_PACK,0), "ASN1_seq_pack"},
  93. {ERR_PACK(0,ASN1_F_ASN1_SEQ_UNPACK,0), "ASN1_seq_unpack"},
  94. {ERR_PACK(0,ASN1_F_ASN1_SIGN,0), "ASN1_sign"},
  95. {ERR_PACK(0,ASN1_F_ASN1_STRING_TABLE_ADD,0), "ASN1_STRING_TABLE_add"},
  96. {ERR_PACK(0,ASN1_F_ASN1_STRING_TYPE_NEW,0), "ASN1_STRING_type_new"},
  97. {ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_D2I,0), "ASN1_TEMPLATE_D2I"},
  98. {ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_EX_D2I,0), "ASN1_TEMPLATE_EX_D2I"},
  99. {ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_NEW,0), "ASN1_TEMPLATE_NEW"},
  100. {ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING,0), "ASN1_TYPE_get_int_octetstring"},
  101. {ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_OCTETSTRING,0), "ASN1_TYPE_get_octetstring"},
  102. {ERR_PACK(0,ASN1_F_ASN1_UNPACK_STRING,0), "ASN1_unpack_string"},
  103. {ERR_PACK(0,ASN1_F_ASN1_VERIFY,0), "ASN1_verify"},
  104. {ERR_PACK(0,ASN1_F_BN_TO_ASN1_ENUMERATED,0), "BN_to_ASN1_ENUMERATED"},
  105. {ERR_PACK(0,ASN1_F_BN_TO_ASN1_INTEGER,0), "BN_to_ASN1_INTEGER"},
  106. {ERR_PACK(0,ASN1_F_COLLECT_DATA,0), "COLLECT_DATA"},
  107. {ERR_PACK(0,ASN1_F_D2I_ASN1_BIT_STRING,0), "D2I_ASN1_BIT_STRING"},
  108. {ERR_PACK(0,ASN1_F_D2I_ASN1_BOOLEAN,0), "d2i_ASN1_BOOLEAN"},
  109. {ERR_PACK(0,ASN1_F_D2I_ASN1_BYTES,0), "d2i_ASN1_bytes"},
  110. {ERR_PACK(0,ASN1_F_D2I_ASN1_GENERALIZEDTIME,0), "D2I_ASN1_GENERALIZEDTIME"},
  111. {ERR_PACK(0,ASN1_F_D2I_ASN1_HEADER,0), "d2i_ASN1_HEADER"},
  112. {ERR_PACK(0,ASN1_F_D2I_ASN1_INTEGER,0), "D2I_ASN1_INTEGER"},
  113. {ERR_PACK(0,ASN1_F_D2I_ASN1_OBJECT,0), "d2i_ASN1_OBJECT"},
  114. {ERR_PACK(0,ASN1_F_D2I_ASN1_SET,0), "d2i_ASN1_SET"},
  115. {ERR_PACK(0,ASN1_F_D2I_ASN1_TYPE_BYTES,0), "d2i_ASN1_type_bytes"},
  116. {ERR_PACK(0,ASN1_F_D2I_ASN1_UINTEGER,0), "d2i_ASN1_UINTEGER"},
  117. {ERR_PACK(0,ASN1_F_D2I_ASN1_UTCTIME,0), "D2I_ASN1_UTCTIME"},
  118. {ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA,0), "d2i_Netscape_RSA"},
  119. {ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA_2,0), "D2I_NETSCAPE_RSA_2"},
  120. {ERR_PACK(0,ASN1_F_D2I_PRIVATEKEY,0), "d2i_PrivateKey"},
  121. {ERR_PACK(0,ASN1_F_D2I_PUBLICKEY,0), "d2i_PublicKey"},
  122. {ERR_PACK(0,ASN1_F_D2I_X509,0), "D2I_X509"},
  123. {ERR_PACK(0,ASN1_F_D2I_X509_CINF,0), "D2I_X509_CINF"},
  124. {ERR_PACK(0,ASN1_F_D2I_X509_NAME,0), "D2I_X509_NAME"},
  125. {ERR_PACK(0,ASN1_F_D2I_X509_PKEY,0), "d2i_X509_PKEY"},
  126. {ERR_PACK(0,ASN1_F_I2D_ASN1_TIME,0), "I2D_ASN1_TIME"},
  127. {ERR_PACK(0,ASN1_F_I2D_DSA_PUBKEY,0), "i2d_DSA_PUBKEY"},
  128. {ERR_PACK(0,ASN1_F_I2D_NETSCAPE_RSA,0), "i2d_Netscape_RSA"},
  129. {ERR_PACK(0,ASN1_F_I2D_PRIVATEKEY,0), "i2d_PrivateKey"},
  130. {ERR_PACK(0,ASN1_F_I2D_PUBLICKEY,0), "i2d_PublicKey"},
  131. {ERR_PACK(0,ASN1_F_I2D_RSA_PUBKEY,0), "i2d_RSA_PUBKEY"},
  132. {ERR_PACK(0,ASN1_F_LONG_C2I,0), "LONG_C2I"},
  133. {ERR_PACK(0,ASN1_F_PKCS5_PBE2_SET,0), "PKCS5_pbe2_set"},
  134. {ERR_PACK(0,ASN1_F_X509_CINF_NEW,0), "X509_CINF_NEW"},
  135. {ERR_PACK(0,ASN1_F_X509_CRL_ADD0_REVOKED,0), "X509_CRL_add0_revoked"},
  136. {ERR_PACK(0,ASN1_F_X509_INFO_NEW,0), "X509_INFO_new"},
  137. {ERR_PACK(0,ASN1_F_X509_NAME_NEW,0), "X509_NAME_NEW"},
  138. {ERR_PACK(0,ASN1_F_X509_NEW,0), "X509_NEW"},
  139. {ERR_PACK(0,ASN1_F_X509_PKEY_NEW,0), "X509_PKEY_new"},
  140. {0,NULL}
  141. };
  142. static ERR_STRING_DATA ASN1_str_reasons[]=
  143. {
  144. {ASN1_R_AUX_ERROR ,"aux error"},
  145. {ASN1_R_BAD_CLASS ,"bad class"},
  146. {ASN1_R_BAD_OBJECT_HEADER ,"bad object header"},
  147. {ASN1_R_BAD_PASSWORD_READ ,"bad password read"},
  148. {ASN1_R_BAD_TAG ,"bad tag"},
  149. {ASN1_R_BN_LIB ,"bn lib"},
  150. {ASN1_R_BOOLEAN_IS_WRONG_LENGTH ,"boolean is wrong length"},
  151. {ASN1_R_BUFFER_TOO_SMALL ,"buffer too small"},
  152. {ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER ,"cipher has no object identifier"},
  153. {ASN1_R_DATA_IS_WRONG ,"data is wrong"},
  154. {ASN1_R_DECODE_ERROR ,"decode error"},
  155. {ASN1_R_DECODING_ERROR ,"decoding error"},
  156. {ASN1_R_ENCODE_ERROR ,"encode error"},
  157. {ASN1_R_ERROR_PARSING_SET_ELEMENT ,"error parsing set element"},
  158. {ASN1_R_ERROR_SETTING_CIPHER_PARAMS ,"error setting cipher params"},
  159. {ASN1_R_EXPECTING_AN_INTEGER ,"expecting an integer"},
  160. {ASN1_R_EXPECTING_AN_OBJECT ,"expecting an object"},
  161. {ASN1_R_EXPECTING_A_BOOLEAN ,"expecting a boolean"},
  162. {ASN1_R_EXPECTING_A_TIME ,"expecting a time"},
  163. {ASN1_R_EXPLICIT_LENGTH_MISMATCH ,"explicit length mismatch"},
  164. {ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED ,"explicit tag not constructed"},
  165. {ASN1_R_FIELD_MISSING ,"field missing"},
  166. {ASN1_R_FIRST_NUM_TOO_LARGE ,"first num too large"},
  167. {ASN1_R_HEADER_TOO_LONG ,"header too long"},
  168. {ASN1_R_ILLEGAL_CHARACTERS ,"illegal characters"},
  169. {ASN1_R_ILLEGAL_NULL ,"illegal null"},
  170. {ASN1_R_ILLEGAL_OPTIONAL_ANY ,"illegal optional any"},
  171. {ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE ,"illegal options on item template"},
  172. {ASN1_R_ILLEGAL_TAGGED_ANY ,"illegal tagged any"},
  173. {ASN1_R_INTEGER_TOO_LARGE_FOR_LONG ,"integer too large for long"},
  174. {ASN1_R_INVALID_BMPSTRING_LENGTH ,"invalid bmpstring length"},
  175. {ASN1_R_INVALID_DIGIT ,"invalid digit"},
  176. {ASN1_R_INVALID_SEPARATOR ,"invalid separator"},
  177. {ASN1_R_INVALID_TIME_FORMAT ,"invalid time format"},
  178. {ASN1_R_INVALID_UNIVERSALSTRING_LENGTH ,"invalid universalstring length"},
  179. {ASN1_R_INVALID_UTF8STRING ,"invalid utf8string"},
  180. {ASN1_R_IV_TOO_LARGE ,"iv too large"},
  181. {ASN1_R_LENGTH_ERROR ,"length error"},
  182. {ASN1_R_MISSING_EOC ,"missing eoc"},
  183. {ASN1_R_MISSING_SECOND_NUMBER ,"missing second number"},
  184. {ASN1_R_MSTRING_NOT_UNIVERSAL ,"mstring not universal"},
  185. {ASN1_R_MSTRING_WRONG_TAG ,"mstring wrong tag"},
  186. {ASN1_R_NON_HEX_CHARACTERS ,"non hex characters"},
  187. {ASN1_R_NOT_ENOUGH_DATA ,"not enough data"},
  188. {ASN1_R_NO_MATCHING_CHOICE_TYPE ,"no matching choice type"},
  189. {ASN1_R_NULL_IS_WRONG_LENGTH ,"null is wrong length"},
  190. {ASN1_R_ODD_NUMBER_OF_CHARS ,"odd number of chars"},
  191. {ASN1_R_PRIVATE_KEY_HEADER_MISSING ,"private key header missing"},
  192. {ASN1_R_SECOND_NUMBER_TOO_LARGE ,"second number too large"},
  193. {ASN1_R_SEQUENCE_LENGTH_MISMATCH ,"sequence length mismatch"},
  194. {ASN1_R_SEQUENCE_NOT_CONSTRUCTED ,"sequence not constructed"},
  195. {ASN1_R_SHORT_LINE ,"short line"},
  196. {ASN1_R_STRING_TOO_LONG ,"string too long"},
  197. {ASN1_R_STRING_TOO_SHORT ,"string too short"},
  198. {ASN1_R_TAG_VALUE_TOO_HIGH ,"tag value too high"},
  199. {ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD,"the asn1 object identifier is not known for this md"},
  200. {ASN1_R_TOO_LONG ,"too long"},
  201. {ASN1_R_TYPE_NOT_CONSTRUCTED ,"type not constructed"},
  202. {ASN1_R_UNABLE_TO_DECODE_RSA_KEY ,"unable to decode rsa key"},
  203. {ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY ,"unable to decode rsa private key"},
  204. {ASN1_R_UNEXPECTED_EOC ,"unexpected eoc"},
  205. {ASN1_R_UNKNOWN_FORMAT ,"unknown format"},
  206. {ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM ,"unknown message digest algorithm"},
  207. {ASN1_R_UNKNOWN_OBJECT_TYPE ,"unknown object type"},
  208. {ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE ,"unknown public key type"},
  209. {ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE ,"unsupported any defined by type"},
  210. {ASN1_R_UNSUPPORTED_CIPHER ,"unsupported cipher"},
  211. {ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM ,"unsupported encryption algorithm"},
  212. {ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE ,"unsupported public key type"},
  213. {ASN1_R_WRONG_TAG ,"wrong tag"},
  214. {ASN1_R_WRONG_TYPE ,"wrong type"},
  215. {0,NULL}
  216. };
  217. #endif
  218. void ERR_load_ASN1_strings(void)
  219. {
  220. static int init=1;
  221. if (init)
  222. {
  223. init=0;
  224. #ifndef OPENSSL_NO_ERR
  225. ERR_load_strings(ERR_LIB_ASN1,ASN1_str_functs);
  226. ERR_load_strings(ERR_LIB_ASN1,ASN1_str_reasons);
  227. #endif
  228. }
  229. }