* copy vendor drop to trunk
[lab.git] / Dev / utvpn / utvpn-unix-v101-7101-public / src / Mayaqua / openssl / ossl_typ.h
1 /* ====================================================================\r
2  * Copyright (c) 1998-2001 The OpenSSL Project.  All rights reserved.\r
3  *\r
4  * Redistribution and use in source and binary forms, with or without\r
5  * modification, are permitted provided that the following conditions\r
6  * are met:\r
7  *\r
8  * 1. Redistributions of source code must retain the above copyright\r
9  *    notice, this list of conditions and the following disclaimer. \r
10  *\r
11  * 2. Redistributions in binary form must reproduce the above copyright\r
12  *    notice, this list of conditions and the following disclaimer in\r
13  *    the documentation and/or other materials provided with the\r
14  *    distribution.\r
15  *\r
16  * 3. All advertising materials mentioning features or use of this\r
17  *    software must display the following acknowledgment:\r
18  *    "This product includes software developed by the OpenSSL Project\r
19  *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"\r
20  *\r
21  * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to\r
22  *    endorse or promote products derived from this software without\r
23  *    prior written permission. For written permission, please contact\r
24  *    openssl-core@openssl.org.\r
25  *\r
26  * 5. Products derived from this software may not be called "OpenSSL"\r
27  *    nor may "OpenSSL" appear in their names without prior written\r
28  *    permission of the OpenSSL Project.\r
29  *\r
30  * 6. Redistributions of any form whatsoever must retain the following\r
31  *    acknowledgment:\r
32  *    "This product includes software developed by the OpenSSL Project\r
33  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"\r
34  *\r
35  * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY\r
36  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\r
37  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\r
38  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR\r
39  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,\r
40  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\r
41  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\r
42  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)\r
43  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,\r
44  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\r
45  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED\r
46  * OF THE POSSIBILITY OF SUCH DAMAGE.\r
47  * ====================================================================\r
48  *\r
49  * This product includes cryptographic software written by Eric Young\r
50  * (eay@cryptsoft.com).  This product includes software written by Tim\r
51  * Hudson (tjh@cryptsoft.com).\r
52  *\r
53  */\r
54 \r
55 #ifndef HEADER_OPENSSL_TYPES_H\r
56 #define HEADER_OPENSSL_TYPES_H\r
57 \r
58 #include <openssl/e_os2.h>\r
59 \r
60 #ifdef NO_ASN1_TYPEDEFS\r
61 #define ASN1_INTEGER            ASN1_STRING\r
62 #define ASN1_ENUMERATED         ASN1_STRING\r
63 #define ASN1_BIT_STRING         ASN1_STRING\r
64 #define ASN1_OCTET_STRING       ASN1_STRING\r
65 #define ASN1_PRINTABLESTRING    ASN1_STRING\r
66 #define ASN1_T61STRING          ASN1_STRING\r
67 #define ASN1_IA5STRING          ASN1_STRING\r
68 #define ASN1_UTCTIME            ASN1_STRING\r
69 #define ASN1_GENERALIZEDTIME    ASN1_STRING\r
70 #define ASN1_TIME               ASN1_STRING\r
71 #define ASN1_GENERALSTRING      ASN1_STRING\r
72 #define ASN1_UNIVERSALSTRING    ASN1_STRING\r
73 #define ASN1_BMPSTRING          ASN1_STRING\r
74 #define ASN1_VISIBLESTRING      ASN1_STRING\r
75 #define ASN1_UTF8STRING         ASN1_STRING\r
76 #define ASN1_BOOLEAN            int\r
77 #define ASN1_NULL               int\r
78 #else\r
79 typedef struct asn1_string_st ASN1_INTEGER;\r
80 typedef struct asn1_string_st ASN1_ENUMERATED;\r
81 typedef struct asn1_string_st ASN1_BIT_STRING;\r
82 typedef struct asn1_string_st ASN1_OCTET_STRING;\r
83 typedef struct asn1_string_st ASN1_PRINTABLESTRING;\r
84 typedef struct asn1_string_st ASN1_T61STRING;\r
85 typedef struct asn1_string_st ASN1_IA5STRING;\r
86 typedef struct asn1_string_st ASN1_GENERALSTRING;\r
87 typedef struct asn1_string_st ASN1_UNIVERSALSTRING;\r
88 typedef struct asn1_string_st ASN1_BMPSTRING;\r
89 typedef struct asn1_string_st ASN1_UTCTIME;\r
90 typedef struct asn1_string_st ASN1_TIME;\r
91 typedef struct asn1_string_st ASN1_GENERALIZEDTIME;\r
92 typedef struct asn1_string_st ASN1_VISIBLESTRING;\r
93 typedef struct asn1_string_st ASN1_UTF8STRING;\r
94 typedef int ASN1_BOOLEAN;\r
95 typedef int ASN1_NULL;\r
96 #endif\r
97 \r
98 #ifdef OPENSSL_SYS_WIN32\r
99 #undef X509_NAME\r
100 #undef X509_CERT_PAIR\r
101 #undef PKCS7_ISSUER_AND_SERIAL\r
102 #endif\r
103 \r
104 #ifdef BIGNUM\r
105 #undef BIGNUM\r
106 #endif\r
107 typedef struct bignum_st BIGNUM;\r
108 typedef struct bignum_ctx BN_CTX;\r
109 typedef struct bn_blinding_st BN_BLINDING;\r
110 typedef struct bn_mont_ctx_st BN_MONT_CTX;\r
111 typedef struct bn_recp_ctx_st BN_RECP_CTX;\r
112 typedef struct bn_gencb_st BN_GENCB;\r
113 \r
114 typedef struct buf_mem_st BUF_MEM;\r
115 \r
116 typedef struct evp_cipher_st EVP_CIPHER;\r
117 typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX;\r
118 typedef struct env_md_st EVP_MD;\r
119 typedef struct env_md_ctx_st EVP_MD_CTX;\r
120 typedef struct evp_pkey_st EVP_PKEY;\r
121 \r
122 typedef struct dh_st DH;\r
123 typedef struct dh_method DH_METHOD;\r
124 \r
125 typedef struct dsa_st DSA;\r
126 typedef struct dsa_method DSA_METHOD;\r
127 \r
128 typedef struct rsa_st RSA;\r
129 typedef struct rsa_meth_st RSA_METHOD;\r
130 \r
131 typedef struct rand_meth_st RAND_METHOD;\r
132 \r
133 typedef struct ecdh_method ECDH_METHOD;\r
134 typedef struct ecdsa_method ECDSA_METHOD;\r
135 \r
136 typedef struct x509_st X509;\r
137 typedef struct X509_algor_st X509_ALGOR;\r
138 typedef struct X509_crl_st X509_CRL;\r
139 typedef struct X509_name_st X509_NAME;\r
140 typedef struct x509_store_st X509_STORE;\r
141 typedef struct x509_store_ctx_st X509_STORE_CTX;\r
142 \r
143 typedef struct v3_ext_ctx X509V3_CTX;\r
144 typedef struct conf_st CONF;\r
145 \r
146 typedef struct store_st STORE;\r
147 typedef struct store_method_st STORE_METHOD;\r
148 \r
149 typedef struct ui_st UI;\r
150 typedef struct ui_method_st UI_METHOD;\r
151 \r
152 typedef struct st_ERR_FNS ERR_FNS;\r
153 \r
154 typedef struct engine_st ENGINE;\r
155 \r
156 typedef struct X509_POLICY_NODE_st X509_POLICY_NODE;\r
157 typedef struct X509_POLICY_LEVEL_st X509_POLICY_LEVEL;\r
158 typedef struct X509_POLICY_TREE_st X509_POLICY_TREE;\r
159 typedef struct X509_POLICY_CACHE_st X509_POLICY_CACHE;\r
160 \r
161   /* If placed in pkcs12.h, we end up with a circular depency with pkcs7.h */\r
162 #define DECLARE_PKCS12_STACK_OF(type) /* Nothing */\r
163 #define IMPLEMENT_PKCS12_STACK_OF(type) /* Nothing */\r
164 \r
165 typedef struct crypto_ex_data_st CRYPTO_EX_DATA;\r
166 /* Callback types for crypto.h */\r
167 typedef int CRYPTO_EX_new(void *parent, void *ptr, CRYPTO_EX_DATA *ad,\r
168                                         int idx, long argl, void *argp);\r
169 typedef void CRYPTO_EX_free(void *parent, void *ptr, CRYPTO_EX_DATA *ad,\r
170                                         int idx, long argl, void *argp);\r
171 typedef int CRYPTO_EX_dup(CRYPTO_EX_DATA *to, CRYPTO_EX_DATA *from, void *from_d, \r
172                                         int idx, long argl, void *argp);\r
173 \r
174 #endif /* def HEADER_OPENSSL_TYPES_H */\r