]> git.sur5r.net Git - freertos/blob - FreeRTOS-Plus/CyaSSL/cyassl/ctaocrypt/error.h
8a0d586280e368f73dbe1ffc5ea7cf6a55844ce7
[freertos] / FreeRTOS-Plus / CyaSSL / cyassl / ctaocrypt / error.h
1 /* error.h
2  *
3  * Copyright (C) 2006-2012 Sawtooth Consulting Ltd.
4  *
5  * This file is part of CyaSSL.
6  *
7  * CyaSSL is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * CyaSSL is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20  */
21
22
23 #ifndef CTAO_CRYPT_ERROR_H
24 #define CTAO_CRYPT_ERROR_H
25
26 #include <cyassl/ctaocrypt/types.h>
27
28
29 #ifdef __cplusplus
30     extern "C" {
31 #endif
32
33
34 /* error codes */
35 enum {
36     MAX_ERROR_SZ       =  80,   /* max size of error string */
37     MAX_CODE_E         = -100,  /* errors -101 - -199 */
38     OPEN_RAN_E         = -101,  /* opening random device error */
39     READ_RAN_E         = -102,  /* reading random device error */
40     WINCRYPT_E         = -103,  /* windows crypt init error */
41     CRYPTGEN_E         = -104,  /* windows crypt generation error */
42     RAN_BLOCK_E        = -105,  /* reading random device would block */
43
44     MP_INIT_E          = -110,  /* mp_init error state */
45     MP_READ_E          = -111,  /* mp_read error state */
46     MP_EXPTMOD_E       = -112,  /* mp_exptmod error state */
47     MP_TO_E            = -113,  /* mp_to_xxx error state, can't convert */
48     MP_SUB_E           = -114,  /* mp_sub error state, can't subtract */
49     MP_ADD_E           = -115,  /* mp_add error state, can't add */
50     MP_MUL_E           = -116,  /* mp_mul error state, can't multiply */
51     MP_MULMOD_E        = -117,  /* mp_mulmod error state, can't multiply mod */
52     MP_MOD_E           = -118,  /* mp_mod error state, can't mod */
53     MP_INVMOD_E        = -119,  /* mp_invmod error state, can't inv mod */
54     MP_CMP_E           = -120,  /* mp_cmp error state */
55     MP_ZERO_E          = -121,  /* got a mp zero result, not expected */
56
57     MEMORY_E           = -125,  /* out of memory error */
58
59     RSA_WRONG_TYPE_E   = -130,  /* RSA wrong block type for RSA function */
60     RSA_BUFFER_E       = -131,  /* RSA buffer error, output too small or 
61                                    input too large */
62     BUFFER_E           = -132,  /* output buffer too small or input too large */
63     ALGO_ID_E          = -133,  /* setting algo id error */
64     PUBLIC_KEY_E       = -134,  /* setting public key error */
65     DATE_E             = -135,  /* setting date validity error */
66     SUBJECT_E          = -136,  /* setting subject name error */
67     ISSUER_E           = -137,  /* setting issuer  name error */
68     CA_TRUE_E          = -138,  /* setting CA basic constraint true error */
69     EXTENSIONS_E       = -139,  /* setting extensions error */
70
71     ASN_PARSE_E        = -140,  /* ASN parsing error, invalid input */
72     ASN_VERSION_E      = -141,  /* ASN version error, invalid number */
73     ASN_GETINT_E       = -142,  /* ASN get big int error, invalid data */
74     ASN_RSA_KEY_E      = -143,  /* ASN key init error, invalid input */
75     ASN_OBJECT_ID_E    = -144,  /* ASN object id error, invalid id */
76     ASN_TAG_NULL_E     = -145,  /* ASN tag error, not null */
77     ASN_EXPECT_0_E     = -146,  /* ASN expect error, not zero */
78     ASN_BITSTR_E       = -147,  /* ASN bit string error, wrong id */
79     ASN_UNKNOWN_OID_E  = -148,  /* ASN oid error, unknown sum id */
80     ASN_DATE_SZ_E      = -149,  /* ASN date error, bad size */
81     ASN_BEFORE_DATE_E  = -150,  /* ASN date error, current date before */
82     ASN_AFTER_DATE_E   = -151,  /* ASN date error, current date after */
83     ASN_SIG_OID_E      = -152,  /* ASN signature error, mismatched oid */
84     ASN_TIME_E         = -153,  /* ASN time error, unknown time type */
85     ASN_INPUT_E        = -154,  /* ASN input error, not enough data */
86     ASN_SIG_CONFIRM_E  = -155,  /* ASN sig error, confirm failure */
87     ASN_SIG_HASH_E     = -156,  /* ASN sig error, unsupported hash type */
88     ASN_SIG_KEY_E      = -157,  /* ASN sig error, unsupported key type */
89     ASN_DH_KEY_E       = -158,  /* ASN key init error, invalid input */
90     ASN_NTRU_KEY_E     = -159,  /* ASN ntru key decode error, invalid input */
91
92     ECC_BAD_ARG_E      = -170,  /* ECC input argument of wrong type */
93     ASN_ECC_KEY_E      = -171,  /* ASN ECC bad input */
94     ECC_CURVE_OID_E    = -172,  /* Unsupported ECC OID curve type */
95     BAD_FUNC_ARG       = -173,  /* Bad function argument provided */
96     NOT_COMPILED_IN    = -174,  /* Feature not compiled in */
97     UNICODE_SIZE_E     = -175,  /* Unicode password too big */
98     NO_PASSWORD        = -176,  /* no password provided by user */
99     ALT_NAME_E         = -177,  /* alt name size problem, too big */
100
101     AES_GCM_AUTH_E     = -180,  /* AES-GCM Authentication check failure */
102
103     MIN_CODE_E         = -200   /* errors -101 - -199 */
104 };
105
106
107 CYASSL_API void CTaoCryptErrorString(int error, char* buffer);
108
109
110 #ifdef __cplusplus
111     } /* extern "C" */
112 #endif
113
114 #endif /* CTAO_CRYPT_ERROR_H */
115