xref: /aosp_15_r20/external/boringssl/src/include/openssl/ssl3.h (revision 8fb009dc861624b67b6cdb62ea21f0f22d0c584b)
1*8fb009dcSAndroid Build Coastguard Worker /* Copyright (C) 1995-1998 Eric Young ([email protected])
2*8fb009dcSAndroid Build Coastguard Worker  * All rights reserved.
3*8fb009dcSAndroid Build Coastguard Worker  *
4*8fb009dcSAndroid Build Coastguard Worker  * This package is an SSL implementation written
5*8fb009dcSAndroid Build Coastguard Worker  * by Eric Young ([email protected]).
6*8fb009dcSAndroid Build Coastguard Worker  * The implementation was written so as to conform with Netscapes SSL.
7*8fb009dcSAndroid Build Coastguard Worker  *
8*8fb009dcSAndroid Build Coastguard Worker  * This library is free for commercial and non-commercial use as long as
9*8fb009dcSAndroid Build Coastguard Worker  * the following conditions are aheared to.  The following conditions
10*8fb009dcSAndroid Build Coastguard Worker  * apply to all code found in this distribution, be it the RC4, RSA,
11*8fb009dcSAndroid Build Coastguard Worker  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
12*8fb009dcSAndroid Build Coastguard Worker  * included with this distribution is covered by the same copyright terms
13*8fb009dcSAndroid Build Coastguard Worker  * except that the holder is Tim Hudson ([email protected]).
14*8fb009dcSAndroid Build Coastguard Worker  *
15*8fb009dcSAndroid Build Coastguard Worker  * Copyright remains Eric Young's, and as such any Copyright notices in
16*8fb009dcSAndroid Build Coastguard Worker  * the code are not to be removed.
17*8fb009dcSAndroid Build Coastguard Worker  * If this package is used in a product, Eric Young should be given attribution
18*8fb009dcSAndroid Build Coastguard Worker  * as the author of the parts of the library used.
19*8fb009dcSAndroid Build Coastguard Worker  * This can be in the form of a textual message at program startup or
20*8fb009dcSAndroid Build Coastguard Worker  * in documentation (online or textual) provided with the package.
21*8fb009dcSAndroid Build Coastguard Worker  *
22*8fb009dcSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
23*8fb009dcSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
24*8fb009dcSAndroid Build Coastguard Worker  * are met:
25*8fb009dcSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the copyright
26*8fb009dcSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
27*8fb009dcSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
28*8fb009dcSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in the
29*8fb009dcSAndroid Build Coastguard Worker  *    documentation and/or other materials provided with the distribution.
30*8fb009dcSAndroid Build Coastguard Worker  * 3. All advertising materials mentioning features or use of this software
31*8fb009dcSAndroid Build Coastguard Worker  *    must display the following acknowledgement:
32*8fb009dcSAndroid Build Coastguard Worker  *    "This product includes cryptographic software written by
33*8fb009dcSAndroid Build Coastguard Worker  *     Eric Young ([email protected])"
34*8fb009dcSAndroid Build Coastguard Worker  *    The word 'cryptographic' can be left out if the rouines from the library
35*8fb009dcSAndroid Build Coastguard Worker  *    being used are not cryptographic related :-).
36*8fb009dcSAndroid Build Coastguard Worker  * 4. If you include any Windows specific code (or a derivative thereof) from
37*8fb009dcSAndroid Build Coastguard Worker  *    the apps directory (application code) you must include an acknowledgement:
38*8fb009dcSAndroid Build Coastguard Worker  *    "This product includes software written by Tim Hudson ([email protected])"
39*8fb009dcSAndroid Build Coastguard Worker  *
40*8fb009dcSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
41*8fb009dcSAndroid Build Coastguard Worker  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42*8fb009dcSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43*8fb009dcSAndroid Build Coastguard Worker  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
44*8fb009dcSAndroid Build Coastguard Worker  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
45*8fb009dcSAndroid Build Coastguard Worker  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
46*8fb009dcSAndroid Build Coastguard Worker  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47*8fb009dcSAndroid Build Coastguard Worker  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
48*8fb009dcSAndroid Build Coastguard Worker  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
49*8fb009dcSAndroid Build Coastguard Worker  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
50*8fb009dcSAndroid Build Coastguard Worker  * SUCH DAMAGE.
51*8fb009dcSAndroid Build Coastguard Worker  *
52*8fb009dcSAndroid Build Coastguard Worker  * The licence and distribution terms for any publically available version or
53*8fb009dcSAndroid Build Coastguard Worker  * derivative of this code cannot be changed.  i.e. this code cannot simply be
54*8fb009dcSAndroid Build Coastguard Worker  * copied and put under another distribution licence
55*8fb009dcSAndroid Build Coastguard Worker  * [including the GNU Public Licence.]
56*8fb009dcSAndroid Build Coastguard Worker  */
57*8fb009dcSAndroid Build Coastguard Worker /* ====================================================================
58*8fb009dcSAndroid Build Coastguard Worker  * Copyright (c) 1998-2002 The OpenSSL Project.  All rights reserved.
59*8fb009dcSAndroid Build Coastguard Worker  *
60*8fb009dcSAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
61*8fb009dcSAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
62*8fb009dcSAndroid Build Coastguard Worker  * are met:
63*8fb009dcSAndroid Build Coastguard Worker  *
64*8fb009dcSAndroid Build Coastguard Worker  * 1. Redistributions of source code must retain the above copyright
65*8fb009dcSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
66*8fb009dcSAndroid Build Coastguard Worker  *
67*8fb009dcSAndroid Build Coastguard Worker  * 2. Redistributions in binary form must reproduce the above copyright
68*8fb009dcSAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in
69*8fb009dcSAndroid Build Coastguard Worker  *    the documentation and/or other materials provided with the
70*8fb009dcSAndroid Build Coastguard Worker  *    distribution.
71*8fb009dcSAndroid Build Coastguard Worker  *
72*8fb009dcSAndroid Build Coastguard Worker  * 3. All advertising materials mentioning features or use of this
73*8fb009dcSAndroid Build Coastguard Worker  *    software must display the following acknowledgment:
74*8fb009dcSAndroid Build Coastguard Worker  *    "This product includes software developed by the OpenSSL Project
75*8fb009dcSAndroid Build Coastguard Worker  *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
76*8fb009dcSAndroid Build Coastguard Worker  *
77*8fb009dcSAndroid Build Coastguard Worker  * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
78*8fb009dcSAndroid Build Coastguard Worker  *    endorse or promote products derived from this software without
79*8fb009dcSAndroid Build Coastguard Worker  *    prior written permission. For written permission, please contact
80*8fb009dcSAndroid Build Coastguard Worker  *    [email protected].
81*8fb009dcSAndroid Build Coastguard Worker  *
82*8fb009dcSAndroid Build Coastguard Worker  * 5. Products derived from this software may not be called "OpenSSL"
83*8fb009dcSAndroid Build Coastguard Worker  *    nor may "OpenSSL" appear in their names without prior written
84*8fb009dcSAndroid Build Coastguard Worker  *    permission of the OpenSSL Project.
85*8fb009dcSAndroid Build Coastguard Worker  *
86*8fb009dcSAndroid Build Coastguard Worker  * 6. Redistributions of any form whatsoever must retain the following
87*8fb009dcSAndroid Build Coastguard Worker  *    acknowledgment:
88*8fb009dcSAndroid Build Coastguard Worker  *    "This product includes software developed by the OpenSSL Project
89*8fb009dcSAndroid Build Coastguard Worker  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
90*8fb009dcSAndroid Build Coastguard Worker  *
91*8fb009dcSAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
92*8fb009dcSAndroid Build Coastguard Worker  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
93*8fb009dcSAndroid Build Coastguard Worker  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
94*8fb009dcSAndroid Build Coastguard Worker  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
95*8fb009dcSAndroid Build Coastguard Worker  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
96*8fb009dcSAndroid Build Coastguard Worker  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
97*8fb009dcSAndroid Build Coastguard Worker  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
98*8fb009dcSAndroid Build Coastguard Worker  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
99*8fb009dcSAndroid Build Coastguard Worker  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
100*8fb009dcSAndroid Build Coastguard Worker  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
101*8fb009dcSAndroid Build Coastguard Worker  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
102*8fb009dcSAndroid Build Coastguard Worker  * OF THE POSSIBILITY OF SUCH DAMAGE.
103*8fb009dcSAndroid Build Coastguard Worker  * ====================================================================
104*8fb009dcSAndroid Build Coastguard Worker  *
105*8fb009dcSAndroid Build Coastguard Worker  * This product includes cryptographic software written by Eric Young
106*8fb009dcSAndroid Build Coastguard Worker  * ([email protected]).  This product includes software written by Tim
107*8fb009dcSAndroid Build Coastguard Worker  * Hudson ([email protected]).
108*8fb009dcSAndroid Build Coastguard Worker  *
109*8fb009dcSAndroid Build Coastguard Worker  */
110*8fb009dcSAndroid Build Coastguard Worker /* ====================================================================
111*8fb009dcSAndroid Build Coastguard Worker  * Copyright 2002 Sun Microsystems, Inc. ALL RIGHTS RESERVED.
112*8fb009dcSAndroid Build Coastguard Worker  * ECC cipher suite support in OpenSSL originally developed by
113*8fb009dcSAndroid Build Coastguard Worker  * SUN MICROSYSTEMS, INC., and contributed to the OpenSSL project.
114*8fb009dcSAndroid Build Coastguard Worker  */
115*8fb009dcSAndroid Build Coastguard Worker 
116*8fb009dcSAndroid Build Coastguard Worker #ifndef OPENSSL_HEADER_SSL3_H
117*8fb009dcSAndroid Build Coastguard Worker #define OPENSSL_HEADER_SSL3_H
118*8fb009dcSAndroid Build Coastguard Worker 
119*8fb009dcSAndroid Build Coastguard Worker #include <openssl/aead.h>
120*8fb009dcSAndroid Build Coastguard Worker 
121*8fb009dcSAndroid Build Coastguard Worker #ifdef  __cplusplus
122*8fb009dcSAndroid Build Coastguard Worker extern "C" {
123*8fb009dcSAndroid Build Coastguard Worker #endif
124*8fb009dcSAndroid Build Coastguard Worker 
125*8fb009dcSAndroid Build Coastguard Worker 
126*8fb009dcSAndroid Build Coastguard Worker // These are kept to support clients that negotiates higher protocol versions
127*8fb009dcSAndroid Build Coastguard Worker // using SSLv2 client hello records.
128*8fb009dcSAndroid Build Coastguard Worker #define SSL2_MT_CLIENT_HELLO 1
129*8fb009dcSAndroid Build Coastguard Worker #define SSL2_VERSION 0x0002
130*8fb009dcSAndroid Build Coastguard Worker 
131*8fb009dcSAndroid Build Coastguard Worker // Signalling cipher suite value from RFC 5746.
132*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_SCSV 0x030000FF
133*8fb009dcSAndroid Build Coastguard Worker // Fallback signalling cipher suite value from RFC 7507.
134*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_FALLBACK_SCSV 0x03005600
135*8fb009dcSAndroid Build Coastguard Worker 
136*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_NULL_MD5 0x03000001
137*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_NULL_SHA 0x03000002
138*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_RC4_40_MD5 0x03000003
139*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_RC4_128_MD5 0x03000004
140*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_RC4_128_SHA 0x03000005
141*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_RC2_40_MD5 0x03000006
142*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_IDEA_128_SHA 0x03000007
143*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_DES_40_CBC_SHA 0x03000008
144*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_DES_64_CBC_SHA 0x03000009
145*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_RSA_DES_192_CBC3_SHA 0x0300000A
146*8fb009dcSAndroid Build Coastguard Worker 
147*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_DSS_DES_40_CBC_SHA 0x0300000B
148*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_DSS_DES_64_CBC_SHA 0x0300000C
149*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_DSS_DES_192_CBC3_SHA 0x0300000D
150*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_RSA_DES_40_CBC_SHA 0x0300000E
151*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_RSA_DES_64_CBC_SHA 0x0300000F
152*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_DH_RSA_DES_192_CBC3_SHA 0x03000010
153*8fb009dcSAndroid Build Coastguard Worker 
154*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_DSS_DES_40_CBC_SHA 0x03000011
155*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_DSS_DES_64_CBC_SHA 0x03000012
156*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_DSS_DES_192_CBC3_SHA 0x03000013
157*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_RSA_DES_40_CBC_SHA 0x03000014
158*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_RSA_DES_64_CBC_SHA 0x03000015
159*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_EDH_RSA_DES_192_CBC3_SHA 0x03000016
160*8fb009dcSAndroid Build Coastguard Worker 
161*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_ADH_RC4_40_MD5 0x03000017
162*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_ADH_RC4_128_MD5 0x03000018
163*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_ADH_DES_40_CBC_SHA 0x03000019
164*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_ADH_DES_64_CBC_SHA 0x0300001A
165*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CK_ADH_DES_192_CBC_SHA 0x0300001B
166*8fb009dcSAndroid Build Coastguard Worker 
167*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_NULL_MD5 "NULL-MD5"
168*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_NULL_SHA "NULL-SHA"
169*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_RC4_40_MD5 "EXP-RC4-MD5"
170*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_RC4_128_MD5 "RC4-MD5"
171*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_RC4_128_SHA "RC4-SHA"
172*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_RC2_40_MD5 "EXP-RC2-CBC-MD5"
173*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_IDEA_128_SHA "IDEA-CBC-SHA"
174*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_DES_40_CBC_SHA "EXP-DES-CBC-SHA"
175*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_DES_64_CBC_SHA "DES-CBC-SHA"
176*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_RSA_DES_192_CBC3_SHA "DES-CBC3-SHA"
177*8fb009dcSAndroid Build Coastguard Worker 
178*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_DSS_DES_40_CBC_SHA "EXP-DH-DSS-DES-CBC-SHA"
179*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_DSS_DES_64_CBC_SHA "DH-DSS-DES-CBC-SHA"
180*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_DSS_DES_192_CBC3_SHA "DH-DSS-DES-CBC3-SHA"
181*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_RSA_DES_40_CBC_SHA "EXP-DH-RSA-DES-CBC-SHA"
182*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_RSA_DES_64_CBC_SHA "DH-RSA-DES-CBC-SHA"
183*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_DH_RSA_DES_192_CBC3_SHA "DH-RSA-DES-CBC3-SHA"
184*8fb009dcSAndroid Build Coastguard Worker 
185*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_DSS_DES_40_CBC_SHA "EXP-EDH-DSS-DES-CBC-SHA"
186*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_DSS_DES_64_CBC_SHA "EDH-DSS-DES-CBC-SHA"
187*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_DSS_DES_192_CBC3_SHA "EDH-DSS-DES-CBC3-SHA"
188*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_RSA_DES_40_CBC_SHA "EXP-EDH-RSA-DES-CBC-SHA"
189*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_RSA_DES_64_CBC_SHA "EDH-RSA-DES-CBC-SHA"
190*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_EDH_RSA_DES_192_CBC3_SHA "EDH-RSA-DES-CBC3-SHA"
191*8fb009dcSAndroid Build Coastguard Worker 
192*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_ADH_RC4_40_MD5 "EXP-ADH-RC4-MD5"
193*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_ADH_RC4_128_MD5 "ADH-RC4-MD5"
194*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_ADH_DES_40_CBC_SHA "EXP-ADH-DES-CBC-SHA"
195*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_ADH_DES_64_CBC_SHA "ADH-DES-CBC-SHA"
196*8fb009dcSAndroid Build Coastguard Worker #define SSL3_TXT_ADH_DES_192_CBC_SHA "ADH-DES-CBC3-SHA"
197*8fb009dcSAndroid Build Coastguard Worker 
198*8fb009dcSAndroid Build Coastguard Worker #define SSL3_SSL_SESSION_ID_LENGTH 32
199*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MAX_SSL_SESSION_ID_LENGTH 32
200*8fb009dcSAndroid Build Coastguard Worker 
201*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MASTER_SECRET_SIZE 48
202*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RANDOM_SIZE 32
203*8fb009dcSAndroid Build Coastguard Worker #define SSL3_SESSION_ID_SIZE 32
204*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_HEADER_LENGTH 5
205*8fb009dcSAndroid Build Coastguard Worker 
206*8fb009dcSAndroid Build Coastguard Worker #define SSL3_HM_HEADER_LENGTH 4
207*8fb009dcSAndroid Build Coastguard Worker 
208*8fb009dcSAndroid Build Coastguard Worker #ifndef SSL3_ALIGN_PAYLOAD
209*8fb009dcSAndroid Build Coastguard Worker // Some will argue that this increases memory footprint, but it's not actually
210*8fb009dcSAndroid Build Coastguard Worker // true. Point is that malloc has to return at least 64-bit aligned pointers,
211*8fb009dcSAndroid Build Coastguard Worker // meaning that allocating 5 bytes wastes 3 bytes in either case. Suggested
212*8fb009dcSAndroid Build Coastguard Worker // pre-gaping simply moves these wasted bytes from the end of allocated region
213*8fb009dcSAndroid Build Coastguard Worker // to its front, but makes data payload aligned, which improves performance.
214*8fb009dcSAndroid Build Coastguard Worker #define SSL3_ALIGN_PAYLOAD 8
215*8fb009dcSAndroid Build Coastguard Worker #else
216*8fb009dcSAndroid Build Coastguard Worker #if (SSL3_ALIGN_PAYLOAD & (SSL3_ALIGN_PAYLOAD - 1)) != 0
217*8fb009dcSAndroid Build Coastguard Worker #error "insane SSL3_ALIGN_PAYLOAD"
218*8fb009dcSAndroid Build Coastguard Worker #undef SSL3_ALIGN_PAYLOAD
219*8fb009dcSAndroid Build Coastguard Worker #endif
220*8fb009dcSAndroid Build Coastguard Worker #endif
221*8fb009dcSAndroid Build Coastguard Worker 
222*8fb009dcSAndroid Build Coastguard Worker // This is the maximum MAC (digest) size used by the SSL library. Currently
223*8fb009dcSAndroid Build Coastguard Worker // maximum of 20 is used by SHA1, but we reserve for future extension for
224*8fb009dcSAndroid Build Coastguard Worker // 512-bit hashes.
225*8fb009dcSAndroid Build Coastguard Worker 
226*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_MD_SIZE 64
227*8fb009dcSAndroid Build Coastguard Worker 
228*8fb009dcSAndroid Build Coastguard Worker // Maximum block size used in all ciphersuites. Currently 16 for AES.
229*8fb009dcSAndroid Build Coastguard Worker 
230*8fb009dcSAndroid Build Coastguard Worker #define SSL_RT_MAX_CIPHER_BLOCK_SIZE 16
231*8fb009dcSAndroid Build Coastguard Worker 
232*8fb009dcSAndroid Build Coastguard Worker // Maximum plaintext length: defined by SSL/TLS standards
233*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_PLAIN_LENGTH 16384
234*8fb009dcSAndroid Build Coastguard Worker // Maximum compression overhead: defined by SSL/TLS standards
235*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_COMPRESSED_OVERHEAD 1024
236*8fb009dcSAndroid Build Coastguard Worker 
237*8fb009dcSAndroid Build Coastguard Worker // The standards give a maximum encryption overhead of 1024 bytes. In practice
238*8fb009dcSAndroid Build Coastguard Worker // the value is lower than this. The overhead is the maximum number of padding
239*8fb009dcSAndroid Build Coastguard Worker // bytes (256) plus the mac size.
240*8fb009dcSAndroid Build Coastguard Worker //
241*8fb009dcSAndroid Build Coastguard Worker // TODO(davidben): This derivation doesn't take AEADs into account, or TLS 1.1
242*8fb009dcSAndroid Build Coastguard Worker // explicit nonces. It happens to work because |SSL3_RT_MAX_MD_SIZE| is larger
243*8fb009dcSAndroid Build Coastguard Worker // than necessary and no true AEAD has variable overhead in TLS 1.2.
244*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_ENCRYPTED_OVERHEAD (256 + SSL3_RT_MAX_MD_SIZE)
245*8fb009dcSAndroid Build Coastguard Worker 
246*8fb009dcSAndroid Build Coastguard Worker // SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD is the maximum overhead in encrypting a
247*8fb009dcSAndroid Build Coastguard Worker // record. This does not include the record header. Some ciphers use explicit
248*8fb009dcSAndroid Build Coastguard Worker // nonces, so it includes both the AEAD overhead as well as the nonce.
249*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_SEND_MAX_ENCRYPTED_OVERHEAD \
250*8fb009dcSAndroid Build Coastguard Worker     (EVP_AEAD_MAX_OVERHEAD + EVP_AEAD_MAX_NONCE_LENGTH)
251*8fb009dcSAndroid Build Coastguard Worker 
252*8fb009dcSAndroid Build Coastguard Worker // SSL3_RT_MAX_COMPRESSED_LENGTH is an alias for
253*8fb009dcSAndroid Build Coastguard Worker // |SSL3_RT_MAX_PLAIN_LENGTH|. Compression is gone, so don't include the
254*8fb009dcSAndroid Build Coastguard Worker // compression overhead.
255*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_COMPRESSED_LENGTH SSL3_RT_MAX_PLAIN_LENGTH
256*8fb009dcSAndroid Build Coastguard Worker 
257*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_ENCRYPTED_LENGTH \
258*8fb009dcSAndroid Build Coastguard Worker   (SSL3_RT_MAX_ENCRYPTED_OVERHEAD + SSL3_RT_MAX_COMPRESSED_LENGTH)
259*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_MAX_PACKET_SIZE \
260*8fb009dcSAndroid Build Coastguard Worker   (SSL3_RT_MAX_ENCRYPTED_LENGTH + SSL3_RT_HEADER_LENGTH)
261*8fb009dcSAndroid Build Coastguard Worker 
262*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MD_CLIENT_FINISHED_CONST "\x43\x4C\x4E\x54"
263*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MD_SERVER_FINISHED_CONST "\x53\x52\x56\x52"
264*8fb009dcSAndroid Build Coastguard Worker 
265*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_CHANGE_CIPHER_SPEC 20
266*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_ALERT 21
267*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_HANDSHAKE 22
268*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_APPLICATION_DATA 23
269*8fb009dcSAndroid Build Coastguard Worker 
270*8fb009dcSAndroid Build Coastguard Worker // Pseudo content type for SSL/TLS header info
271*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_HEADER 0x100
272*8fb009dcSAndroid Build Coastguard Worker #define SSL3_RT_CLIENT_HELLO_INNER 0x101
273*8fb009dcSAndroid Build Coastguard Worker 
274*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AL_WARNING 1
275*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AL_FATAL 2
276*8fb009dcSAndroid Build Coastguard Worker 
277*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_CLOSE_NOTIFY 0
278*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_UNEXPECTED_MESSAGE 10     // fatal
279*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_BAD_RECORD_MAC 20         // fatal
280*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_DECOMPRESSION_FAILURE 30  // fatal
281*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_HANDSHAKE_FAILURE 40      // fatal
282*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_NO_CERTIFICATE 41
283*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_BAD_CERTIFICATE 42
284*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_UNSUPPORTED_CERTIFICATE 43
285*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_CERTIFICATE_REVOKED 44
286*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_CERTIFICATE_EXPIRED 45
287*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_CERTIFICATE_UNKNOWN 46
288*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_ILLEGAL_PARAMETER 47       // fatal
289*8fb009dcSAndroid Build Coastguard Worker #define SSL3_AD_INAPPROPRIATE_FALLBACK 86  // fatal
290*8fb009dcSAndroid Build Coastguard Worker 
291*8fb009dcSAndroid Build Coastguard Worker #define SSL3_CT_RSA_SIGN 1
292*8fb009dcSAndroid Build Coastguard Worker 
293*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_HELLO_REQUEST 0
294*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CLIENT_HELLO 1
295*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_SERVER_HELLO 2
296*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_NEW_SESSION_TICKET 4
297*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_END_OF_EARLY_DATA 5
298*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_ENCRYPTED_EXTENSIONS 8
299*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CERTIFICATE 11
300*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_SERVER_KEY_EXCHANGE 12
301*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CERTIFICATE_REQUEST 13
302*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_SERVER_HELLO_DONE 14
303*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CERTIFICATE_VERIFY 15
304*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CLIENT_KEY_EXCHANGE 16
305*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_FINISHED 20
306*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CERTIFICATE_STATUS 22
307*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_SUPPLEMENTAL_DATA 23
308*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_KEY_UPDATE 24
309*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_COMPRESSED_CERTIFICATE 25
310*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_NEXT_PROTO 67
311*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CHANNEL_ID 203
312*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_MESSAGE_HASH 254
313*8fb009dcSAndroid Build Coastguard Worker #define DTLS1_MT_HELLO_VERIFY_REQUEST 3
314*8fb009dcSAndroid Build Coastguard Worker 
315*8fb009dcSAndroid Build Coastguard Worker // The following are legacy aliases for consumers which use
316*8fb009dcSAndroid Build Coastguard Worker // |SSL_CTX_set_msg_callback|.
317*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_SERVER_DONE SSL3_MT_SERVER_HELLO_DONE
318*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_NEWSESSION_TICKET SSL3_MT_NEW_SESSION_TICKET
319*8fb009dcSAndroid Build Coastguard Worker 
320*8fb009dcSAndroid Build Coastguard Worker 
321*8fb009dcSAndroid Build Coastguard Worker #define SSL3_MT_CCS 1
322*8fb009dcSAndroid Build Coastguard Worker 
323*8fb009dcSAndroid Build Coastguard Worker 
324*8fb009dcSAndroid Build Coastguard Worker #ifdef  __cplusplus
325*8fb009dcSAndroid Build Coastguard Worker }  // extern C
326*8fb009dcSAndroid Build Coastguard Worker #endif
327*8fb009dcSAndroid Build Coastguard Worker 
328*8fb009dcSAndroid Build Coastguard Worker #endif  // OPENSSL_HEADER_SSL3_H
329