1/* crypto/asn1/asn1_err.c */
2/* ====================================================================
3 * Copyright (c) 1999-2004 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
56/* NOTE: this file was auto generated by the mkerr.pl script: any changes
57 * made to it will be overwritten when the script next updates this file,
58 * only reason strings will be preserved.
59 */
60
61#include <stdio.h>
62#include <openssl/err.h>
63#include <openssl/asn1.h>
64
65/* BEGIN ERROR CODES */
66#ifndef OPENSSL_NO_ERR
67static ERR_STRING_DATA ASN1_str_functs[]=
68	{
69{ERR_PACK(0,ASN1_F_A2D_ASN1_OBJECT,0),	"a2d_ASN1_OBJECT"},
70{ERR_PACK(0,ASN1_F_A2I_ASN1_ENUMERATED,0),	"a2i_ASN1_ENUMERATED"},
71{ERR_PACK(0,ASN1_F_A2I_ASN1_INTEGER,0),	"a2i_ASN1_INTEGER"},
72{ERR_PACK(0,ASN1_F_A2I_ASN1_STRING,0),	"a2i_ASN1_STRING"},
73{ERR_PACK(0,ASN1_F_ASN1_BIT_STRING_SET_BIT,0),	"ASN1_BIT_STRING_set_bit"},
74{ERR_PACK(0,ASN1_F_ASN1_CHECK_TLEN,0),	"ASN1_CHECK_TLEN"},
75{ERR_PACK(0,ASN1_F_ASN1_COLLATE_PRIMITIVE,0),	"ASN1_COLLATE_PRIMITIVE"},
76{ERR_PACK(0,ASN1_F_ASN1_COLLECT,0),	"ASN1_COLLECT"},
77{ERR_PACK(0,ASN1_F_ASN1_D2I_BIO,0),	"ASN1_d2i_bio"},
78{ERR_PACK(0,ASN1_F_ASN1_D2I_EX_PRIMITIVE,0),	"ASN1_D2I_EX_PRIMITIVE"},
79{ERR_PACK(0,ASN1_F_ASN1_D2I_FP,0),	"ASN1_d2i_fp"},
80{ERR_PACK(0,ASN1_F_ASN1_DIGEST,0),	"ASN1_digest"},
81{ERR_PACK(0,ASN1_F_ASN1_DO_ADB,0),	"ASN1_DO_ADB"},
82{ERR_PACK(0,ASN1_F_ASN1_DUP,0),	"ASN1_dup"},
83{ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_SET,0),	"ASN1_ENUMERATED_set"},
84{ERR_PACK(0,ASN1_F_ASN1_ENUMERATED_TO_BN,0),	"ASN1_ENUMERATED_to_BN"},
85{ERR_PACK(0,ASN1_F_ASN1_GENERALIZEDTIME_SET,0),	"ASN1_GENERALIZEDTIME_set"},
86{ERR_PACK(0,ASN1_F_ASN1_GET_OBJECT,0),	"ASN1_get_object"},
87{ERR_PACK(0,ASN1_F_ASN1_HEADER_NEW,0),	"ASN1_HEADER_new"},
88{ERR_PACK(0,ASN1_F_ASN1_I2D_BIO,0),	"ASN1_i2d_bio"},
89{ERR_PACK(0,ASN1_F_ASN1_I2D_FP,0),	"ASN1_i2d_fp"},
90{ERR_PACK(0,ASN1_F_ASN1_INTEGER_SET,0),	"ASN1_INTEGER_set"},
91{ERR_PACK(0,ASN1_F_ASN1_INTEGER_TO_BN,0),	"ASN1_INTEGER_to_BN"},
92{ERR_PACK(0,ASN1_F_ASN1_ITEM_EX_D2I,0),	"ASN1_ITEM_EX_D2I"},
93{ERR_PACK(0,ASN1_F_ASN1_ITEM_NEW,0),	"ASN1_item_new"},
94{ERR_PACK(0,ASN1_F_ASN1_MBSTRING_COPY,0),	"ASN1_mbstring_copy"},
95{ERR_PACK(0,ASN1_F_ASN1_OBJECT_NEW,0),	"ASN1_OBJECT_new"},
96{ERR_PACK(0,ASN1_F_ASN1_PACK_STRING,0),	"ASN1_pack_string"},
97{ERR_PACK(0,ASN1_F_ASN1_PBE_SET,0),	"ASN1_PBE_SET"},
98{ERR_PACK(0,ASN1_F_ASN1_SEQ_PACK,0),	"ASN1_seq_pack"},
99{ERR_PACK(0,ASN1_F_ASN1_SEQ_UNPACK,0),	"ASN1_seq_unpack"},
100{ERR_PACK(0,ASN1_F_ASN1_SIGN,0),	"ASN1_sign"},
101{ERR_PACK(0,ASN1_F_ASN1_STRING_SET,0),	"ASN1_STRING_set"},
102{ERR_PACK(0,ASN1_F_ASN1_STRING_TABLE_ADD,0),	"ASN1_STRING_TABLE_add"},
103{ERR_PACK(0,ASN1_F_ASN1_STRING_TYPE_NEW,0),	"ASN1_STRING_type_new"},
104{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_D2I,0),	"ASN1_TEMPLATE_D2I"},
105{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_EX_D2I,0),	"ASN1_TEMPLATE_EX_D2I"},
106{ERR_PACK(0,ASN1_F_ASN1_TEMPLATE_NEW,0),	"ASN1_TEMPLATE_NEW"},
107{ERR_PACK(0,ASN1_F_ASN1_TIME_SET,0),	"ASN1_TIME_set"},
108{ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING,0),	"ASN1_TYPE_get_int_octetstring"},
109{ERR_PACK(0,ASN1_F_ASN1_TYPE_GET_OCTETSTRING,0),	"ASN1_TYPE_get_octetstring"},
110{ERR_PACK(0,ASN1_F_ASN1_UNPACK_STRING,0),	"ASN1_unpack_string"},
111{ERR_PACK(0,ASN1_F_ASN1_UTCTIME_SET,0),	"ASN1_UTCTIME_set"},
112{ERR_PACK(0,ASN1_F_ASN1_VERIFY,0),	"ASN1_verify"},
113{ERR_PACK(0,ASN1_F_BN_TO_ASN1_ENUMERATED,0),	"BN_to_ASN1_ENUMERATED"},
114{ERR_PACK(0,ASN1_F_BN_TO_ASN1_INTEGER,0),	"BN_to_ASN1_INTEGER"},
115{ERR_PACK(0,ASN1_F_COLLECT_DATA,0),	"COLLECT_DATA"},
116{ERR_PACK(0,ASN1_F_D2I_ASN1_BIT_STRING,0),	"D2I_ASN1_BIT_STRING"},
117{ERR_PACK(0,ASN1_F_D2I_ASN1_BOOLEAN,0),	"d2i_ASN1_BOOLEAN"},
118{ERR_PACK(0,ASN1_F_D2I_ASN1_BYTES,0),	"d2i_ASN1_bytes"},
119{ERR_PACK(0,ASN1_F_D2I_ASN1_GENERALIZEDTIME,0),	"D2I_ASN1_GENERALIZEDTIME"},
120{ERR_PACK(0,ASN1_F_D2I_ASN1_HEADER,0),	"d2i_ASN1_HEADER"},
121{ERR_PACK(0,ASN1_F_D2I_ASN1_INTEGER,0),	"D2I_ASN1_INTEGER"},
122{ERR_PACK(0,ASN1_F_D2I_ASN1_OBJECT,0),	"d2i_ASN1_OBJECT"},
123{ERR_PACK(0,ASN1_F_D2I_ASN1_SET,0),	"d2i_ASN1_SET"},
124{ERR_PACK(0,ASN1_F_D2I_ASN1_TYPE_BYTES,0),	"d2i_ASN1_type_bytes"},
125{ERR_PACK(0,ASN1_F_D2I_ASN1_UINTEGER,0),	"d2i_ASN1_UINTEGER"},
126{ERR_PACK(0,ASN1_F_D2I_ASN1_UTCTIME,0),	"D2I_ASN1_UTCTIME"},
127{ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA,0),	"d2i_Netscape_RSA"},
128{ERR_PACK(0,ASN1_F_D2I_NETSCAPE_RSA_2,0),	"D2I_NETSCAPE_RSA_2"},
129{ERR_PACK(0,ASN1_F_D2I_PRIVATEKEY,0),	"d2i_PrivateKey"},
130{ERR_PACK(0,ASN1_F_D2I_PUBLICKEY,0),	"d2i_PublicKey"},
131{ERR_PACK(0,ASN1_F_D2I_X509,0),	"D2I_X509"},
132{ERR_PACK(0,ASN1_F_D2I_X509_CINF,0),	"D2I_X509_CINF"},
133{ERR_PACK(0,ASN1_F_D2I_X509_NAME,0),	"D2I_X509_NAME"},
134{ERR_PACK(0,ASN1_F_D2I_X509_PKEY,0),	"d2i_X509_PKEY"},
135{ERR_PACK(0,ASN1_F_I2D_ASN1_SET,0),	"i2d_ASN1_SET"},
136{ERR_PACK(0,ASN1_F_I2D_ASN1_TIME,0),	"I2D_ASN1_TIME"},
137{ERR_PACK(0,ASN1_F_I2D_DSA_PUBKEY,0),	"i2d_DSA_PUBKEY"},
138{ERR_PACK(0,ASN1_F_I2D_NETSCAPE_RSA,0),	"i2d_Netscape_RSA"},
139{ERR_PACK(0,ASN1_F_I2D_PRIVATEKEY,0),	"i2d_PrivateKey"},
140{ERR_PACK(0,ASN1_F_I2D_PUBLICKEY,0),	"i2d_PublicKey"},
141{ERR_PACK(0,ASN1_F_I2D_RSA_PUBKEY,0),	"i2d_RSA_PUBKEY"},
142{ERR_PACK(0,ASN1_F_LONG_C2I,0),	"LONG_C2I"},
143{ERR_PACK(0,ASN1_F_OID_MODULE_INIT,0),	"OID_MODULE_INIT"},
144{ERR_PACK(0,ASN1_F_PKCS5_PBE2_SET,0),	"PKCS5_pbe2_set"},
145{ERR_PACK(0,ASN1_F_X509_CINF_NEW,0),	"X509_CINF_NEW"},
146{ERR_PACK(0,ASN1_F_X509_CRL_ADD0_REVOKED,0),	"X509_CRL_add0_revoked"},
147{ERR_PACK(0,ASN1_F_X509_INFO_NEW,0),	"X509_INFO_new"},
148{ERR_PACK(0,ASN1_F_X509_NAME_NEW,0),	"X509_NAME_NEW"},
149{ERR_PACK(0,ASN1_F_X509_NEW,0),	"X509_NEW"},
150{ERR_PACK(0,ASN1_F_X509_PKEY_NEW,0),	"X509_PKEY_new"},
151{0,NULL}
152	};
153
154static ERR_STRING_DATA ASN1_str_reasons[]=
155	{
156{ASN1_R_ADDING_OBJECT                    ,"adding object"},
157{ASN1_R_AUX_ERROR                        ,"aux error"},
158{ASN1_R_BAD_CLASS                        ,"bad class"},
159{ASN1_R_BAD_OBJECT_HEADER                ,"bad object header"},
160{ASN1_R_BAD_PASSWORD_READ                ,"bad password read"},
161{ASN1_R_BAD_TAG                          ,"bad tag"},
162{ASN1_R_BN_LIB                           ,"bn lib"},
163{ASN1_R_BOOLEAN_IS_WRONG_LENGTH          ,"boolean is wrong length"},
164{ASN1_R_BUFFER_TOO_SMALL                 ,"buffer too small"},
165{ASN1_R_CIPHER_HAS_NO_OBJECT_IDENTIFIER  ,"cipher has no object identifier"},
166{ASN1_R_DATA_IS_WRONG                    ,"data is wrong"},
167{ASN1_R_DECODE_ERROR                     ,"decode error"},
168{ASN1_R_DECODING_ERROR                   ,"decoding error"},
169{ASN1_R_ENCODE_ERROR                     ,"encode error"},
170{ASN1_R_ERROR_GETTING_TIME               ,"error getting time"},
171{ASN1_R_ERROR_LOADING_SECTION            ,"error loading section"},
172{ASN1_R_ERROR_PARSING_SET_ELEMENT        ,"error parsing set element"},
173{ASN1_R_ERROR_SETTING_CIPHER_PARAMS      ,"error setting cipher params"},
174{ASN1_R_EXPECTING_AN_INTEGER             ,"expecting an integer"},
175{ASN1_R_EXPECTING_AN_OBJECT              ,"expecting an object"},
176{ASN1_R_EXPECTING_A_BOOLEAN              ,"expecting a boolean"},
177{ASN1_R_EXPECTING_A_TIME                 ,"expecting a time"},
178{ASN1_R_EXPLICIT_LENGTH_MISMATCH         ,"explicit length mismatch"},
179{ASN1_R_EXPLICIT_TAG_NOT_CONSTRUCTED     ,"explicit tag not constructed"},
180{ASN1_R_FIELD_MISSING                    ,"field missing"},
181{ASN1_R_FIRST_NUM_TOO_LARGE              ,"first num too large"},
182{ASN1_R_HEADER_TOO_LONG                  ,"header too long"},
183{ASN1_R_ILLEGAL_CHARACTERS               ,"illegal characters"},
184{ASN1_R_ILLEGAL_NULL                     ,"illegal null"},
185{ASN1_R_ILLEGAL_OPTIONAL_ANY             ,"illegal optional any"},
186{ASN1_R_ILLEGAL_OPTIONS_ON_ITEM_TEMPLATE ,"illegal options on item template"},
187{ASN1_R_ILLEGAL_TAGGED_ANY               ,"illegal tagged any"},
188{ASN1_R_INTEGER_TOO_LARGE_FOR_LONG       ,"integer too large for long"},
189{ASN1_R_INVALID_BMPSTRING_LENGTH         ,"invalid bmpstring length"},
190{ASN1_R_INVALID_DIGIT                    ,"invalid digit"},
191{ASN1_R_INVALID_SEPARATOR                ,"invalid separator"},
192{ASN1_R_INVALID_TIME_FORMAT              ,"invalid time format"},
193{ASN1_R_INVALID_UNIVERSALSTRING_LENGTH   ,"invalid universalstring length"},
194{ASN1_R_INVALID_UTF8STRING               ,"invalid utf8string"},
195{ASN1_R_IV_TOO_LARGE                     ,"iv too large"},
196{ASN1_R_LENGTH_ERROR                     ,"length error"},
197{ASN1_R_MISSING_EOC                      ,"missing eoc"},
198{ASN1_R_MISSING_SECOND_NUMBER            ,"missing second number"},
199{ASN1_R_MSTRING_NOT_UNIVERSAL            ,"mstring not universal"},
200{ASN1_R_MSTRING_WRONG_TAG                ,"mstring wrong tag"},
201{ASN1_R_NON_HEX_CHARACTERS               ,"non hex characters"},
202{ASN1_R_NOT_ENOUGH_DATA                  ,"not enough data"},
203{ASN1_R_NO_MATCHING_CHOICE_TYPE          ,"no matching choice type"},
204{ASN1_R_NULL_IS_WRONG_LENGTH             ,"null is wrong length"},
205{ASN1_R_ODD_NUMBER_OF_CHARS              ,"odd number of chars"},
206{ASN1_R_PRIVATE_KEY_HEADER_MISSING       ,"private key header missing"},
207{ASN1_R_SECOND_NUMBER_TOO_LARGE          ,"second number too large"},
208{ASN1_R_SEQUENCE_LENGTH_MISMATCH         ,"sequence length mismatch"},
209{ASN1_R_SEQUENCE_NOT_CONSTRUCTED         ,"sequence not constructed"},
210{ASN1_R_SHORT_LINE                       ,"short line"},
211{ASN1_R_STRING_TOO_LONG                  ,"string too long"},
212{ASN1_R_STRING_TOO_SHORT                 ,"string too short"},
213{ASN1_R_TAG_VALUE_TOO_HIGH               ,"tag value too high"},
214{ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD,"the asn1 object identifier is not known for this md"},
215{ASN1_R_TOO_LONG                         ,"too long"},
216{ASN1_R_TYPE_NOT_CONSTRUCTED             ,"type not constructed"},
217{ASN1_R_UNABLE_TO_DECODE_RSA_KEY         ,"unable to decode rsa key"},
218{ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY ,"unable to decode rsa private key"},
219{ASN1_R_UNEXPECTED_EOC                   ,"unexpected eoc"},
220{ASN1_R_UNKNOWN_FORMAT                   ,"unknown format"},
221{ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM ,"unknown message digest algorithm"},
222{ASN1_R_UNKNOWN_OBJECT_TYPE              ,"unknown object type"},
223{ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE          ,"unknown public key type"},
224{ASN1_R_UNSUPPORTED_ANY_DEFINED_BY_TYPE  ,"unsupported any defined by type"},
225{ASN1_R_UNSUPPORTED_CIPHER               ,"unsupported cipher"},
226{ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM ,"unsupported encryption algorithm"},
227{ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE      ,"unsupported public key type"},
228{ASN1_R_WRONG_TAG                        ,"wrong tag"},
229{ASN1_R_WRONG_TYPE                       ,"wrong type"},
230{0,NULL}
231	};
232
233#endif
234
235void ERR_load_ASN1_strings(void)
236	{
237	static int init=1;
238
239	if (init)
240		{
241		init=0;
242#ifndef OPENSSL_NO_ERR
243		ERR_load_strings(ERR_LIB_ASN1,ASN1_str_functs);
244		ERR_load_strings(ERR_LIB_ASN1,ASN1_str_reasons);
245#endif
246
247		}
248	}
249