LCOV - code coverage report
Current view: top level - home/mbr/git/openssl.git/ssl - s3_lib.c (source / functions) Hit Total Coverage
Test: lcov_coverage_final.info Lines: 228 661 34.5 %
Date: 2014-08-02 Functions: 20 27 74.1 %
Branches: 124 496 25.0 %

           Branch data     Line data    Source code
       1                 :            : /* ssl/s3_lib.c */
       2                 :            : /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
       3                 :            :  * All rights reserved.
       4                 :            :  *
       5                 :            :  * This package is an SSL implementation written
       6                 :            :  * by Eric Young (eay@cryptsoft.com).
       7                 :            :  * The implementation was written so as to conform with Netscapes SSL.
       8                 :            :  * 
       9                 :            :  * This library is free for commercial and non-commercial use as long as
      10                 :            :  * the following conditions are aheared to.  The following conditions
      11                 :            :  * apply to all code found in this distribution, be it the RC4, RSA,
      12                 :            :  * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
      13                 :            :  * included with this distribution is covered by the same copyright terms
      14                 :            :  * except that the holder is Tim Hudson (tjh@cryptsoft.com).
      15                 :            :  * 
      16                 :            :  * Copyright remains Eric Young's, and as such any Copyright notices in
      17                 :            :  * the code are not to be removed.
      18                 :            :  * If this package is used in a product, Eric Young should be given attribution
      19                 :            :  * as the author of the parts of the library used.
      20                 :            :  * This can be in the form of a textual message at program startup or
      21                 :            :  * in documentation (online or textual) provided with the package.
      22                 :            :  * 
      23                 :            :  * Redistribution and use in source and binary forms, with or without
      24                 :            :  * modification, are permitted provided that the following conditions
      25                 :            :  * are met:
      26                 :            :  * 1. Redistributions of source code must retain the copyright
      27                 :            :  *    notice, this list of conditions and the following disclaimer.
      28                 :            :  * 2. Redistributions in binary form must reproduce the above copyright
      29                 :            :  *    notice, this list of conditions and the following disclaimer in the
      30                 :            :  *    documentation and/or other materials provided with the distribution.
      31                 :            :  * 3. All advertising materials mentioning features or use of this software
      32                 :            :  *    must display the following acknowledgement:
      33                 :            :  *    "This product includes cryptographic software written by
      34                 :            :  *     Eric Young (eay@cryptsoft.com)"
      35                 :            :  *    The word 'cryptographic' can be left out if the rouines from the library
      36                 :            :  *    being used are not cryptographic related :-).
      37                 :            :  * 4. If you include any Windows specific code (or a derivative thereof) from 
      38                 :            :  *    the apps directory (application code) you must include an acknowledgement:
      39                 :            :  *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
      40                 :            :  * 
      41                 :            :  * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
      42                 :            :  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
      43                 :            :  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
      44                 :            :  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
      45                 :            :  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
      46                 :            :  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
      47                 :            :  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
      48                 :            :  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
      49                 :            :  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
      50                 :            :  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
      51                 :            :  * SUCH DAMAGE.
      52                 :            :  * 
      53                 :            :  * The licence and distribution terms for any publically available version or
      54                 :            :  * derivative of this code cannot be changed.  i.e. this code cannot simply be
      55                 :            :  * copied and put under another distribution licence
      56                 :            :  * [including the GNU Public Licence.]
      57                 :            :  */
      58                 :            : /* ====================================================================
      59                 :            :  * Copyright (c) 1998-2007 The OpenSSL Project.  All rights reserved.
      60                 :            :  *
      61                 :            :  * Redistribution and use in source and binary forms, with or without
      62                 :            :  * modification, are permitted provided that the following conditions
      63                 :            :  * are met:
      64                 :            :  *
      65                 :            :  * 1. Redistributions of source code must retain the above copyright
      66                 :            :  *    notice, this list of conditions and the following disclaimer. 
      67                 :            :  *
      68                 :            :  * 2. Redistributions in binary form must reproduce the above copyright
      69                 :            :  *    notice, this list of conditions and the following disclaimer in
      70                 :            :  *    the documentation and/or other materials provided with the
      71                 :            :  *    distribution.
      72                 :            :  *
      73                 :            :  * 3. All advertising materials mentioning features or use of this
      74                 :            :  *    software must display the following acknowledgment:
      75                 :            :  *    "This product includes software developed by the OpenSSL Project
      76                 :            :  *    for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
      77                 :            :  *
      78                 :            :  * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
      79                 :            :  *    endorse or promote products derived from this software without
      80                 :            :  *    prior written permission. For written permission, please contact
      81                 :            :  *    openssl-core@openssl.org.
      82                 :            :  *
      83                 :            :  * 5. Products derived from this software may not be called "OpenSSL"
      84                 :            :  *    nor may "OpenSSL" appear in their names without prior written
      85                 :            :  *    permission of the OpenSSL Project.
      86                 :            :  *
      87                 :            :  * 6. Redistributions of any form whatsoever must retain the following
      88                 :            :  *    acknowledgment:
      89                 :            :  *    "This product includes software developed by the OpenSSL Project
      90                 :            :  *    for use in the OpenSSL Toolkit (http://www.openssl.org/)"
      91                 :            :  *
      92                 :            :  * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
      93                 :            :  * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
      94                 :            :  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
      95                 :            :  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE OpenSSL PROJECT OR
      96                 :            :  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
      97                 :            :  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
      98                 :            :  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
      99                 :            :  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     100                 :            :  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
     101                 :            :  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     102                 :            :  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
     103                 :            :  * OF THE POSSIBILITY OF SUCH DAMAGE.
     104                 :            :  * ====================================================================
     105                 :            :  *
     106                 :            :  * This product includes cryptographic software written by Eric Young
     107                 :            :  * (eay@cryptsoft.com).  This product includes software written by Tim
     108                 :            :  * Hudson (tjh@cryptsoft.com).
     109                 :            :  *
     110                 :            :  */
     111                 :            : /* ====================================================================
     112                 :            :  * Copyright 2002 Sun Microsystems, Inc. ALL RIGHTS RESERVED.
     113                 :            :  *
     114                 :            :  * Portions of the attached software ("Contribution") are developed by 
     115                 :            :  * SUN MICROSYSTEMS, INC., and are contributed to the OpenSSL project.
     116                 :            :  *
     117                 :            :  * The Contribution is licensed pursuant to the OpenSSL open source
     118                 :            :  * license provided above.
     119                 :            :  *
     120                 :            :  * ECC cipher suite support in OpenSSL originally written by
     121                 :            :  * Vipul Gupta and Sumit Gupta of Sun Microsystems Laboratories.
     122                 :            :  *
     123                 :            :  */
     124                 :            : /* ====================================================================
     125                 :            :  * Copyright 2005 Nokia. All rights reserved.
     126                 :            :  *
     127                 :            :  * The portions of the attached software ("Contribution") is developed by
     128                 :            :  * Nokia Corporation and is licensed pursuant to the OpenSSL open source
     129                 :            :  * license.
     130                 :            :  *
     131                 :            :  * The Contribution, originally written by Mika Kousa and Pasi Eronen of
     132                 :            :  * Nokia Corporation, consists of the "PSK" (Pre-Shared Key) ciphersuites
     133                 :            :  * support (see RFC 4279) to OpenSSL.
     134                 :            :  *
     135                 :            :  * No patent licenses or other rights except those expressly stated in
     136                 :            :  * the OpenSSL open source license shall be deemed granted or received
     137                 :            :  * expressly, by implication, estoppel, or otherwise.
     138                 :            :  *
     139                 :            :  * No assurances are provided by Nokia that the Contribution does not
     140                 :            :  * infringe the patent or other intellectual property rights of any third
     141                 :            :  * party or that the license provides you with all the necessary rights
     142                 :            :  * to make use of the Contribution.
     143                 :            :  *
     144                 :            :  * THE SOFTWARE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. IN
     145                 :            :  * ADDITION TO THE DISCLAIMERS INCLUDED IN THE LICENSE, NOKIA
     146                 :            :  * SPECIFICALLY DISCLAIMS ANY LIABILITY FOR CLAIMS BROUGHT BY YOU OR ANY
     147                 :            :  * OTHER ENTITY BASED ON INFRINGEMENT OF INTELLECTUAL PROPERTY RIGHTS OR
     148                 :            :  * OTHERWISE.
     149                 :            :  */
     150                 :            : 
     151                 :            : #include <stdio.h>
     152                 :            : #include <openssl/objects.h>
     153                 :            : #include "ssl_locl.h"
     154                 :            : #include "kssl_lcl.h"
     155                 :            : #include <openssl/md5.h>
     156                 :            : #ifndef OPENSSL_NO_DH
     157                 :            : #include <openssl/dh.h>
     158                 :            : #endif
     159                 :            : 
     160                 :            : const char ssl3_version_str[]="SSLv3" OPENSSL_VERSION_PTEXT;
     161                 :            : 
     162                 :            : #define SSL3_NUM_CIPHERS        (sizeof(ssl3_ciphers)/sizeof(SSL_CIPHER))
     163                 :            : 
     164                 :            : /* list of available SSLv3 ciphers (sorted by id) */
     165                 :            : OPENSSL_GLOBAL const SSL_CIPHER ssl3_ciphers[]={
     166                 :            : 
     167                 :            : /* The RSA ciphers */
     168                 :            : /* Cipher 01 */
     169                 :            :         {
     170                 :            :         1,
     171                 :            :         SSL3_TXT_RSA_NULL_MD5,
     172                 :            :         SSL3_CK_RSA_NULL_MD5,
     173                 :            :         SSL_kRSA,
     174                 :            :         SSL_aRSA,
     175                 :            :         SSL_eNULL,
     176                 :            :         SSL_MD5,
     177                 :            :         SSL_SSLV3,
     178                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE,
     179                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     180                 :            :         0,
     181                 :            :         0,
     182                 :            :         },
     183                 :            : 
     184                 :            : /* Cipher 02 */
     185                 :            :         {
     186                 :            :         1,
     187                 :            :         SSL3_TXT_RSA_NULL_SHA,
     188                 :            :         SSL3_CK_RSA_NULL_SHA,
     189                 :            :         SSL_kRSA,
     190                 :            :         SSL_aRSA,
     191                 :            :         SSL_eNULL,
     192                 :            :         SSL_SHA1,
     193                 :            :         SSL_SSLV3,
     194                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
     195                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     196                 :            :         0,
     197                 :            :         0,
     198                 :            :         },
     199                 :            : 
     200                 :            : /* Cipher 03 */
     201                 :            :         {
     202                 :            :         1,
     203                 :            :         SSL3_TXT_RSA_RC4_40_MD5,
     204                 :            :         SSL3_CK_RSA_RC4_40_MD5,
     205                 :            :         SSL_kRSA,
     206                 :            :         SSL_aRSA,
     207                 :            :         SSL_RC4,
     208                 :            :         SSL_MD5,
     209                 :            :         SSL_SSLV3,
     210                 :            :         SSL_EXPORT|SSL_EXP40,
     211                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     212                 :            :         40,
     213                 :            :         128,
     214                 :            :         },
     215                 :            : 
     216                 :            : /* Cipher 04 */
     217                 :            :         {
     218                 :            :         1,
     219                 :            :         SSL3_TXT_RSA_RC4_128_MD5,
     220                 :            :         SSL3_CK_RSA_RC4_128_MD5,
     221                 :            :         SSL_kRSA,
     222                 :            :         SSL_aRSA,
     223                 :            :         SSL_RC4,
     224                 :            :         SSL_MD5,
     225                 :            :         SSL_SSLV3,
     226                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     227                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     228                 :            :         128,
     229                 :            :         128,
     230                 :            :         },
     231                 :            : 
     232                 :            : /* Cipher 05 */
     233                 :            :         {
     234                 :            :         1,
     235                 :            :         SSL3_TXT_RSA_RC4_128_SHA,
     236                 :            :         SSL3_CK_RSA_RC4_128_SHA,
     237                 :            :         SSL_kRSA,
     238                 :            :         SSL_aRSA,
     239                 :            :         SSL_RC4,
     240                 :            :         SSL_SHA1,
     241                 :            :         SSL_SSLV3,
     242                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     243                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     244                 :            :         128,
     245                 :            :         128,
     246                 :            :         },
     247                 :            : 
     248                 :            : /* Cipher 06 */
     249                 :            :         {
     250                 :            :         1,
     251                 :            :         SSL3_TXT_RSA_RC2_40_MD5,
     252                 :            :         SSL3_CK_RSA_RC2_40_MD5,
     253                 :            :         SSL_kRSA,
     254                 :            :         SSL_aRSA,
     255                 :            :         SSL_RC2,
     256                 :            :         SSL_MD5,
     257                 :            :         SSL_SSLV3,
     258                 :            :         SSL_EXPORT|SSL_EXP40,
     259                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     260                 :            :         40,
     261                 :            :         128,
     262                 :            :         },
     263                 :            : 
     264                 :            : /* Cipher 07 */
     265                 :            : #ifndef OPENSSL_NO_IDEA
     266                 :            :         {
     267                 :            :         1,
     268                 :            :         SSL3_TXT_RSA_IDEA_128_SHA,
     269                 :            :         SSL3_CK_RSA_IDEA_128_SHA,
     270                 :            :         SSL_kRSA,
     271                 :            :         SSL_aRSA,
     272                 :            :         SSL_IDEA,
     273                 :            :         SSL_SHA1,
     274                 :            :         SSL_SSLV3,
     275                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     276                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     277                 :            :         128,
     278                 :            :         128,
     279                 :            :         },
     280                 :            : #endif
     281                 :            : 
     282                 :            : /* Cipher 08 */
     283                 :            :         {
     284                 :            :         1,
     285                 :            :         SSL3_TXT_RSA_DES_40_CBC_SHA,
     286                 :            :         SSL3_CK_RSA_DES_40_CBC_SHA,
     287                 :            :         SSL_kRSA,
     288                 :            :         SSL_aRSA,
     289                 :            :         SSL_DES,
     290                 :            :         SSL_SHA1,
     291                 :            :         SSL_SSLV3,
     292                 :            :         SSL_EXPORT|SSL_EXP40,
     293                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     294                 :            :         40,
     295                 :            :         56,
     296                 :            :         },
     297                 :            : 
     298                 :            : /* Cipher 09 */
     299                 :            :         {
     300                 :            :         1,
     301                 :            :         SSL3_TXT_RSA_DES_64_CBC_SHA,
     302                 :            :         SSL3_CK_RSA_DES_64_CBC_SHA,
     303                 :            :         SSL_kRSA,
     304                 :            :         SSL_aRSA,
     305                 :            :         SSL_DES,
     306                 :            :         SSL_SHA1,
     307                 :            :         SSL_SSLV3,
     308                 :            :         SSL_NOT_EXP|SSL_LOW,
     309                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     310                 :            :         56,
     311                 :            :         56,
     312                 :            :         },
     313                 :            : 
     314                 :            : /* Cipher 0A */
     315                 :            :         {
     316                 :            :         1,
     317                 :            :         SSL3_TXT_RSA_DES_192_CBC3_SHA,
     318                 :            :         SSL3_CK_RSA_DES_192_CBC3_SHA,
     319                 :            :         SSL_kRSA,
     320                 :            :         SSL_aRSA,
     321                 :            :         SSL_3DES,
     322                 :            :         SSL_SHA1,
     323                 :            :         SSL_SSLV3,
     324                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     325                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     326                 :            :         112,
     327                 :            :         168,
     328                 :            :         },
     329                 :            : 
     330                 :            : /* The DH ciphers */
     331                 :            : /* Cipher 0B */
     332                 :            :         {
     333                 :            :         1,
     334                 :            :         SSL3_TXT_DH_DSS_DES_40_CBC_SHA,
     335                 :            :         SSL3_CK_DH_DSS_DES_40_CBC_SHA,
     336                 :            :         SSL_kDHd,
     337                 :            :         SSL_aDH,
     338                 :            :         SSL_DES,
     339                 :            :         SSL_SHA1,
     340                 :            :         SSL_SSLV3,
     341                 :            :         SSL_EXPORT|SSL_EXP40,
     342                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     343                 :            :         40,
     344                 :            :         56,
     345                 :            :         },
     346                 :            : 
     347                 :            : /* Cipher 0C */
     348                 :            :         {
     349                 :            :         1,
     350                 :            :         SSL3_TXT_DH_DSS_DES_64_CBC_SHA,
     351                 :            :         SSL3_CK_DH_DSS_DES_64_CBC_SHA,
     352                 :            :         SSL_kDHd,
     353                 :            :         SSL_aDH,
     354                 :            :         SSL_DES,
     355                 :            :         SSL_SHA1,
     356                 :            :         SSL_SSLV3,
     357                 :            :         SSL_NOT_EXP|SSL_LOW,
     358                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     359                 :            :         56,
     360                 :            :         56,
     361                 :            :         },
     362                 :            : 
     363                 :            : /* Cipher 0D */
     364                 :            :         {
     365                 :            :         1,
     366                 :            :         SSL3_TXT_DH_DSS_DES_192_CBC3_SHA,
     367                 :            :         SSL3_CK_DH_DSS_DES_192_CBC3_SHA,
     368                 :            :         SSL_kDHd,
     369                 :            :         SSL_aDH,
     370                 :            :         SSL_3DES,
     371                 :            :         SSL_SHA1,
     372                 :            :         SSL_SSLV3,
     373                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     374                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     375                 :            :         112,
     376                 :            :         168,
     377                 :            :         },
     378                 :            : 
     379                 :            : /* Cipher 0E */
     380                 :            :         {
     381                 :            :         1,
     382                 :            :         SSL3_TXT_DH_RSA_DES_40_CBC_SHA,
     383                 :            :         SSL3_CK_DH_RSA_DES_40_CBC_SHA,
     384                 :            :         SSL_kDHr,
     385                 :            :         SSL_aDH,
     386                 :            :         SSL_DES,
     387                 :            :         SSL_SHA1,
     388                 :            :         SSL_SSLV3,
     389                 :            :         SSL_EXPORT|SSL_EXP40,
     390                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     391                 :            :         40,
     392                 :            :         56,
     393                 :            :         },
     394                 :            : 
     395                 :            : /* Cipher 0F */
     396                 :            :         {
     397                 :            :         1,
     398                 :            :         SSL3_TXT_DH_RSA_DES_64_CBC_SHA,
     399                 :            :         SSL3_CK_DH_RSA_DES_64_CBC_SHA,
     400                 :            :         SSL_kDHr,
     401                 :            :         SSL_aDH,
     402                 :            :         SSL_DES,
     403                 :            :         SSL_SHA1,
     404                 :            :         SSL_SSLV3,
     405                 :            :         SSL_NOT_EXP|SSL_LOW,
     406                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     407                 :            :         56,
     408                 :            :         56,
     409                 :            :         },
     410                 :            : 
     411                 :            : /* Cipher 10 */
     412                 :            :         {
     413                 :            :         1,
     414                 :            :         SSL3_TXT_DH_RSA_DES_192_CBC3_SHA,
     415                 :            :         SSL3_CK_DH_RSA_DES_192_CBC3_SHA,
     416                 :            :         SSL_kDHr,
     417                 :            :         SSL_aDH,
     418                 :            :         SSL_3DES,
     419                 :            :         SSL_SHA1,
     420                 :            :         SSL_SSLV3,
     421                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     422                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     423                 :            :         112,
     424                 :            :         168,
     425                 :            :         },
     426                 :            : 
     427                 :            : /* The Ephemeral DH ciphers */
     428                 :            : /* Cipher 11 */
     429                 :            :         {
     430                 :            :         1,
     431                 :            :         SSL3_TXT_DHE_DSS_DES_40_CBC_SHA,
     432                 :            :         SSL3_CK_DHE_DSS_DES_40_CBC_SHA,
     433                 :            :         SSL_kDHE,
     434                 :            :         SSL_aDSS,
     435                 :            :         SSL_DES,
     436                 :            :         SSL_SHA1,
     437                 :            :         SSL_SSLV3,
     438                 :            :         SSL_EXPORT|SSL_EXP40,
     439                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     440                 :            :         40,
     441                 :            :         56,
     442                 :            :         },
     443                 :            : 
     444                 :            : /* Cipher 12 */
     445                 :            :         {
     446                 :            :         1,
     447                 :            :         SSL3_TXT_DHE_DSS_DES_64_CBC_SHA,
     448                 :            :         SSL3_CK_DHE_DSS_DES_64_CBC_SHA,
     449                 :            :         SSL_kDHE,
     450                 :            :         SSL_aDSS,
     451                 :            :         SSL_DES,
     452                 :            :         SSL_SHA1,
     453                 :            :         SSL_SSLV3,
     454                 :            :         SSL_NOT_EXP|SSL_LOW,
     455                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     456                 :            :         56,
     457                 :            :         56,
     458                 :            :         },
     459                 :            : 
     460                 :            : /* Cipher 13 */
     461                 :            :         {
     462                 :            :         1,
     463                 :            :         SSL3_TXT_DHE_DSS_DES_192_CBC3_SHA,
     464                 :            :         SSL3_CK_DHE_DSS_DES_192_CBC3_SHA,
     465                 :            :         SSL_kDHE,
     466                 :            :         SSL_aDSS,
     467                 :            :         SSL_3DES,
     468                 :            :         SSL_SHA1,
     469                 :            :         SSL_SSLV3,
     470                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     471                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     472                 :            :         112,
     473                 :            :         168,
     474                 :            :         },
     475                 :            : 
     476                 :            : /* Cipher 14 */
     477                 :            :         {
     478                 :            :         1,
     479                 :            :         SSL3_TXT_DHE_RSA_DES_40_CBC_SHA,
     480                 :            :         SSL3_CK_DHE_RSA_DES_40_CBC_SHA,
     481                 :            :         SSL_kDHE,
     482                 :            :         SSL_aRSA,
     483                 :            :         SSL_DES,
     484                 :            :         SSL_SHA1,
     485                 :            :         SSL_SSLV3,
     486                 :            :         SSL_EXPORT|SSL_EXP40,
     487                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     488                 :            :         40,
     489                 :            :         56,
     490                 :            :         },
     491                 :            : 
     492                 :            : /* Cipher 15 */
     493                 :            :         {
     494                 :            :         1,
     495                 :            :         SSL3_TXT_DHE_RSA_DES_64_CBC_SHA,
     496                 :            :         SSL3_CK_DHE_RSA_DES_64_CBC_SHA,
     497                 :            :         SSL_kDHE,
     498                 :            :         SSL_aRSA,
     499                 :            :         SSL_DES,
     500                 :            :         SSL_SHA1,
     501                 :            :         SSL_SSLV3,
     502                 :            :         SSL_NOT_EXP|SSL_LOW,
     503                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     504                 :            :         56,
     505                 :            :         56,
     506                 :            :         },
     507                 :            : 
     508                 :            : /* Cipher 16 */
     509                 :            :         {
     510                 :            :         1,
     511                 :            :         SSL3_TXT_DHE_RSA_DES_192_CBC3_SHA,
     512                 :            :         SSL3_CK_DHE_RSA_DES_192_CBC3_SHA,
     513                 :            :         SSL_kDHE,
     514                 :            :         SSL_aRSA,
     515                 :            :         SSL_3DES,
     516                 :            :         SSL_SHA1,
     517                 :            :         SSL_SSLV3,
     518                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     519                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     520                 :            :         112,
     521                 :            :         168,
     522                 :            :         },
     523                 :            : 
     524                 :            : /* Cipher 17 */
     525                 :            :         {
     526                 :            :         1,
     527                 :            :         SSL3_TXT_ADH_RC4_40_MD5,
     528                 :            :         SSL3_CK_ADH_RC4_40_MD5,
     529                 :            :         SSL_kDHE,
     530                 :            :         SSL_aNULL,
     531                 :            :         SSL_RC4,
     532                 :            :         SSL_MD5,
     533                 :            :         SSL_SSLV3,
     534                 :            :         SSL_EXPORT|SSL_EXP40,
     535                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     536                 :            :         40,
     537                 :            :         128,
     538                 :            :         },
     539                 :            : 
     540                 :            : /* Cipher 18 */
     541                 :            :         {
     542                 :            :         1,
     543                 :            :         SSL3_TXT_ADH_RC4_128_MD5,
     544                 :            :         SSL3_CK_ADH_RC4_128_MD5,
     545                 :            :         SSL_kDHE,
     546                 :            :         SSL_aNULL,
     547                 :            :         SSL_RC4,
     548                 :            :         SSL_MD5,
     549                 :            :         SSL_SSLV3,
     550                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     551                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     552                 :            :         128,
     553                 :            :         128,
     554                 :            :         },
     555                 :            : 
     556                 :            : /* Cipher 19 */
     557                 :            :         {
     558                 :            :         1,
     559                 :            :         SSL3_TXT_ADH_DES_40_CBC_SHA,
     560                 :            :         SSL3_CK_ADH_DES_40_CBC_SHA,
     561                 :            :         SSL_kDHE,
     562                 :            :         SSL_aNULL,
     563                 :            :         SSL_DES,
     564                 :            :         SSL_SHA1,
     565                 :            :         SSL_SSLV3,
     566                 :            :         SSL_EXPORT|SSL_EXP40,
     567                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     568                 :            :         40,
     569                 :            :         128,
     570                 :            :         },
     571                 :            : 
     572                 :            : /* Cipher 1A */
     573                 :            :         {
     574                 :            :         1,
     575                 :            :         SSL3_TXT_ADH_DES_64_CBC_SHA,
     576                 :            :         SSL3_CK_ADH_DES_64_CBC_SHA,
     577                 :            :         SSL_kDHE,
     578                 :            :         SSL_aNULL,
     579                 :            :         SSL_DES,
     580                 :            :         SSL_SHA1,
     581                 :            :         SSL_SSLV3,
     582                 :            :         SSL_NOT_EXP|SSL_LOW,
     583                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     584                 :            :         56,
     585                 :            :         56,
     586                 :            :         },
     587                 :            : 
     588                 :            : /* Cipher 1B */
     589                 :            :         {
     590                 :            :         1,
     591                 :            :         SSL3_TXT_ADH_DES_192_CBC_SHA,
     592                 :            :         SSL3_CK_ADH_DES_192_CBC_SHA,
     593                 :            :         SSL_kDHE,
     594                 :            :         SSL_aNULL,
     595                 :            :         SSL_3DES,
     596                 :            :         SSL_SHA1,
     597                 :            :         SSL_SSLV3,
     598                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     599                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     600                 :            :         112,
     601                 :            :         168,
     602                 :            :         },
     603                 :            : 
     604                 :            : /* Fortezza ciphersuite from SSL 3.0 spec */
     605                 :            : #if 0
     606                 :            : /* Cipher 1C */
     607                 :            :         {
     608                 :            :         0,
     609                 :            :         SSL3_TXT_FZA_DMS_NULL_SHA,
     610                 :            :         SSL3_CK_FZA_DMS_NULL_SHA,
     611                 :            :         SSL_kFZA,
     612                 :            :         SSL_aFZA,
     613                 :            :         SSL_eNULL,
     614                 :            :         SSL_SHA1,
     615                 :            :         SSL_SSLV3,
     616                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE,
     617                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     618                 :            :         0,
     619                 :            :         0,
     620                 :            :         },
     621                 :            : 
     622                 :            : /* Cipher 1D */
     623                 :            :         {
     624                 :            :         0,
     625                 :            :         SSL3_TXT_FZA_DMS_FZA_SHA,
     626                 :            :         SSL3_CK_FZA_DMS_FZA_SHA,
     627                 :            :         SSL_kFZA,
     628                 :            :         SSL_aFZA,
     629                 :            :         SSL_eFZA,
     630                 :            :         SSL_SHA1,
     631                 :            :         SSL_SSLV3,
     632                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE,
     633                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     634                 :            :         0,
     635                 :            :         0,
     636                 :            :         },
     637                 :            : 
     638                 :            : /* Cipher 1E */
     639                 :            :         {
     640                 :            :         0,
     641                 :            :         SSL3_TXT_FZA_DMS_RC4_SHA,
     642                 :            :         SSL3_CK_FZA_DMS_RC4_SHA,
     643                 :            :         SSL_kFZA,
     644                 :            :         SSL_aFZA,
     645                 :            :         SSL_RC4,
     646                 :            :         SSL_SHA1,
     647                 :            :         SSL_SSLV3,
     648                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     649                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     650                 :            :         128,
     651                 :            :         128,
     652                 :            :         },
     653                 :            : #endif
     654                 :            : 
     655                 :            : #ifndef OPENSSL_NO_KRB5
     656                 :            : /* The Kerberos ciphers*/
     657                 :            : /* Cipher 1E */
     658                 :            :         {
     659                 :            :         1,
     660                 :            :         SSL3_TXT_KRB5_DES_64_CBC_SHA,
     661                 :            :         SSL3_CK_KRB5_DES_64_CBC_SHA,
     662                 :            :         SSL_kKRB5,
     663                 :            :         SSL_aKRB5,
     664                 :            :         SSL_DES,
     665                 :            :         SSL_SHA1,
     666                 :            :         SSL_SSLV3,
     667                 :            :         SSL_NOT_EXP|SSL_LOW,
     668                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     669                 :            :         56,
     670                 :            :         56,
     671                 :            :         },
     672                 :            : 
     673                 :            : /* Cipher 1F */
     674                 :            :         {
     675                 :            :         1,
     676                 :            :         SSL3_TXT_KRB5_DES_192_CBC3_SHA,
     677                 :            :         SSL3_CK_KRB5_DES_192_CBC3_SHA,
     678                 :            :         SSL_kKRB5,
     679                 :            :         SSL_aKRB5,
     680                 :            :         SSL_3DES,
     681                 :            :         SSL_SHA1,
     682                 :            :         SSL_SSLV3,
     683                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     684                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     685                 :            :         112,
     686                 :            :         168,
     687                 :            :         },
     688                 :            : 
     689                 :            : /* Cipher 20 */
     690                 :            :         {
     691                 :            :         1,
     692                 :            :         SSL3_TXT_KRB5_RC4_128_SHA,
     693                 :            :         SSL3_CK_KRB5_RC4_128_SHA,
     694                 :            :         SSL_kKRB5,
     695                 :            :         SSL_aKRB5,
     696                 :            :         SSL_RC4,
     697                 :            :         SSL_SHA1,
     698                 :            :         SSL_SSLV3,
     699                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     700                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     701                 :            :         128,
     702                 :            :         128,
     703                 :            :         },
     704                 :            : 
     705                 :            : /* Cipher 21 */
     706                 :            :         {
     707                 :            :         1,
     708                 :            :         SSL3_TXT_KRB5_IDEA_128_CBC_SHA,
     709                 :            :         SSL3_CK_KRB5_IDEA_128_CBC_SHA,
     710                 :            :         SSL_kKRB5,
     711                 :            :         SSL_aKRB5,
     712                 :            :         SSL_IDEA,
     713                 :            :         SSL_SHA1,
     714                 :            :         SSL_SSLV3,
     715                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     716                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     717                 :            :         128,
     718                 :            :         128,
     719                 :            :         },
     720                 :            : 
     721                 :            : /* Cipher 22 */
     722                 :            :         {
     723                 :            :         1,
     724                 :            :         SSL3_TXT_KRB5_DES_64_CBC_MD5,
     725                 :            :         SSL3_CK_KRB5_DES_64_CBC_MD5,
     726                 :            :         SSL_kKRB5,
     727                 :            :         SSL_aKRB5,
     728                 :            :         SSL_DES,
     729                 :            :         SSL_MD5,
     730                 :            :         SSL_SSLV3,
     731                 :            :         SSL_NOT_EXP|SSL_LOW,
     732                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     733                 :            :         56,
     734                 :            :         56,
     735                 :            :         },
     736                 :            : 
     737                 :            : /* Cipher 23 */
     738                 :            :         {
     739                 :            :         1,
     740                 :            :         SSL3_TXT_KRB5_DES_192_CBC3_MD5,
     741                 :            :         SSL3_CK_KRB5_DES_192_CBC3_MD5,
     742                 :            :         SSL_kKRB5,
     743                 :            :         SSL_aKRB5,
     744                 :            :         SSL_3DES,
     745                 :            :         SSL_MD5,
     746                 :            :         SSL_SSLV3,
     747                 :            :         SSL_NOT_EXP|SSL_HIGH,
     748                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     749                 :            :         112,
     750                 :            :         168,
     751                 :            :         },
     752                 :            : 
     753                 :            : /* Cipher 24 */
     754                 :            :         {
     755                 :            :         1,
     756                 :            :         SSL3_TXT_KRB5_RC4_128_MD5,
     757                 :            :         SSL3_CK_KRB5_RC4_128_MD5,
     758                 :            :         SSL_kKRB5,
     759                 :            :         SSL_aKRB5,
     760                 :            :         SSL_RC4,
     761                 :            :         SSL_MD5,
     762                 :            :         SSL_SSLV3,
     763                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     764                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     765                 :            :         128,
     766                 :            :         128,
     767                 :            :         },
     768                 :            : 
     769                 :            : /* Cipher 25 */
     770                 :            :         {
     771                 :            :         1,
     772                 :            :         SSL3_TXT_KRB5_IDEA_128_CBC_MD5,
     773                 :            :         SSL3_CK_KRB5_IDEA_128_CBC_MD5,
     774                 :            :         SSL_kKRB5,
     775                 :            :         SSL_aKRB5,
     776                 :            :         SSL_IDEA,
     777                 :            :         SSL_MD5,
     778                 :            :         SSL_SSLV3,
     779                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
     780                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     781                 :            :         128,
     782                 :            :         128,
     783                 :            :         },
     784                 :            : 
     785                 :            : /* Cipher 26 */
     786                 :            :         {
     787                 :            :         1,
     788                 :            :         SSL3_TXT_KRB5_DES_40_CBC_SHA,
     789                 :            :         SSL3_CK_KRB5_DES_40_CBC_SHA,
     790                 :            :         SSL_kKRB5,
     791                 :            :         SSL_aKRB5,
     792                 :            :         SSL_DES,
     793                 :            :         SSL_SHA1,
     794                 :            :         SSL_SSLV3,
     795                 :            :         SSL_EXPORT|SSL_EXP40,
     796                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     797                 :            :         40,
     798                 :            :         56,
     799                 :            :         },
     800                 :            : 
     801                 :            : /* Cipher 27 */
     802                 :            :         {
     803                 :            :         1,
     804                 :            :         SSL3_TXT_KRB5_RC2_40_CBC_SHA,
     805                 :            :         SSL3_CK_KRB5_RC2_40_CBC_SHA,
     806                 :            :         SSL_kKRB5,
     807                 :            :         SSL_aKRB5,
     808                 :            :         SSL_RC2,
     809                 :            :         SSL_SHA1,
     810                 :            :         SSL_SSLV3,
     811                 :            :         SSL_EXPORT|SSL_EXP40,
     812                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     813                 :            :         40,
     814                 :            :         128,
     815                 :            :         },
     816                 :            : 
     817                 :            : /* Cipher 28 */
     818                 :            :         {
     819                 :            :         1,
     820                 :            :         SSL3_TXT_KRB5_RC4_40_SHA,
     821                 :            :         SSL3_CK_KRB5_RC4_40_SHA,
     822                 :            :         SSL_kKRB5,
     823                 :            :         SSL_aKRB5,
     824                 :            :         SSL_RC4,
     825                 :            :         SSL_SHA1,
     826                 :            :         SSL_SSLV3,
     827                 :            :         SSL_EXPORT|SSL_EXP40,
     828                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     829                 :            :         40,
     830                 :            :         128,
     831                 :            :         },
     832                 :            : 
     833                 :            : /* Cipher 29 */
     834                 :            :         {
     835                 :            :         1,
     836                 :            :         SSL3_TXT_KRB5_DES_40_CBC_MD5,
     837                 :            :         SSL3_CK_KRB5_DES_40_CBC_MD5,
     838                 :            :         SSL_kKRB5,
     839                 :            :         SSL_aKRB5,
     840                 :            :         SSL_DES,
     841                 :            :         SSL_MD5,
     842                 :            :         SSL_SSLV3,
     843                 :            :         SSL_EXPORT|SSL_EXP40,
     844                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     845                 :            :         40,
     846                 :            :         56,
     847                 :            :         },
     848                 :            : 
     849                 :            : /* Cipher 2A */
     850                 :            :         {
     851                 :            :         1,
     852                 :            :         SSL3_TXT_KRB5_RC2_40_CBC_MD5,
     853                 :            :         SSL3_CK_KRB5_RC2_40_CBC_MD5,
     854                 :            :         SSL_kKRB5,
     855                 :            :         SSL_aKRB5,
     856                 :            :         SSL_RC2,
     857                 :            :         SSL_MD5,
     858                 :            :         SSL_SSLV3,
     859                 :            :         SSL_EXPORT|SSL_EXP40,
     860                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     861                 :            :         40,
     862                 :            :         128,
     863                 :            :         },
     864                 :            : 
     865                 :            : /* Cipher 2B */
     866                 :            :         {
     867                 :            :         1,
     868                 :            :         SSL3_TXT_KRB5_RC4_40_MD5,
     869                 :            :         SSL3_CK_KRB5_RC4_40_MD5,
     870                 :            :         SSL_kKRB5,
     871                 :            :         SSL_aKRB5,
     872                 :            :         SSL_RC4,
     873                 :            :         SSL_MD5,
     874                 :            :         SSL_SSLV3,
     875                 :            :         SSL_EXPORT|SSL_EXP40,
     876                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     877                 :            :         40,
     878                 :            :         128,
     879                 :            :         },
     880                 :            : #endif  /* OPENSSL_NO_KRB5 */
     881                 :            : 
     882                 :            : /* New AES ciphersuites */
     883                 :            : /* Cipher 2F */
     884                 :            :         {
     885                 :            :         1,
     886                 :            :         TLS1_TXT_RSA_WITH_AES_128_SHA,
     887                 :            :         TLS1_CK_RSA_WITH_AES_128_SHA,
     888                 :            :         SSL_kRSA,
     889                 :            :         SSL_aRSA,
     890                 :            :         SSL_AES128,
     891                 :            :         SSL_SHA1,
     892                 :            :         SSL_TLSV1,
     893                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     894                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     895                 :            :         128,
     896                 :            :         128,
     897                 :            :         },
     898                 :            : /* Cipher 30 */
     899                 :            :         {
     900                 :            :         1,
     901                 :            :         TLS1_TXT_DH_DSS_WITH_AES_128_SHA,
     902                 :            :         TLS1_CK_DH_DSS_WITH_AES_128_SHA,
     903                 :            :         SSL_kDHd,
     904                 :            :         SSL_aDH,
     905                 :            :         SSL_AES128,
     906                 :            :         SSL_SHA1,
     907                 :            :         SSL_TLSV1,
     908                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     909                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     910                 :            :         128,
     911                 :            :         128,
     912                 :            :         },
     913                 :            : /* Cipher 31 */
     914                 :            :         {
     915                 :            :         1,
     916                 :            :         TLS1_TXT_DH_RSA_WITH_AES_128_SHA,
     917                 :            :         TLS1_CK_DH_RSA_WITH_AES_128_SHA,
     918                 :            :         SSL_kDHr,
     919                 :            :         SSL_aDH,
     920                 :            :         SSL_AES128,
     921                 :            :         SSL_SHA1,
     922                 :            :         SSL_TLSV1,
     923                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     924                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     925                 :            :         128,
     926                 :            :         128,
     927                 :            :         },
     928                 :            : /* Cipher 32 */
     929                 :            :         {
     930                 :            :         1,
     931                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_128_SHA,
     932                 :            :         TLS1_CK_DHE_DSS_WITH_AES_128_SHA,
     933                 :            :         SSL_kDHE,
     934                 :            :         SSL_aDSS,
     935                 :            :         SSL_AES128,
     936                 :            :         SSL_SHA1,
     937                 :            :         SSL_TLSV1,
     938                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     939                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     940                 :            :         128,
     941                 :            :         128,
     942                 :            :         },
     943                 :            : /* Cipher 33 */
     944                 :            :         {
     945                 :            :         1,
     946                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_128_SHA,
     947                 :            :         TLS1_CK_DHE_RSA_WITH_AES_128_SHA,
     948                 :            :         SSL_kDHE,
     949                 :            :         SSL_aRSA,
     950                 :            :         SSL_AES128,
     951                 :            :         SSL_SHA1,
     952                 :            :         SSL_TLSV1,
     953                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     954                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     955                 :            :         128,
     956                 :            :         128,
     957                 :            :         },
     958                 :            : /* Cipher 34 */
     959                 :            :         {
     960                 :            :         1,
     961                 :            :         TLS1_TXT_ADH_WITH_AES_128_SHA,
     962                 :            :         TLS1_CK_ADH_WITH_AES_128_SHA,
     963                 :            :         SSL_kDHE,
     964                 :            :         SSL_aNULL,
     965                 :            :         SSL_AES128,
     966                 :            :         SSL_SHA1,
     967                 :            :         SSL_TLSV1,
     968                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     969                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     970                 :            :         128,
     971                 :            :         128,
     972                 :            :         },
     973                 :            : 
     974                 :            : /* Cipher 35 */
     975                 :            :         {
     976                 :            :         1,
     977                 :            :         TLS1_TXT_RSA_WITH_AES_256_SHA,
     978                 :            :         TLS1_CK_RSA_WITH_AES_256_SHA,
     979                 :            :         SSL_kRSA,
     980                 :            :         SSL_aRSA,
     981                 :            :         SSL_AES256,
     982                 :            :         SSL_SHA1,
     983                 :            :         SSL_TLSV1,
     984                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
     985                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
     986                 :            :         256,
     987                 :            :         256,
     988                 :            :         },
     989                 :            : /* Cipher 36 */
     990                 :            :         {
     991                 :            :         1,
     992                 :            :         TLS1_TXT_DH_DSS_WITH_AES_256_SHA,
     993                 :            :         TLS1_CK_DH_DSS_WITH_AES_256_SHA,
     994                 :            :         SSL_kDHd,
     995                 :            :         SSL_aDH,
     996                 :            :         SSL_AES256,
     997                 :            :         SSL_SHA1,
     998                 :            :         SSL_TLSV1,
     999                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1000                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1001                 :            :         256,
    1002                 :            :         256,
    1003                 :            :         },
    1004                 :            : 
    1005                 :            : /* Cipher 37 */
    1006                 :            :         {
    1007                 :            :         1,
    1008                 :            :         TLS1_TXT_DH_RSA_WITH_AES_256_SHA,
    1009                 :            :         TLS1_CK_DH_RSA_WITH_AES_256_SHA,
    1010                 :            :         SSL_kDHr,
    1011                 :            :         SSL_aDH,
    1012                 :            :         SSL_AES256,
    1013                 :            :         SSL_SHA1,
    1014                 :            :         SSL_TLSV1,
    1015                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1016                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1017                 :            :         256,
    1018                 :            :         256,
    1019                 :            :         },
    1020                 :            : 
    1021                 :            : /* Cipher 38 */
    1022                 :            :         {
    1023                 :            :         1,
    1024                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_256_SHA,
    1025                 :            :         TLS1_CK_DHE_DSS_WITH_AES_256_SHA,
    1026                 :            :         SSL_kDHE,
    1027                 :            :         SSL_aDSS,
    1028                 :            :         SSL_AES256,
    1029                 :            :         SSL_SHA1,
    1030                 :            :         SSL_TLSV1,
    1031                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1032                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1033                 :            :         256,
    1034                 :            :         256,
    1035                 :            :         },
    1036                 :            : 
    1037                 :            : /* Cipher 39 */
    1038                 :            :         {
    1039                 :            :         1,
    1040                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_256_SHA,
    1041                 :            :         TLS1_CK_DHE_RSA_WITH_AES_256_SHA,
    1042                 :            :         SSL_kDHE,
    1043                 :            :         SSL_aRSA,
    1044                 :            :         SSL_AES256,
    1045                 :            :         SSL_SHA1,
    1046                 :            :         SSL_TLSV1,
    1047                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1048                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1049                 :            :         256,
    1050                 :            :         256,
    1051                 :            :         },
    1052                 :            : 
    1053                 :            :         /* Cipher 3A */
    1054                 :            :         {
    1055                 :            :         1,
    1056                 :            :         TLS1_TXT_ADH_WITH_AES_256_SHA,
    1057                 :            :         TLS1_CK_ADH_WITH_AES_256_SHA,
    1058                 :            :         SSL_kDHE,
    1059                 :            :         SSL_aNULL,
    1060                 :            :         SSL_AES256,
    1061                 :            :         SSL_SHA1,
    1062                 :            :         SSL_TLSV1,
    1063                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1064                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1065                 :            :         256,
    1066                 :            :         256,
    1067                 :            :         },
    1068                 :            : 
    1069                 :            :         /* TLS v1.2 ciphersuites */
    1070                 :            :         /* Cipher 3B */
    1071                 :            :         {
    1072                 :            :         1,
    1073                 :            :         TLS1_TXT_RSA_WITH_NULL_SHA256,
    1074                 :            :         TLS1_CK_RSA_WITH_NULL_SHA256,
    1075                 :            :         SSL_kRSA,
    1076                 :            :         SSL_aRSA,
    1077                 :            :         SSL_eNULL,
    1078                 :            :         SSL_SHA256,
    1079                 :            :         SSL_TLSV1_2,
    1080                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    1081                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1082                 :            :         0,
    1083                 :            :         0,
    1084                 :            :         },
    1085                 :            : 
    1086                 :            :         /* Cipher 3C */
    1087                 :            :         {
    1088                 :            :         1,
    1089                 :            :         TLS1_TXT_RSA_WITH_AES_128_SHA256,
    1090                 :            :         TLS1_CK_RSA_WITH_AES_128_SHA256,
    1091                 :            :         SSL_kRSA,
    1092                 :            :         SSL_aRSA,
    1093                 :            :         SSL_AES128,
    1094                 :            :         SSL_SHA256,
    1095                 :            :         SSL_TLSV1_2,
    1096                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1097                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1098                 :            :         128,
    1099                 :            :         128,
    1100                 :            :         },
    1101                 :            : 
    1102                 :            :         /* Cipher 3D */
    1103                 :            :         {
    1104                 :            :         1,
    1105                 :            :         TLS1_TXT_RSA_WITH_AES_256_SHA256,
    1106                 :            :         TLS1_CK_RSA_WITH_AES_256_SHA256,
    1107                 :            :         SSL_kRSA,
    1108                 :            :         SSL_aRSA,
    1109                 :            :         SSL_AES256,
    1110                 :            :         SSL_SHA256,
    1111                 :            :         SSL_TLSV1_2,
    1112                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1113                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1114                 :            :         256,
    1115                 :            :         256,
    1116                 :            :         },
    1117                 :            : 
    1118                 :            :         /* Cipher 3E */
    1119                 :            :         {
    1120                 :            :         1,
    1121                 :            :         TLS1_TXT_DH_DSS_WITH_AES_128_SHA256,
    1122                 :            :         TLS1_CK_DH_DSS_WITH_AES_128_SHA256,
    1123                 :            :         SSL_kDHd,
    1124                 :            :         SSL_aDH,
    1125                 :            :         SSL_AES128,
    1126                 :            :         SSL_SHA256,
    1127                 :            :         SSL_TLSV1_2,
    1128                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1129                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1130                 :            :         128,
    1131                 :            :         128,
    1132                 :            :         },
    1133                 :            : 
    1134                 :            :         /* Cipher 3F */
    1135                 :            :         {
    1136                 :            :         1,
    1137                 :            :         TLS1_TXT_DH_RSA_WITH_AES_128_SHA256,
    1138                 :            :         TLS1_CK_DH_RSA_WITH_AES_128_SHA256,
    1139                 :            :         SSL_kDHr,
    1140                 :            :         SSL_aDH,
    1141                 :            :         SSL_AES128,
    1142                 :            :         SSL_SHA256,
    1143                 :            :         SSL_TLSV1_2,
    1144                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1145                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1146                 :            :         128,
    1147                 :            :         128,
    1148                 :            :         },
    1149                 :            : 
    1150                 :            :         /* Cipher 40 */
    1151                 :            :         {
    1152                 :            :         1,
    1153                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_128_SHA256,
    1154                 :            :         TLS1_CK_DHE_DSS_WITH_AES_128_SHA256,
    1155                 :            :         SSL_kDHE,
    1156                 :            :         SSL_aDSS,
    1157                 :            :         SSL_AES128,
    1158                 :            :         SSL_SHA256,
    1159                 :            :         SSL_TLSV1_2,
    1160                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1161                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1162                 :            :         128,
    1163                 :            :         128,
    1164                 :            :         },
    1165                 :            : 
    1166                 :            : #ifndef OPENSSL_NO_CAMELLIA
    1167                 :            :         /* Camellia ciphersuites from RFC4132 (128-bit portion) */
    1168                 :            : 
    1169                 :            :         /* Cipher 41 */
    1170                 :            :         {
    1171                 :            :         1,
    1172                 :            :         TLS1_TXT_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1173                 :            :         TLS1_CK_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1174                 :            :         SSL_kRSA,
    1175                 :            :         SSL_aRSA,
    1176                 :            :         SSL_CAMELLIA128,
    1177                 :            :         SSL_SHA1,
    1178                 :            :         SSL_TLSV1,
    1179                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1180                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1181                 :            :         128,
    1182                 :            :         128,
    1183                 :            :         },
    1184                 :            : 
    1185                 :            :         /* Cipher 42 */
    1186                 :            :         {
    1187                 :            :         1,
    1188                 :            :         TLS1_TXT_DH_DSS_WITH_CAMELLIA_128_CBC_SHA,
    1189                 :            :         TLS1_CK_DH_DSS_WITH_CAMELLIA_128_CBC_SHA,
    1190                 :            :         SSL_kDHd,
    1191                 :            :         SSL_aDH,
    1192                 :            :         SSL_CAMELLIA128,
    1193                 :            :         SSL_SHA1,
    1194                 :            :         SSL_TLSV1,
    1195                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1196                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1197                 :            :         128,
    1198                 :            :         128,
    1199                 :            :         },
    1200                 :            : 
    1201                 :            :         /* Cipher 43 */
    1202                 :            :         {
    1203                 :            :         1,
    1204                 :            :         TLS1_TXT_DH_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1205                 :            :         TLS1_CK_DH_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1206                 :            :         SSL_kDHr,
    1207                 :            :         SSL_aDH,
    1208                 :            :         SSL_CAMELLIA128,
    1209                 :            :         SSL_SHA1,
    1210                 :            :         SSL_TLSV1,
    1211                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1212                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1213                 :            :         128,
    1214                 :            :         128,
    1215                 :            :         },
    1216                 :            : 
    1217                 :            :         /* Cipher 44 */
    1218                 :            :         {
    1219                 :            :         1,
    1220                 :            :         TLS1_TXT_DHE_DSS_WITH_CAMELLIA_128_CBC_SHA,
    1221                 :            :         TLS1_CK_DHE_DSS_WITH_CAMELLIA_128_CBC_SHA,
    1222                 :            :         SSL_kDHE,
    1223                 :            :         SSL_aDSS,
    1224                 :            :         SSL_CAMELLIA128,
    1225                 :            :         SSL_SHA1,
    1226                 :            :         SSL_TLSV1,
    1227                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1228                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1229                 :            :         128,
    1230                 :            :         128,
    1231                 :            :         },
    1232                 :            : 
    1233                 :            :         /* Cipher 45 */
    1234                 :            :         {
    1235                 :            :         1,
    1236                 :            :         TLS1_TXT_DHE_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1237                 :            :         TLS1_CK_DHE_RSA_WITH_CAMELLIA_128_CBC_SHA,
    1238                 :            :         SSL_kDHE,
    1239                 :            :         SSL_aRSA,
    1240                 :            :         SSL_CAMELLIA128,
    1241                 :            :         SSL_SHA1,
    1242                 :            :         SSL_TLSV1,
    1243                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1244                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1245                 :            :         128,
    1246                 :            :         128,
    1247                 :            :         },
    1248                 :            : 
    1249                 :            :         /* Cipher 46 */
    1250                 :            :         {
    1251                 :            :         1,
    1252                 :            :         TLS1_TXT_ADH_WITH_CAMELLIA_128_CBC_SHA,
    1253                 :            :         TLS1_CK_ADH_WITH_CAMELLIA_128_CBC_SHA,
    1254                 :            :         SSL_kDHE,
    1255                 :            :         SSL_aNULL,
    1256                 :            :         SSL_CAMELLIA128,
    1257                 :            :         SSL_SHA1,
    1258                 :            :         SSL_TLSV1,
    1259                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1260                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1261                 :            :         128,
    1262                 :            :         128,
    1263                 :            :         },
    1264                 :            : #endif /* OPENSSL_NO_CAMELLIA */
    1265                 :            : 
    1266                 :            : #if TLS1_ALLOW_EXPERIMENTAL_CIPHERSUITES
    1267                 :            :         /* New TLS Export CipherSuites from expired ID */
    1268                 :            : #if 0
    1269                 :            :         /* Cipher 60 */
    1270                 :            :         {
    1271                 :            :         1,
    1272                 :            :         TLS1_TXT_RSA_EXPORT1024_WITH_RC4_56_MD5,
    1273                 :            :         TLS1_CK_RSA_EXPORT1024_WITH_RC4_56_MD5,
    1274                 :            :         SSL_kRSA,
    1275                 :            :         SSL_aRSA,
    1276                 :            :         SSL_RC4,
    1277                 :            :         SSL_MD5,
    1278                 :            :         SSL_TLSV1,
    1279                 :            :         SSL_EXPORT|SSL_EXP56,
    1280                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1281                 :            :         56,
    1282                 :            :         128,
    1283                 :            :         },
    1284                 :            : 
    1285                 :            :         /* Cipher 61 */
    1286                 :            :         {
    1287                 :            :         1,
    1288                 :            :         TLS1_TXT_RSA_EXPORT1024_WITH_RC2_CBC_56_MD5,
    1289                 :            :         TLS1_CK_RSA_EXPORT1024_WITH_RC2_CBC_56_MD5,
    1290                 :            :         SSL_kRSA,
    1291                 :            :         SSL_aRSA,
    1292                 :            :         SSL_RC2,
    1293                 :            :         SSL_MD5,
    1294                 :            :         SSL_TLSV1,
    1295                 :            :         SSL_EXPORT|SSL_EXP56,
    1296                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1297                 :            :         56,
    1298                 :            :         128,
    1299                 :            :         },
    1300                 :            : #endif
    1301                 :            : 
    1302                 :            :         /* Cipher 62 */
    1303                 :            :         {
    1304                 :            :         1,
    1305                 :            :         TLS1_TXT_RSA_EXPORT1024_WITH_DES_CBC_SHA,
    1306                 :            :         TLS1_CK_RSA_EXPORT1024_WITH_DES_CBC_SHA,
    1307                 :            :         SSL_kRSA,
    1308                 :            :         SSL_aRSA,
    1309                 :            :         SSL_DES,
    1310                 :            :         SSL_SHA1,
    1311                 :            :         SSL_TLSV1,
    1312                 :            :         SSL_EXPORT|SSL_EXP56,
    1313                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1314                 :            :         56,
    1315                 :            :         56,
    1316                 :            :         },
    1317                 :            : 
    1318                 :            :         /* Cipher 63 */
    1319                 :            :         {
    1320                 :            :         1,
    1321                 :            :         TLS1_TXT_DHE_DSS_EXPORT1024_WITH_DES_CBC_SHA,
    1322                 :            :         TLS1_CK_DHE_DSS_EXPORT1024_WITH_DES_CBC_SHA,
    1323                 :            :         SSL_kDHE,
    1324                 :            :         SSL_aDSS,
    1325                 :            :         SSL_DES,
    1326                 :            :         SSL_SHA1,
    1327                 :            :         SSL_TLSV1,
    1328                 :            :         SSL_EXPORT|SSL_EXP56,
    1329                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1330                 :            :         56,
    1331                 :            :         56,
    1332                 :            :         },
    1333                 :            : 
    1334                 :            :         /* Cipher 64 */
    1335                 :            :         {
    1336                 :            :         1,
    1337                 :            :         TLS1_TXT_RSA_EXPORT1024_WITH_RC4_56_SHA,
    1338                 :            :         TLS1_CK_RSA_EXPORT1024_WITH_RC4_56_SHA,
    1339                 :            :         SSL_kRSA,
    1340                 :            :         SSL_aRSA,
    1341                 :            :         SSL_RC4,
    1342                 :            :         SSL_SHA1,
    1343                 :            :         SSL_TLSV1,
    1344                 :            :         SSL_EXPORT|SSL_EXP56,
    1345                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1346                 :            :         56,
    1347                 :            :         128,
    1348                 :            :         },
    1349                 :            : 
    1350                 :            :         /* Cipher 65 */
    1351                 :            :         {
    1352                 :            :         1,
    1353                 :            :         TLS1_TXT_DHE_DSS_EXPORT1024_WITH_RC4_56_SHA,
    1354                 :            :         TLS1_CK_DHE_DSS_EXPORT1024_WITH_RC4_56_SHA,
    1355                 :            :         SSL_kDHE,
    1356                 :            :         SSL_aDSS,
    1357                 :            :         SSL_RC4,
    1358                 :            :         SSL_SHA1,
    1359                 :            :         SSL_TLSV1,
    1360                 :            :         SSL_EXPORT|SSL_EXP56,
    1361                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1362                 :            :         56,
    1363                 :            :         128,
    1364                 :            :         },
    1365                 :            : 
    1366                 :            :         /* Cipher 66 */
    1367                 :            :         {
    1368                 :            :         1,
    1369                 :            :         TLS1_TXT_DHE_DSS_WITH_RC4_128_SHA,
    1370                 :            :         TLS1_CK_DHE_DSS_WITH_RC4_128_SHA,
    1371                 :            :         SSL_kDHE,
    1372                 :            :         SSL_aDSS,
    1373                 :            :         SSL_RC4,
    1374                 :            :         SSL_SHA1,
    1375                 :            :         SSL_TLSV1,
    1376                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1377                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1378                 :            :         128,
    1379                 :            :         128,
    1380                 :            :         },
    1381                 :            : #endif
    1382                 :            : 
    1383                 :            :         /* TLS v1.2 ciphersuites */
    1384                 :            :         /* Cipher 67 */
    1385                 :            :         {
    1386                 :            :         1,
    1387                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_128_SHA256,
    1388                 :            :         TLS1_CK_DHE_RSA_WITH_AES_128_SHA256,
    1389                 :            :         SSL_kDHE,
    1390                 :            :         SSL_aRSA,
    1391                 :            :         SSL_AES128,
    1392                 :            :         SSL_SHA256,
    1393                 :            :         SSL_TLSV1_2,
    1394                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1395                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1396                 :            :         128,
    1397                 :            :         128,
    1398                 :            :         },
    1399                 :            : 
    1400                 :            :         /* Cipher 68 */
    1401                 :            :         {
    1402                 :            :         1,
    1403                 :            :         TLS1_TXT_DH_DSS_WITH_AES_256_SHA256,
    1404                 :            :         TLS1_CK_DH_DSS_WITH_AES_256_SHA256,
    1405                 :            :         SSL_kDHd,
    1406                 :            :         SSL_aDH,
    1407                 :            :         SSL_AES256,
    1408                 :            :         SSL_SHA256,
    1409                 :            :         SSL_TLSV1_2,
    1410                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1411                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1412                 :            :         256,
    1413                 :            :         256,
    1414                 :            :         },
    1415                 :            : 
    1416                 :            :         /* Cipher 69 */
    1417                 :            :         {
    1418                 :            :         1,
    1419                 :            :         TLS1_TXT_DH_RSA_WITH_AES_256_SHA256,
    1420                 :            :         TLS1_CK_DH_RSA_WITH_AES_256_SHA256,
    1421                 :            :         SSL_kDHr,
    1422                 :            :         SSL_aDH,
    1423                 :            :         SSL_AES256,
    1424                 :            :         SSL_SHA256,
    1425                 :            :         SSL_TLSV1_2,
    1426                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1427                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1428                 :            :         256,
    1429                 :            :         256,
    1430                 :            :         },
    1431                 :            : 
    1432                 :            :         /* Cipher 6A */
    1433                 :            :         {
    1434                 :            :         1,
    1435                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_256_SHA256,
    1436                 :            :         TLS1_CK_DHE_DSS_WITH_AES_256_SHA256,
    1437                 :            :         SSL_kDHE,
    1438                 :            :         SSL_aDSS,
    1439                 :            :         SSL_AES256,
    1440                 :            :         SSL_SHA256,
    1441                 :            :         SSL_TLSV1_2,
    1442                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1443                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1444                 :            :         256,
    1445                 :            :         256,
    1446                 :            :         },
    1447                 :            : 
    1448                 :            :         /* Cipher 6B */
    1449                 :            :         {
    1450                 :            :         1,
    1451                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_256_SHA256,
    1452                 :            :         TLS1_CK_DHE_RSA_WITH_AES_256_SHA256,
    1453                 :            :         SSL_kDHE,
    1454                 :            :         SSL_aRSA,
    1455                 :            :         SSL_AES256,
    1456                 :            :         SSL_SHA256,
    1457                 :            :         SSL_TLSV1_2,
    1458                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1459                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1460                 :            :         256,
    1461                 :            :         256,
    1462                 :            :         },
    1463                 :            : 
    1464                 :            :         /* Cipher 6C */
    1465                 :            :         {
    1466                 :            :         1,
    1467                 :            :         TLS1_TXT_ADH_WITH_AES_128_SHA256,
    1468                 :            :         TLS1_CK_ADH_WITH_AES_128_SHA256,
    1469                 :            :         SSL_kDHE,
    1470                 :            :         SSL_aNULL,
    1471                 :            :         SSL_AES128,
    1472                 :            :         SSL_SHA256,
    1473                 :            :         SSL_TLSV1_2,
    1474                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1475                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1476                 :            :         128,
    1477                 :            :         128,
    1478                 :            :         },
    1479                 :            : 
    1480                 :            :         /* Cipher 6D */
    1481                 :            :         {
    1482                 :            :         1,
    1483                 :            :         TLS1_TXT_ADH_WITH_AES_256_SHA256,
    1484                 :            :         TLS1_CK_ADH_WITH_AES_256_SHA256,
    1485                 :            :         SSL_kDHE,
    1486                 :            :         SSL_aNULL,
    1487                 :            :         SSL_AES256,
    1488                 :            :         SSL_SHA256,
    1489                 :            :         SSL_TLSV1_2,
    1490                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1491                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1492                 :            :         256,
    1493                 :            :         256,
    1494                 :            :         },
    1495                 :            : 
    1496                 :            :         /* GOST Ciphersuites */
    1497                 :            : 
    1498                 :            :         {
    1499                 :            :         1,
    1500                 :            :         "GOST94-GOST89-GOST89",
    1501                 :            :         0x3000080,
    1502                 :            :         SSL_kGOST,
    1503                 :            :         SSL_aGOST94,
    1504                 :            :         SSL_eGOST2814789CNT,
    1505                 :            :         SSL_GOST89MAC,
    1506                 :            :         SSL_TLSV1,
    1507                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1508                 :            :         SSL_HANDSHAKE_MAC_GOST94|TLS1_PRF_GOST94|TLS1_STREAM_MAC,
    1509                 :            :         256,
    1510                 :            :         256
    1511                 :            :         },
    1512                 :            :         {
    1513                 :            :         1,
    1514                 :            :         "GOST2001-GOST89-GOST89",
    1515                 :            :         0x3000081,
    1516                 :            :         SSL_kGOST,
    1517                 :            :         SSL_aGOST01,
    1518                 :            :         SSL_eGOST2814789CNT,
    1519                 :            :         SSL_GOST89MAC,
    1520                 :            :         SSL_TLSV1,
    1521                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1522                 :            :         SSL_HANDSHAKE_MAC_GOST94|TLS1_PRF_GOST94|TLS1_STREAM_MAC,
    1523                 :            :         256,
    1524                 :            :         256
    1525                 :            :         },
    1526                 :            :         {
    1527                 :            :         1,
    1528                 :            :         "GOST94-NULL-GOST94",
    1529                 :            :         0x3000082,
    1530                 :            :         SSL_kGOST,
    1531                 :            :         SSL_aGOST94,
    1532                 :            :         SSL_eNULL,
    1533                 :            :         SSL_GOST94,
    1534                 :            :         SSL_TLSV1,
    1535                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE,
    1536                 :            :         SSL_HANDSHAKE_MAC_GOST94|TLS1_PRF_GOST94,
    1537                 :            :         0,
    1538                 :            :         0
    1539                 :            :         },
    1540                 :            :         {
    1541                 :            :         1,
    1542                 :            :         "GOST2001-NULL-GOST94",
    1543                 :            :         0x3000083,
    1544                 :            :         SSL_kGOST,
    1545                 :            :         SSL_aGOST01,
    1546                 :            :         SSL_eNULL,
    1547                 :            :         SSL_GOST94,
    1548                 :            :         SSL_TLSV1,
    1549                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE,
    1550                 :            :         SSL_HANDSHAKE_MAC_GOST94|TLS1_PRF_GOST94,
    1551                 :            :         0,
    1552                 :            :         0
    1553                 :            :         },
    1554                 :            : 
    1555                 :            : #ifndef OPENSSL_NO_CAMELLIA
    1556                 :            :         /* Camellia ciphersuites from RFC4132 (256-bit portion) */
    1557                 :            : 
    1558                 :            :         /* Cipher 84 */
    1559                 :            :         {
    1560                 :            :         1,
    1561                 :            :         TLS1_TXT_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1562                 :            :         TLS1_CK_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1563                 :            :         SSL_kRSA,
    1564                 :            :         SSL_aRSA,
    1565                 :            :         SSL_CAMELLIA256,
    1566                 :            :         SSL_SHA1,
    1567                 :            :         SSL_TLSV1,
    1568                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1569                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1570                 :            :         256,
    1571                 :            :         256,
    1572                 :            :         },
    1573                 :            :         /* Cipher 85 */
    1574                 :            :         {
    1575                 :            :         1,
    1576                 :            :         TLS1_TXT_DH_DSS_WITH_CAMELLIA_256_CBC_SHA,
    1577                 :            :         TLS1_CK_DH_DSS_WITH_CAMELLIA_256_CBC_SHA,
    1578                 :            :         SSL_kDHd,
    1579                 :            :         SSL_aDH,
    1580                 :            :         SSL_CAMELLIA256,
    1581                 :            :         SSL_SHA1,
    1582                 :            :         SSL_TLSV1,
    1583                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1584                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1585                 :            :         256,
    1586                 :            :         256,
    1587                 :            :         },
    1588                 :            : 
    1589                 :            :         /* Cipher 86 */
    1590                 :            :         {
    1591                 :            :         1,
    1592                 :            :         TLS1_TXT_DH_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1593                 :            :         TLS1_CK_DH_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1594                 :            :         SSL_kDHr,
    1595                 :            :         SSL_aDH,
    1596                 :            :         SSL_CAMELLIA256,
    1597                 :            :         SSL_SHA1,
    1598                 :            :         SSL_TLSV1,
    1599                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1600                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1601                 :            :         256,
    1602                 :            :         256,
    1603                 :            :         },
    1604                 :            : 
    1605                 :            :         /* Cipher 87 */
    1606                 :            :         {
    1607                 :            :         1,
    1608                 :            :         TLS1_TXT_DHE_DSS_WITH_CAMELLIA_256_CBC_SHA,
    1609                 :            :         TLS1_CK_DHE_DSS_WITH_CAMELLIA_256_CBC_SHA,
    1610                 :            :         SSL_kDHE,
    1611                 :            :         SSL_aDSS,
    1612                 :            :         SSL_CAMELLIA256,
    1613                 :            :         SSL_SHA1,
    1614                 :            :         SSL_TLSV1,
    1615                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1616                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1617                 :            :         256,
    1618                 :            :         256,
    1619                 :            :         },
    1620                 :            : 
    1621                 :            :         /* Cipher 88 */
    1622                 :            :         {
    1623                 :            :         1,
    1624                 :            :         TLS1_TXT_DHE_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1625                 :            :         TLS1_CK_DHE_RSA_WITH_CAMELLIA_256_CBC_SHA,
    1626                 :            :         SSL_kDHE,
    1627                 :            :         SSL_aRSA,
    1628                 :            :         SSL_CAMELLIA256,
    1629                 :            :         SSL_SHA1,
    1630                 :            :         SSL_TLSV1,
    1631                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1632                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1633                 :            :         256,
    1634                 :            :         256,
    1635                 :            :         },
    1636                 :            : 
    1637                 :            :         /* Cipher 89 */
    1638                 :            :         {
    1639                 :            :         1,
    1640                 :            :         TLS1_TXT_ADH_WITH_CAMELLIA_256_CBC_SHA,
    1641                 :            :         TLS1_CK_ADH_WITH_CAMELLIA_256_CBC_SHA,
    1642                 :            :         SSL_kDHE,
    1643                 :            :         SSL_aNULL,
    1644                 :            :         SSL_CAMELLIA256,
    1645                 :            :         SSL_SHA1,
    1646                 :            :         SSL_TLSV1,
    1647                 :            :         SSL_NOT_EXP|SSL_HIGH,
    1648                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1649                 :            :         256,
    1650                 :            :         256,
    1651                 :            :         },
    1652                 :            : #endif /* OPENSSL_NO_CAMELLIA */
    1653                 :            : 
    1654                 :            : #ifndef OPENSSL_NO_PSK
    1655                 :            :         /* Cipher 8A */
    1656                 :            :         {
    1657                 :            :         1,
    1658                 :            :         TLS1_TXT_PSK_WITH_RC4_128_SHA,
    1659                 :            :         TLS1_CK_PSK_WITH_RC4_128_SHA,
    1660                 :            :         SSL_kPSK,
    1661                 :            :         SSL_aPSK,
    1662                 :            :         SSL_RC4,
    1663                 :            :         SSL_SHA1,
    1664                 :            :         SSL_TLSV1,
    1665                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1666                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1667                 :            :         128,
    1668                 :            :         128,
    1669                 :            :         },
    1670                 :            : 
    1671                 :            :         /* Cipher 8B */
    1672                 :            :         {
    1673                 :            :         1,
    1674                 :            :         TLS1_TXT_PSK_WITH_3DES_EDE_CBC_SHA,
    1675                 :            :         TLS1_CK_PSK_WITH_3DES_EDE_CBC_SHA,
    1676                 :            :         SSL_kPSK,
    1677                 :            :         SSL_aPSK,
    1678                 :            :         SSL_3DES,
    1679                 :            :         SSL_SHA1,
    1680                 :            :         SSL_TLSV1,
    1681                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1682                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1683                 :            :         112,
    1684                 :            :         168,
    1685                 :            :         },
    1686                 :            : 
    1687                 :            :         /* Cipher 8C */
    1688                 :            :         {
    1689                 :            :         1,
    1690                 :            :         TLS1_TXT_PSK_WITH_AES_128_CBC_SHA,
    1691                 :            :         TLS1_CK_PSK_WITH_AES_128_CBC_SHA,
    1692                 :            :         SSL_kPSK,
    1693                 :            :         SSL_aPSK,
    1694                 :            :         SSL_AES128,
    1695                 :            :         SSL_SHA1,
    1696                 :            :         SSL_TLSV1,
    1697                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1698                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1699                 :            :         128,
    1700                 :            :         128,
    1701                 :            :         },
    1702                 :            : 
    1703                 :            :         /* Cipher 8D */
    1704                 :            :         {
    1705                 :            :         1,
    1706                 :            :         TLS1_TXT_PSK_WITH_AES_256_CBC_SHA,
    1707                 :            :         TLS1_CK_PSK_WITH_AES_256_CBC_SHA,
    1708                 :            :         SSL_kPSK,
    1709                 :            :         SSL_aPSK,
    1710                 :            :         SSL_AES256,
    1711                 :            :         SSL_SHA1,
    1712                 :            :         SSL_TLSV1,
    1713                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1714                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1715                 :            :         256,
    1716                 :            :         256,
    1717                 :            :         },
    1718                 :            : #endif  /* OPENSSL_NO_PSK */
    1719                 :            : 
    1720                 :            : #ifndef OPENSSL_NO_SEED
    1721                 :            :         /* SEED ciphersuites from RFC4162 */
    1722                 :            : 
    1723                 :            :         /* Cipher 96 */
    1724                 :            :         {
    1725                 :            :         1,
    1726                 :            :         TLS1_TXT_RSA_WITH_SEED_SHA,
    1727                 :            :         TLS1_CK_RSA_WITH_SEED_SHA,
    1728                 :            :         SSL_kRSA,
    1729                 :            :         SSL_aRSA,
    1730                 :            :         SSL_SEED,
    1731                 :            :         SSL_SHA1,
    1732                 :            :         SSL_TLSV1,
    1733                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1734                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1735                 :            :         128,
    1736                 :            :         128,
    1737                 :            :         },
    1738                 :            : 
    1739                 :            :         /* Cipher 97 */
    1740                 :            :         {
    1741                 :            :         1,
    1742                 :            :         TLS1_TXT_DH_DSS_WITH_SEED_SHA,
    1743                 :            :         TLS1_CK_DH_DSS_WITH_SEED_SHA,
    1744                 :            :         SSL_kDHd,
    1745                 :            :         SSL_aDH,
    1746                 :            :         SSL_SEED,
    1747                 :            :         SSL_SHA1,
    1748                 :            :         SSL_TLSV1,
    1749                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1750                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1751                 :            :         128,
    1752                 :            :         128,
    1753                 :            :         },
    1754                 :            : 
    1755                 :            :         /* Cipher 98 */
    1756                 :            :         {
    1757                 :            :         1,
    1758                 :            :         TLS1_TXT_DH_RSA_WITH_SEED_SHA,
    1759                 :            :         TLS1_CK_DH_RSA_WITH_SEED_SHA,
    1760                 :            :         SSL_kDHr,
    1761                 :            :         SSL_aDH,
    1762                 :            :         SSL_SEED,
    1763                 :            :         SSL_SHA1,
    1764                 :            :         SSL_TLSV1,
    1765                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1766                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1767                 :            :         128,
    1768                 :            :         128,
    1769                 :            :         },
    1770                 :            : 
    1771                 :            :         /* Cipher 99 */
    1772                 :            :         {
    1773                 :            :         1,
    1774                 :            :         TLS1_TXT_DHE_DSS_WITH_SEED_SHA,
    1775                 :            :         TLS1_CK_DHE_DSS_WITH_SEED_SHA,
    1776                 :            :         SSL_kDHE,
    1777                 :            :         SSL_aDSS,
    1778                 :            :         SSL_SEED,
    1779                 :            :         SSL_SHA1,
    1780                 :            :         SSL_TLSV1,
    1781                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1782                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1783                 :            :         128,
    1784                 :            :         128,
    1785                 :            :         },
    1786                 :            : 
    1787                 :            :         /* Cipher 9A */
    1788                 :            :         {
    1789                 :            :         1,
    1790                 :            :         TLS1_TXT_DHE_RSA_WITH_SEED_SHA,
    1791                 :            :         TLS1_CK_DHE_RSA_WITH_SEED_SHA,
    1792                 :            :         SSL_kDHE,
    1793                 :            :         SSL_aRSA,
    1794                 :            :         SSL_SEED,
    1795                 :            :         SSL_SHA1,
    1796                 :            :         SSL_TLSV1,
    1797                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1798                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1799                 :            :         128,
    1800                 :            :         128,
    1801                 :            :         },
    1802                 :            : 
    1803                 :            :         /* Cipher 9B */
    1804                 :            :         {
    1805                 :            :         1,
    1806                 :            :         TLS1_TXT_ADH_WITH_SEED_SHA,
    1807                 :            :         TLS1_CK_ADH_WITH_SEED_SHA,
    1808                 :            :         SSL_kDHE,
    1809                 :            :         SSL_aNULL,
    1810                 :            :         SSL_SEED,
    1811                 :            :         SSL_SHA1,
    1812                 :            :         SSL_TLSV1,
    1813                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    1814                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    1815                 :            :         128,
    1816                 :            :         128,
    1817                 :            :         },
    1818                 :            : 
    1819                 :            : #endif /* OPENSSL_NO_SEED */
    1820                 :            : 
    1821                 :            :         /* GCM ciphersuites from RFC5288 */
    1822                 :            : 
    1823                 :            :         /* Cipher 9C */
    1824                 :            :         {
    1825                 :            :         1,
    1826                 :            :         TLS1_TXT_RSA_WITH_AES_128_GCM_SHA256,
    1827                 :            :         TLS1_CK_RSA_WITH_AES_128_GCM_SHA256,
    1828                 :            :         SSL_kRSA,
    1829                 :            :         SSL_aRSA,
    1830                 :            :         SSL_AES128GCM,
    1831                 :            :         SSL_AEAD,
    1832                 :            :         SSL_TLSV1_2,
    1833                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1834                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1835                 :            :         128,
    1836                 :            :         128,
    1837                 :            :         },
    1838                 :            : 
    1839                 :            :         /* Cipher 9D */
    1840                 :            :         {
    1841                 :            :         1,
    1842                 :            :         TLS1_TXT_RSA_WITH_AES_256_GCM_SHA384,
    1843                 :            :         TLS1_CK_RSA_WITH_AES_256_GCM_SHA384,
    1844                 :            :         SSL_kRSA,
    1845                 :            :         SSL_aRSA,
    1846                 :            :         SSL_AES256GCM,
    1847                 :            :         SSL_AEAD,
    1848                 :            :         SSL_TLSV1_2,
    1849                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1850                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    1851                 :            :         256,
    1852                 :            :         256,
    1853                 :            :         },
    1854                 :            : 
    1855                 :            :         /* Cipher 9E */
    1856                 :            :         {
    1857                 :            :         1,
    1858                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_128_GCM_SHA256,
    1859                 :            :         TLS1_CK_DHE_RSA_WITH_AES_128_GCM_SHA256,
    1860                 :            :         SSL_kDHE,
    1861                 :            :         SSL_aRSA,
    1862                 :            :         SSL_AES128GCM,
    1863                 :            :         SSL_AEAD,
    1864                 :            :         SSL_TLSV1_2,
    1865                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1866                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1867                 :            :         128,
    1868                 :            :         128,
    1869                 :            :         },
    1870                 :            : 
    1871                 :            :         /* Cipher 9F */
    1872                 :            :         {
    1873                 :            :         1,
    1874                 :            :         TLS1_TXT_DHE_RSA_WITH_AES_256_GCM_SHA384,
    1875                 :            :         TLS1_CK_DHE_RSA_WITH_AES_256_GCM_SHA384,
    1876                 :            :         SSL_kDHE,
    1877                 :            :         SSL_aRSA,
    1878                 :            :         SSL_AES256GCM,
    1879                 :            :         SSL_AEAD,
    1880                 :            :         SSL_TLSV1_2,
    1881                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1882                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    1883                 :            :         256,
    1884                 :            :         256,
    1885                 :            :         },
    1886                 :            : 
    1887                 :            :         /* Cipher A0 */
    1888                 :            :         {
    1889                 :            :         1,
    1890                 :            :         TLS1_TXT_DH_RSA_WITH_AES_128_GCM_SHA256,
    1891                 :            :         TLS1_CK_DH_RSA_WITH_AES_128_GCM_SHA256,
    1892                 :            :         SSL_kDHr,
    1893                 :            :         SSL_aDH,
    1894                 :            :         SSL_AES128GCM,
    1895                 :            :         SSL_AEAD,
    1896                 :            :         SSL_TLSV1_2,
    1897                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1898                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1899                 :            :         128,
    1900                 :            :         128,
    1901                 :            :         },
    1902                 :            : 
    1903                 :            :         /* Cipher A1 */
    1904                 :            :         {
    1905                 :            :         1,
    1906                 :            :         TLS1_TXT_DH_RSA_WITH_AES_256_GCM_SHA384,
    1907                 :            :         TLS1_CK_DH_RSA_WITH_AES_256_GCM_SHA384,
    1908                 :            :         SSL_kDHr,
    1909                 :            :         SSL_aDH,
    1910                 :            :         SSL_AES256GCM,
    1911                 :            :         SSL_AEAD,
    1912                 :            :         SSL_TLSV1_2,
    1913                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1914                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    1915                 :            :         256,
    1916                 :            :         256,
    1917                 :            :         },
    1918                 :            : 
    1919                 :            :         /* Cipher A2 */
    1920                 :            :         {
    1921                 :            :         1,
    1922                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_128_GCM_SHA256,
    1923                 :            :         TLS1_CK_DHE_DSS_WITH_AES_128_GCM_SHA256,
    1924                 :            :         SSL_kDHE,
    1925                 :            :         SSL_aDSS,
    1926                 :            :         SSL_AES128GCM,
    1927                 :            :         SSL_AEAD,
    1928                 :            :         SSL_TLSV1_2,
    1929                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1930                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1931                 :            :         128,
    1932                 :            :         128,
    1933                 :            :         },
    1934                 :            : 
    1935                 :            :         /* Cipher A3 */
    1936                 :            :         {
    1937                 :            :         1,
    1938                 :            :         TLS1_TXT_DHE_DSS_WITH_AES_256_GCM_SHA384,
    1939                 :            :         TLS1_CK_DHE_DSS_WITH_AES_256_GCM_SHA384,
    1940                 :            :         SSL_kDHE,
    1941                 :            :         SSL_aDSS,
    1942                 :            :         SSL_AES256GCM,
    1943                 :            :         SSL_AEAD,
    1944                 :            :         SSL_TLSV1_2,
    1945                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1946                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    1947                 :            :         256,
    1948                 :            :         256,
    1949                 :            :         },
    1950                 :            : 
    1951                 :            :         /* Cipher A4 */
    1952                 :            :         {
    1953                 :            :         1,
    1954                 :            :         TLS1_TXT_DH_DSS_WITH_AES_128_GCM_SHA256,
    1955                 :            :         TLS1_CK_DH_DSS_WITH_AES_128_GCM_SHA256,
    1956                 :            :         SSL_kDHd,
    1957                 :            :         SSL_aDH,
    1958                 :            :         SSL_AES128GCM,
    1959                 :            :         SSL_AEAD,
    1960                 :            :         SSL_TLSV1_2,
    1961                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1962                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1963                 :            :         128,
    1964                 :            :         128,
    1965                 :            :         },
    1966                 :            : 
    1967                 :            :         /* Cipher A5 */
    1968                 :            :         {
    1969                 :            :         1,
    1970                 :            :         TLS1_TXT_DH_DSS_WITH_AES_256_GCM_SHA384,
    1971                 :            :         TLS1_CK_DH_DSS_WITH_AES_256_GCM_SHA384,
    1972                 :            :         SSL_kDHd,
    1973                 :            :         SSL_aDH,
    1974                 :            :         SSL_AES256GCM,
    1975                 :            :         SSL_AEAD,
    1976                 :            :         SSL_TLSV1_2,
    1977                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1978                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    1979                 :            :         256,
    1980                 :            :         256,
    1981                 :            :         },
    1982                 :            : 
    1983                 :            :         /* Cipher A6 */
    1984                 :            :         {
    1985                 :            :         1,
    1986                 :            :         TLS1_TXT_ADH_WITH_AES_128_GCM_SHA256,
    1987                 :            :         TLS1_CK_ADH_WITH_AES_128_GCM_SHA256,
    1988                 :            :         SSL_kDHE,
    1989                 :            :         SSL_aNULL,
    1990                 :            :         SSL_AES128GCM,
    1991                 :            :         SSL_AEAD,
    1992                 :            :         SSL_TLSV1_2,
    1993                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    1994                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    1995                 :            :         128,
    1996                 :            :         128,
    1997                 :            :         },
    1998                 :            : 
    1999                 :            :         /* Cipher A7 */
    2000                 :            :         {
    2001                 :            :         1,
    2002                 :            :         TLS1_TXT_ADH_WITH_AES_256_GCM_SHA384,
    2003                 :            :         TLS1_CK_ADH_WITH_AES_256_GCM_SHA384,
    2004                 :            :         SSL_kDHE,
    2005                 :            :         SSL_aNULL,
    2006                 :            :         SSL_AES256GCM,
    2007                 :            :         SSL_AEAD,
    2008                 :            :         SSL_TLSV1_2,
    2009                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2010                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2011                 :            :         256,
    2012                 :            :         256,
    2013                 :            :         },
    2014                 :            : #ifdef OPENSSL_SSL_DEBUG_BROKEN_PROTOCOL
    2015                 :            :         {
    2016                 :            :         1,
    2017                 :            :         "SCSV",
    2018                 :            :         SSL3_CK_SCSV,
    2019                 :            :         0,
    2020                 :            :         0,
    2021                 :            :         0,
    2022                 :            :         0,
    2023                 :            :         0,
    2024                 :            :         0,
    2025                 :            :         0,
    2026                 :            :         0,
    2027                 :            :         0
    2028                 :            :         },
    2029                 :            : #endif
    2030                 :            : 
    2031                 :            : #ifndef OPENSSL_NO_CAMELLIA
    2032                 :            :         /* TLS 1.2 Camellia SHA-256 ciphersuites from RFC5932 */
    2033                 :            : 
    2034                 :            :         /* Cipher BA */
    2035                 :            :         {
    2036                 :            :         1,
    2037                 :            :         TLS1_TXT_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2038                 :            :         TLS1_CK_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2039                 :            :         SSL_kRSA,
    2040                 :            :         SSL_aRSA,
    2041                 :            :         SSL_CAMELLIA128,
    2042                 :            :         SSL_SHA256,
    2043                 :            :         SSL_TLSV1_2,
    2044                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2045                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2046                 :            :         128,
    2047                 :            :         128,
    2048                 :            :         },
    2049                 :            : 
    2050                 :            :         /* Cipher BB */
    2051                 :            :         {
    2052                 :            :         1,
    2053                 :            :         TLS1_TXT_DH_DSS_WITH_CAMELLIA_128_CBC_SHA256,
    2054                 :            :         TLS1_CK_DH_DSS_WITH_CAMELLIA_128_CBC_SHA256,
    2055                 :            :         SSL_kDHd,
    2056                 :            :         SSL_aDH,
    2057                 :            :         SSL_CAMELLIA128,
    2058                 :            :         SSL_SHA256,
    2059                 :            :         SSL_TLSV1_2,
    2060                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2061                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2062                 :            :         128,
    2063                 :            :         128,
    2064                 :            :         },
    2065                 :            : 
    2066                 :            :         /* Cipher BC */
    2067                 :            :         {
    2068                 :            :         1,
    2069                 :            :         TLS1_TXT_DH_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2070                 :            :         TLS1_CK_DH_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2071                 :            :         SSL_kDHr,
    2072                 :            :         SSL_aDH,
    2073                 :            :         SSL_CAMELLIA128,
    2074                 :            :         SSL_SHA256,
    2075                 :            :         SSL_TLSV1_2,
    2076                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2077                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2078                 :            :         128,
    2079                 :            :         128,
    2080                 :            :         },
    2081                 :            : 
    2082                 :            :         /* Cipher BD */
    2083                 :            :         {
    2084                 :            :         1,
    2085                 :            :         TLS1_TXT_DHE_DSS_WITH_CAMELLIA_128_CBC_SHA256,
    2086                 :            :         TLS1_CK_DHE_DSS_WITH_CAMELLIA_128_CBC_SHA256,
    2087                 :            :         SSL_kEDH,
    2088                 :            :         SSL_aDSS,
    2089                 :            :         SSL_CAMELLIA128,
    2090                 :            :         SSL_SHA256,
    2091                 :            :         SSL_TLSV1_2,
    2092                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2093                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2094                 :            :         128,
    2095                 :            :         128,
    2096                 :            :         },
    2097                 :            : 
    2098                 :            :         /* Cipher BE */
    2099                 :            :         {
    2100                 :            :         1,
    2101                 :            :         TLS1_TXT_DHE_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2102                 :            :         TLS1_CK_DHE_RSA_WITH_CAMELLIA_128_CBC_SHA256,
    2103                 :            :         SSL_kEDH,
    2104                 :            :         SSL_aRSA,
    2105                 :            :         SSL_CAMELLIA128,
    2106                 :            :         SSL_SHA256,
    2107                 :            :         SSL_TLSV1_2,
    2108                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2109                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2110                 :            :         128,
    2111                 :            :         128,
    2112                 :            :         },
    2113                 :            : 
    2114                 :            :         /* Cipher BF */
    2115                 :            :         {
    2116                 :            :         1,
    2117                 :            :         TLS1_TXT_ADH_WITH_CAMELLIA_128_CBC_SHA256,
    2118                 :            :         TLS1_CK_ADH_WITH_CAMELLIA_128_CBC_SHA256,
    2119                 :            :         SSL_kEDH,
    2120                 :            :         SSL_aNULL,
    2121                 :            :         SSL_CAMELLIA128,
    2122                 :            :         SSL_SHA256,
    2123                 :            :         SSL_TLSV1_2,
    2124                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2125                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2126                 :            :         128,
    2127                 :            :         128,
    2128                 :            :         },
    2129                 :            : 
    2130                 :            :         /* Cipher C0 */
    2131                 :            :         {
    2132                 :            :         1,
    2133                 :            :         TLS1_TXT_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2134                 :            :         TLS1_CK_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2135                 :            :         SSL_kRSA,
    2136                 :            :         SSL_aRSA,
    2137                 :            :         SSL_CAMELLIA256,
    2138                 :            :         SSL_SHA256,
    2139                 :            :         SSL_TLSV1_2,
    2140                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2141                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2142                 :            :         256,
    2143                 :            :         256,
    2144                 :            :         },
    2145                 :            : 
    2146                 :            :         /* Cipher C1 */
    2147                 :            :         {
    2148                 :            :         1,
    2149                 :            :         TLS1_TXT_DH_DSS_WITH_CAMELLIA_256_CBC_SHA256,
    2150                 :            :         TLS1_CK_DH_DSS_WITH_CAMELLIA_256_CBC_SHA256,
    2151                 :            :         SSL_kDHd,
    2152                 :            :         SSL_aDH,
    2153                 :            :         SSL_CAMELLIA256,
    2154                 :            :         SSL_SHA256,
    2155                 :            :         SSL_TLSV1_2,
    2156                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2157                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2158                 :            :         256,
    2159                 :            :         256,
    2160                 :            :         },
    2161                 :            : 
    2162                 :            :         /* Cipher C2 */
    2163                 :            :         {
    2164                 :            :         1,
    2165                 :            :         TLS1_TXT_DH_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2166                 :            :         TLS1_CK_DH_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2167                 :            :         SSL_kDHr,
    2168                 :            :         SSL_aDH,
    2169                 :            :         SSL_CAMELLIA256,
    2170                 :            :         SSL_SHA256,
    2171                 :            :         SSL_TLSV1_2,
    2172                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2173                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2174                 :            :         256,
    2175                 :            :         256,
    2176                 :            :         },
    2177                 :            : 
    2178                 :            :         /* Cipher C3 */
    2179                 :            :         {
    2180                 :            :         1,
    2181                 :            :         TLS1_TXT_DHE_DSS_WITH_CAMELLIA_256_CBC_SHA256,
    2182                 :            :         TLS1_CK_DHE_DSS_WITH_CAMELLIA_256_CBC_SHA256,
    2183                 :            :         SSL_kEDH,
    2184                 :            :         SSL_aDSS,
    2185                 :            :         SSL_CAMELLIA256,
    2186                 :            :         SSL_SHA256,
    2187                 :            :         SSL_TLSV1_2,
    2188                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2189                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2190                 :            :         256,
    2191                 :            :         256,
    2192                 :            :         },
    2193                 :            : 
    2194                 :            :         /* Cipher C4 */
    2195                 :            :         {
    2196                 :            :         1,
    2197                 :            :         TLS1_TXT_DHE_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2198                 :            :         TLS1_CK_DHE_RSA_WITH_CAMELLIA_256_CBC_SHA256,
    2199                 :            :         SSL_kEDH,
    2200                 :            :         SSL_aRSA,
    2201                 :            :         SSL_CAMELLIA256,
    2202                 :            :         SSL_SHA256,
    2203                 :            :         SSL_TLSV1_2,
    2204                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2205                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2206                 :            :         256,
    2207                 :            :         256,
    2208                 :            :         },
    2209                 :            : 
    2210                 :            :         /* Cipher C5 */
    2211                 :            :         {
    2212                 :            :         1,
    2213                 :            :         TLS1_TXT_ADH_WITH_CAMELLIA_256_CBC_SHA256,
    2214                 :            :         TLS1_CK_ADH_WITH_CAMELLIA_256_CBC_SHA256,
    2215                 :            :         SSL_kEDH,
    2216                 :            :         SSL_aNULL,
    2217                 :            :         SSL_CAMELLIA256,
    2218                 :            :         SSL_SHA256,
    2219                 :            :         SSL_TLSV1_2,
    2220                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2221                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2222                 :            :         256,
    2223                 :            :         256,
    2224                 :            :         },
    2225                 :            : #endif
    2226                 :            : 
    2227                 :            : #ifndef OPENSSL_NO_ECDH
    2228                 :            :         /* Cipher C001 */
    2229                 :            :         {
    2230                 :            :         1,
    2231                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_NULL_SHA,
    2232                 :            :         TLS1_CK_ECDH_ECDSA_WITH_NULL_SHA,
    2233                 :            :         SSL_kECDHe,
    2234                 :            :         SSL_aECDH,
    2235                 :            :         SSL_eNULL,
    2236                 :            :         SSL_SHA1,
    2237                 :            :         SSL_TLSV1,
    2238                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    2239                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2240                 :            :         0,
    2241                 :            :         0,
    2242                 :            :         },
    2243                 :            : 
    2244                 :            :         /* Cipher C002 */
    2245                 :            :         {
    2246                 :            :         1,
    2247                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_RC4_128_SHA,
    2248                 :            :         TLS1_CK_ECDH_ECDSA_WITH_RC4_128_SHA,
    2249                 :            :         SSL_kECDHe,
    2250                 :            :         SSL_aECDH,
    2251                 :            :         SSL_RC4,
    2252                 :            :         SSL_SHA1,
    2253                 :            :         SSL_TLSV1,
    2254                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    2255                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2256                 :            :         128,
    2257                 :            :         128,
    2258                 :            :         },
    2259                 :            : 
    2260                 :            :         /* Cipher C003 */
    2261                 :            :         {
    2262                 :            :         1,
    2263                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_DES_192_CBC3_SHA,
    2264                 :            :         TLS1_CK_ECDH_ECDSA_WITH_DES_192_CBC3_SHA,
    2265                 :            :         SSL_kECDHe,
    2266                 :            :         SSL_aECDH,
    2267                 :            :         SSL_3DES,
    2268                 :            :         SSL_SHA1,
    2269                 :            :         SSL_TLSV1,
    2270                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2271                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2272                 :            :         112,
    2273                 :            :         168,
    2274                 :            :         },
    2275                 :            : 
    2276                 :            :         /* Cipher C004 */
    2277                 :            :         {
    2278                 :            :         1,
    2279                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_128_CBC_SHA,
    2280                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_128_CBC_SHA,
    2281                 :            :         SSL_kECDHe,
    2282                 :            :         SSL_aECDH,
    2283                 :            :         SSL_AES128,
    2284                 :            :         SSL_SHA1,
    2285                 :            :         SSL_TLSV1,
    2286                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2287                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2288                 :            :         128,
    2289                 :            :         128,
    2290                 :            :         },
    2291                 :            : 
    2292                 :            :         /* Cipher C005 */
    2293                 :            :         {
    2294                 :            :         1,
    2295                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_256_CBC_SHA,
    2296                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_256_CBC_SHA,
    2297                 :            :         SSL_kECDHe,
    2298                 :            :         SSL_aECDH,
    2299                 :            :         SSL_AES256,
    2300                 :            :         SSL_SHA1,
    2301                 :            :         SSL_TLSV1,
    2302                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2303                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2304                 :            :         256,
    2305                 :            :         256,
    2306                 :            :         },
    2307                 :            : 
    2308                 :            :         /* Cipher C006 */
    2309                 :            :         {
    2310                 :            :         1,
    2311                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_NULL_SHA,
    2312                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_NULL_SHA,
    2313                 :            :         SSL_kECDHE,
    2314                 :            :         SSL_aECDSA,
    2315                 :            :         SSL_eNULL,
    2316                 :            :         SSL_SHA1,
    2317                 :            :         SSL_TLSV1,
    2318                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    2319                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2320                 :            :         0,
    2321                 :            :         0,
    2322                 :            :         },
    2323                 :            : 
    2324                 :            :         /* Cipher C007 */
    2325                 :            :         {
    2326                 :            :         1,
    2327                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_RC4_128_SHA,
    2328                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_RC4_128_SHA,
    2329                 :            :         SSL_kECDHE,
    2330                 :            :         SSL_aECDSA,
    2331                 :            :         SSL_RC4,
    2332                 :            :         SSL_SHA1,
    2333                 :            :         SSL_TLSV1,
    2334                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    2335                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2336                 :            :         128,
    2337                 :            :         128,
    2338                 :            :         },
    2339                 :            : 
    2340                 :            :         /* Cipher C008 */
    2341                 :            :         {
    2342                 :            :         1,
    2343                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_DES_192_CBC3_SHA,
    2344                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_DES_192_CBC3_SHA,
    2345                 :            :         SSL_kECDHE,
    2346                 :            :         SSL_aECDSA,
    2347                 :            :         SSL_3DES,
    2348                 :            :         SSL_SHA1,
    2349                 :            :         SSL_TLSV1,
    2350                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2351                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2352                 :            :         112,
    2353                 :            :         168,
    2354                 :            :         },
    2355                 :            : 
    2356                 :            :         /* Cipher C009 */
    2357                 :            :         {
    2358                 :            :         1,
    2359                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
    2360                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
    2361                 :            :         SSL_kECDHE,
    2362                 :            :         SSL_aECDSA,
    2363                 :            :         SSL_AES128,
    2364                 :            :         SSL_SHA1,
    2365                 :            :         SSL_TLSV1,
    2366                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2367                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2368                 :            :         128,
    2369                 :            :         128,
    2370                 :            :         },
    2371                 :            : 
    2372                 :            :         /* Cipher C00A */
    2373                 :            :         {
    2374                 :            :         1,
    2375                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
    2376                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
    2377                 :            :         SSL_kECDHE,
    2378                 :            :         SSL_aECDSA,
    2379                 :            :         SSL_AES256,
    2380                 :            :         SSL_SHA1,
    2381                 :            :         SSL_TLSV1,
    2382                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2383                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2384                 :            :         256,
    2385                 :            :         256,
    2386                 :            :         },
    2387                 :            : 
    2388                 :            :         /* Cipher C00B */
    2389                 :            :         {
    2390                 :            :         1,
    2391                 :            :         TLS1_TXT_ECDH_RSA_WITH_NULL_SHA,
    2392                 :            :         TLS1_CK_ECDH_RSA_WITH_NULL_SHA,
    2393                 :            :         SSL_kECDHr,
    2394                 :            :         SSL_aECDH,
    2395                 :            :         SSL_eNULL,
    2396                 :            :         SSL_SHA1,
    2397                 :            :         SSL_TLSV1,
    2398                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    2399                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2400                 :            :         0,
    2401                 :            :         0,
    2402                 :            :         },
    2403                 :            : 
    2404                 :            :         /* Cipher C00C */
    2405                 :            :         {
    2406                 :            :         1,
    2407                 :            :         TLS1_TXT_ECDH_RSA_WITH_RC4_128_SHA,
    2408                 :            :         TLS1_CK_ECDH_RSA_WITH_RC4_128_SHA,
    2409                 :            :         SSL_kECDHr,
    2410                 :            :         SSL_aECDH,
    2411                 :            :         SSL_RC4,
    2412                 :            :         SSL_SHA1,
    2413                 :            :         SSL_TLSV1,
    2414                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    2415                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2416                 :            :         128,
    2417                 :            :         128,
    2418                 :            :         },
    2419                 :            : 
    2420                 :            :         /* Cipher C00D */
    2421                 :            :         {
    2422                 :            :         1,
    2423                 :            :         TLS1_TXT_ECDH_RSA_WITH_DES_192_CBC3_SHA,
    2424                 :            :         TLS1_CK_ECDH_RSA_WITH_DES_192_CBC3_SHA,
    2425                 :            :         SSL_kECDHr,
    2426                 :            :         SSL_aECDH,
    2427                 :            :         SSL_3DES,
    2428                 :            :         SSL_SHA1,
    2429                 :            :         SSL_TLSV1,
    2430                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2431                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2432                 :            :         112,
    2433                 :            :         168,
    2434                 :            :         },
    2435                 :            : 
    2436                 :            :         /* Cipher C00E */
    2437                 :            :         {
    2438                 :            :         1,
    2439                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_128_CBC_SHA,
    2440                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_128_CBC_SHA,
    2441                 :            :         SSL_kECDHr,
    2442                 :            :         SSL_aECDH,
    2443                 :            :         SSL_AES128,
    2444                 :            :         SSL_SHA1,
    2445                 :            :         SSL_TLSV1,
    2446                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2447                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2448                 :            :         128,
    2449                 :            :         128,
    2450                 :            :         },
    2451                 :            : 
    2452                 :            :         /* Cipher C00F */
    2453                 :            :         {
    2454                 :            :         1,
    2455                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_256_CBC_SHA,
    2456                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_256_CBC_SHA,
    2457                 :            :         SSL_kECDHr,
    2458                 :            :         SSL_aECDH,
    2459                 :            :         SSL_AES256,
    2460                 :            :         SSL_SHA1,
    2461                 :            :         SSL_TLSV1,
    2462                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2463                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2464                 :            :         256,
    2465                 :            :         256,
    2466                 :            :         },
    2467                 :            : 
    2468                 :            :         /* Cipher C010 */
    2469                 :            :         {
    2470                 :            :         1,
    2471                 :            :         TLS1_TXT_ECDHE_RSA_WITH_NULL_SHA,
    2472                 :            :         TLS1_CK_ECDHE_RSA_WITH_NULL_SHA,
    2473                 :            :         SSL_kECDHE,
    2474                 :            :         SSL_aRSA,
    2475                 :            :         SSL_eNULL,
    2476                 :            :         SSL_SHA1,
    2477                 :            :         SSL_TLSV1,
    2478                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    2479                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2480                 :            :         0,
    2481                 :            :         0,
    2482                 :            :         },
    2483                 :            : 
    2484                 :            :         /* Cipher C011 */
    2485                 :            :         {
    2486                 :            :         1,
    2487                 :            :         TLS1_TXT_ECDHE_RSA_WITH_RC4_128_SHA,
    2488                 :            :         TLS1_CK_ECDHE_RSA_WITH_RC4_128_SHA,
    2489                 :            :         SSL_kECDHE,
    2490                 :            :         SSL_aRSA,
    2491                 :            :         SSL_RC4,
    2492                 :            :         SSL_SHA1,
    2493                 :            :         SSL_TLSV1,
    2494                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    2495                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2496                 :            :         128,
    2497                 :            :         128,
    2498                 :            :         },
    2499                 :            : 
    2500                 :            :         /* Cipher C012 */
    2501                 :            :         {
    2502                 :            :         1,
    2503                 :            :         TLS1_TXT_ECDHE_RSA_WITH_DES_192_CBC3_SHA,
    2504                 :            :         TLS1_CK_ECDHE_RSA_WITH_DES_192_CBC3_SHA,
    2505                 :            :         SSL_kECDHE,
    2506                 :            :         SSL_aRSA,
    2507                 :            :         SSL_3DES,
    2508                 :            :         SSL_SHA1,
    2509                 :            :         SSL_TLSV1,
    2510                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2511                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2512                 :            :         112,
    2513                 :            :         168,
    2514                 :            :         },
    2515                 :            : 
    2516                 :            :         /* Cipher C013 */
    2517                 :            :         {
    2518                 :            :         1,
    2519                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_128_CBC_SHA,
    2520                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_128_CBC_SHA,
    2521                 :            :         SSL_kECDHE,
    2522                 :            :         SSL_aRSA,
    2523                 :            :         SSL_AES128,
    2524                 :            :         SSL_SHA1,
    2525                 :            :         SSL_TLSV1,
    2526                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2527                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2528                 :            :         128,
    2529                 :            :         128,
    2530                 :            :         },
    2531                 :            : 
    2532                 :            :         /* Cipher C014 */
    2533                 :            :         {
    2534                 :            :         1,
    2535                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_256_CBC_SHA,
    2536                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_256_CBC_SHA,
    2537                 :            :         SSL_kECDHE,
    2538                 :            :         SSL_aRSA,
    2539                 :            :         SSL_AES256,
    2540                 :            :         SSL_SHA1,
    2541                 :            :         SSL_TLSV1,
    2542                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2543                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2544                 :            :         256,
    2545                 :            :         256,
    2546                 :            :         },
    2547                 :            : 
    2548                 :            :         /* Cipher C015 */
    2549                 :            :         {
    2550                 :            :         1,
    2551                 :            :         TLS1_TXT_ECDH_anon_WITH_NULL_SHA,
    2552                 :            :         TLS1_CK_ECDH_anon_WITH_NULL_SHA,
    2553                 :            :         SSL_kECDHE,
    2554                 :            :         SSL_aNULL,
    2555                 :            :         SSL_eNULL,
    2556                 :            :         SSL_SHA1,
    2557                 :            :         SSL_TLSV1,
    2558                 :            :         SSL_NOT_EXP|SSL_STRONG_NONE|SSL_FIPS,
    2559                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2560                 :            :         0,
    2561                 :            :         0,
    2562                 :            :         },
    2563                 :            : 
    2564                 :            :         /* Cipher C016 */
    2565                 :            :         {
    2566                 :            :         1,
    2567                 :            :         TLS1_TXT_ECDH_anon_WITH_RC4_128_SHA,
    2568                 :            :         TLS1_CK_ECDH_anon_WITH_RC4_128_SHA,
    2569                 :            :         SSL_kECDHE,
    2570                 :            :         SSL_aNULL,
    2571                 :            :         SSL_RC4,
    2572                 :            :         SSL_SHA1,
    2573                 :            :         SSL_TLSV1,
    2574                 :            :         SSL_NOT_EXP|SSL_MEDIUM,
    2575                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2576                 :            :         128,
    2577                 :            :         128,
    2578                 :            :         },
    2579                 :            : 
    2580                 :            :         /* Cipher C017 */
    2581                 :            :         {
    2582                 :            :         1,
    2583                 :            :         TLS1_TXT_ECDH_anon_WITH_DES_192_CBC3_SHA,
    2584                 :            :         TLS1_CK_ECDH_anon_WITH_DES_192_CBC3_SHA,
    2585                 :            :         SSL_kECDHE,
    2586                 :            :         SSL_aNULL,
    2587                 :            :         SSL_3DES,
    2588                 :            :         SSL_SHA1,
    2589                 :            :         SSL_TLSV1,
    2590                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2591                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2592                 :            :         112,
    2593                 :            :         168,
    2594                 :            :         },
    2595                 :            : 
    2596                 :            :         /* Cipher C018 */
    2597                 :            :         {
    2598                 :            :         1,
    2599                 :            :         TLS1_TXT_ECDH_anon_WITH_AES_128_CBC_SHA,
    2600                 :            :         TLS1_CK_ECDH_anon_WITH_AES_128_CBC_SHA,
    2601                 :            :         SSL_kECDHE,
    2602                 :            :         SSL_aNULL,
    2603                 :            :         SSL_AES128,
    2604                 :            :         SSL_SHA1,
    2605                 :            :         SSL_TLSV1,
    2606                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2607                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2608                 :            :         128,
    2609                 :            :         128,
    2610                 :            :         },
    2611                 :            : 
    2612                 :            :         /* Cipher C019 */
    2613                 :            :         {
    2614                 :            :         1,
    2615                 :            :         TLS1_TXT_ECDH_anon_WITH_AES_256_CBC_SHA,
    2616                 :            :         TLS1_CK_ECDH_anon_WITH_AES_256_CBC_SHA,
    2617                 :            :         SSL_kECDHE,
    2618                 :            :         SSL_aNULL,
    2619                 :            :         SSL_AES256,
    2620                 :            :         SSL_SHA1,
    2621                 :            :         SSL_TLSV1,
    2622                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2623                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2624                 :            :         256,
    2625                 :            :         256,
    2626                 :            :         },
    2627                 :            : #endif  /* OPENSSL_NO_ECDH */
    2628                 :            : 
    2629                 :            : #ifndef OPENSSL_NO_SRP
    2630                 :            :         /* Cipher C01A */
    2631                 :            :         {
    2632                 :            :         1,
    2633                 :            :         TLS1_TXT_SRP_SHA_WITH_3DES_EDE_CBC_SHA,
    2634                 :            :         TLS1_CK_SRP_SHA_WITH_3DES_EDE_CBC_SHA,
    2635                 :            :         SSL_kSRP,
    2636                 :            :         SSL_aSRP,
    2637                 :            :         SSL_3DES,
    2638                 :            :         SSL_SHA1,
    2639                 :            :         SSL_TLSV1,
    2640                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2641                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2642                 :            :         112,
    2643                 :            :         168,
    2644                 :            :         },
    2645                 :            : 
    2646                 :            :         /* Cipher C01B */
    2647                 :            :         {
    2648                 :            :         1,
    2649                 :            :         TLS1_TXT_SRP_SHA_RSA_WITH_3DES_EDE_CBC_SHA,
    2650                 :            :         TLS1_CK_SRP_SHA_RSA_WITH_3DES_EDE_CBC_SHA,
    2651                 :            :         SSL_kSRP,
    2652                 :            :         SSL_aRSA,
    2653                 :            :         SSL_3DES,
    2654                 :            :         SSL_SHA1,
    2655                 :            :         SSL_TLSV1,
    2656                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2657                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2658                 :            :         112,
    2659                 :            :         168,
    2660                 :            :         },
    2661                 :            : 
    2662                 :            :         /* Cipher C01C */
    2663                 :            :         {
    2664                 :            :         1,
    2665                 :            :         TLS1_TXT_SRP_SHA_DSS_WITH_3DES_EDE_CBC_SHA,
    2666                 :            :         TLS1_CK_SRP_SHA_DSS_WITH_3DES_EDE_CBC_SHA,
    2667                 :            :         SSL_kSRP,
    2668                 :            :         SSL_aDSS,
    2669                 :            :         SSL_3DES,
    2670                 :            :         SSL_SHA1,
    2671                 :            :         SSL_TLSV1,
    2672                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2673                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2674                 :            :         112,
    2675                 :            :         168,
    2676                 :            :         },
    2677                 :            : 
    2678                 :            :         /* Cipher C01D */
    2679                 :            :         {
    2680                 :            :         1,
    2681                 :            :         TLS1_TXT_SRP_SHA_WITH_AES_128_CBC_SHA,
    2682                 :            :         TLS1_CK_SRP_SHA_WITH_AES_128_CBC_SHA,
    2683                 :            :         SSL_kSRP,
    2684                 :            :         SSL_aSRP,
    2685                 :            :         SSL_AES128,
    2686                 :            :         SSL_SHA1,
    2687                 :            :         SSL_TLSV1,
    2688                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2689                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2690                 :            :         128,
    2691                 :            :         128,
    2692                 :            :         },
    2693                 :            : 
    2694                 :            :         /* Cipher C01E */
    2695                 :            :         {
    2696                 :            :         1,
    2697                 :            :         TLS1_TXT_SRP_SHA_RSA_WITH_AES_128_CBC_SHA,
    2698                 :            :         TLS1_CK_SRP_SHA_RSA_WITH_AES_128_CBC_SHA,
    2699                 :            :         SSL_kSRP,
    2700                 :            :         SSL_aRSA,
    2701                 :            :         SSL_AES128,
    2702                 :            :         SSL_SHA1,
    2703                 :            :         SSL_TLSV1,
    2704                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2705                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2706                 :            :         128,
    2707                 :            :         128,
    2708                 :            :         },
    2709                 :            : 
    2710                 :            :         /* Cipher C01F */
    2711                 :            :         {
    2712                 :            :         1,
    2713                 :            :         TLS1_TXT_SRP_SHA_DSS_WITH_AES_128_CBC_SHA,
    2714                 :            :         TLS1_CK_SRP_SHA_DSS_WITH_AES_128_CBC_SHA,
    2715                 :            :         SSL_kSRP,
    2716                 :            :         SSL_aDSS,
    2717                 :            :         SSL_AES128,
    2718                 :            :         SSL_SHA1,
    2719                 :            :         SSL_TLSV1,
    2720                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2721                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2722                 :            :         128,
    2723                 :            :         128,
    2724                 :            :         },
    2725                 :            : 
    2726                 :            :         /* Cipher C020 */
    2727                 :            :         {
    2728                 :            :         1,
    2729                 :            :         TLS1_TXT_SRP_SHA_WITH_AES_256_CBC_SHA,
    2730                 :            :         TLS1_CK_SRP_SHA_WITH_AES_256_CBC_SHA,
    2731                 :            :         SSL_kSRP,
    2732                 :            :         SSL_aSRP,
    2733                 :            :         SSL_AES256,
    2734                 :            :         SSL_SHA1,
    2735                 :            :         SSL_TLSV1,
    2736                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2737                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2738                 :            :         256,
    2739                 :            :         256,
    2740                 :            :         },
    2741                 :            : 
    2742                 :            :         /* Cipher C021 */
    2743                 :            :         {
    2744                 :            :         1,
    2745                 :            :         TLS1_TXT_SRP_SHA_RSA_WITH_AES_256_CBC_SHA,
    2746                 :            :         TLS1_CK_SRP_SHA_RSA_WITH_AES_256_CBC_SHA,
    2747                 :            :         SSL_kSRP,
    2748                 :            :         SSL_aRSA,
    2749                 :            :         SSL_AES256,
    2750                 :            :         SSL_SHA1,
    2751                 :            :         SSL_TLSV1,
    2752                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2753                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2754                 :            :         256,
    2755                 :            :         256,
    2756                 :            :         },
    2757                 :            : 
    2758                 :            :         /* Cipher C022 */
    2759                 :            :         {
    2760                 :            :         1,
    2761                 :            :         TLS1_TXT_SRP_SHA_DSS_WITH_AES_256_CBC_SHA,
    2762                 :            :         TLS1_CK_SRP_SHA_DSS_WITH_AES_256_CBC_SHA,
    2763                 :            :         SSL_kSRP,
    2764                 :            :         SSL_aDSS,
    2765                 :            :         SSL_AES256,
    2766                 :            :         SSL_SHA1,
    2767                 :            :         SSL_TLSV1,
    2768                 :            :         SSL_NOT_EXP|SSL_HIGH,
    2769                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    2770                 :            :         256,
    2771                 :            :         256,
    2772                 :            :         },
    2773                 :            : #endif  /* OPENSSL_NO_SRP */
    2774                 :            : #ifndef OPENSSL_NO_ECDH
    2775                 :            : 
    2776                 :            :         /* HMAC based TLS v1.2 ciphersuites from RFC5289 */
    2777                 :            : 
    2778                 :            :         /* Cipher C023 */
    2779                 :            :         {
    2780                 :            :         1,
    2781                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_128_SHA256,
    2782                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_128_SHA256,
    2783                 :            :         SSL_kECDHE,
    2784                 :            :         SSL_aECDSA,
    2785                 :            :         SSL_AES128,
    2786                 :            :         SSL_SHA256,
    2787                 :            :         SSL_TLSV1_2,
    2788                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2789                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2790                 :            :         128,
    2791                 :            :         128,
    2792                 :            :         },
    2793                 :            : 
    2794                 :            :         /* Cipher C024 */
    2795                 :            :         {
    2796                 :            :         1,
    2797                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_256_SHA384,
    2798                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_256_SHA384,
    2799                 :            :         SSL_kECDHE,
    2800                 :            :         SSL_aECDSA,
    2801                 :            :         SSL_AES256,
    2802                 :            :         SSL_SHA384,
    2803                 :            :         SSL_TLSV1_2,
    2804                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2805                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2806                 :            :         256,
    2807                 :            :         256,
    2808                 :            :         },
    2809                 :            : 
    2810                 :            :         /* Cipher C025 */
    2811                 :            :         {
    2812                 :            :         1,
    2813                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_128_SHA256,
    2814                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_128_SHA256,
    2815                 :            :         SSL_kECDHe,
    2816                 :            :         SSL_aECDH,
    2817                 :            :         SSL_AES128,
    2818                 :            :         SSL_SHA256,
    2819                 :            :         SSL_TLSV1_2,
    2820                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2821                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2822                 :            :         128,
    2823                 :            :         128,
    2824                 :            :         },
    2825                 :            : 
    2826                 :            :         /* Cipher C026 */
    2827                 :            :         {
    2828                 :            :         1,
    2829                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_256_SHA384,
    2830                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_256_SHA384,
    2831                 :            :         SSL_kECDHe,
    2832                 :            :         SSL_aECDH,
    2833                 :            :         SSL_AES256,
    2834                 :            :         SSL_SHA384,
    2835                 :            :         SSL_TLSV1_2,
    2836                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2837                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2838                 :            :         256,
    2839                 :            :         256,
    2840                 :            :         },
    2841                 :            : 
    2842                 :            :         /* Cipher C027 */
    2843                 :            :         {
    2844                 :            :         1,
    2845                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_128_SHA256,
    2846                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_128_SHA256,
    2847                 :            :         SSL_kECDHE,
    2848                 :            :         SSL_aRSA,
    2849                 :            :         SSL_AES128,
    2850                 :            :         SSL_SHA256,
    2851                 :            :         SSL_TLSV1_2,
    2852                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2853                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2854                 :            :         128,
    2855                 :            :         128,
    2856                 :            :         },
    2857                 :            : 
    2858                 :            :         /* Cipher C028 */
    2859                 :            :         {
    2860                 :            :         1,
    2861                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_256_SHA384,
    2862                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_256_SHA384,
    2863                 :            :         SSL_kECDHE,
    2864                 :            :         SSL_aRSA,
    2865                 :            :         SSL_AES256,
    2866                 :            :         SSL_SHA384,
    2867                 :            :         SSL_TLSV1_2,
    2868                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2869                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2870                 :            :         256,
    2871                 :            :         256,
    2872                 :            :         },
    2873                 :            : 
    2874                 :            :         /* Cipher C029 */
    2875                 :            :         {
    2876                 :            :         1,
    2877                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_128_SHA256,
    2878                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_128_SHA256,
    2879                 :            :         SSL_kECDHr,
    2880                 :            :         SSL_aECDH,
    2881                 :            :         SSL_AES128,
    2882                 :            :         SSL_SHA256,
    2883                 :            :         SSL_TLSV1_2,
    2884                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2885                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2886                 :            :         128,
    2887                 :            :         128,
    2888                 :            :         },
    2889                 :            : 
    2890                 :            :         /* Cipher C02A */
    2891                 :            :         {
    2892                 :            :         1,
    2893                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_256_SHA384,
    2894                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_256_SHA384,
    2895                 :            :         SSL_kECDHr,
    2896                 :            :         SSL_aECDH,
    2897                 :            :         SSL_AES256,
    2898                 :            :         SSL_SHA384,
    2899                 :            :         SSL_TLSV1_2,
    2900                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2901                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2902                 :            :         256,
    2903                 :            :         256,
    2904                 :            :         },
    2905                 :            : 
    2906                 :            :         /* GCM based TLS v1.2 ciphersuites from RFC5289 */
    2907                 :            : 
    2908                 :            :         /* Cipher C02B */
    2909                 :            :         {
    2910                 :            :         1,
    2911                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
    2912                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
    2913                 :            :         SSL_kECDHE,
    2914                 :            :         SSL_aECDSA,
    2915                 :            :         SSL_AES128GCM,
    2916                 :            :         SSL_AEAD,
    2917                 :            :         SSL_TLSV1_2,
    2918                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2919                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2920                 :            :         128,
    2921                 :            :         128,
    2922                 :            :         },
    2923                 :            : 
    2924                 :            :         /* Cipher C02C */
    2925                 :            :         {
    2926                 :            :         1,
    2927                 :            :         TLS1_TXT_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
    2928                 :            :         TLS1_CK_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
    2929                 :            :         SSL_kECDHE,
    2930                 :            :         SSL_aECDSA,
    2931                 :            :         SSL_AES256GCM,
    2932                 :            :         SSL_AEAD,
    2933                 :            :         SSL_TLSV1_2,
    2934                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2935                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2936                 :            :         256,
    2937                 :            :         256,
    2938                 :            :         },
    2939                 :            : 
    2940                 :            :         /* Cipher C02D */
    2941                 :            :         {
    2942                 :            :         1,
    2943                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_128_GCM_SHA256,
    2944                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_128_GCM_SHA256,
    2945                 :            :         SSL_kECDHe,
    2946                 :            :         SSL_aECDH,
    2947                 :            :         SSL_AES128GCM,
    2948                 :            :         SSL_AEAD,
    2949                 :            :         SSL_TLSV1_2,
    2950                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2951                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2952                 :            :         128,
    2953                 :            :         128,
    2954                 :            :         },
    2955                 :            : 
    2956                 :            :         /* Cipher C02E */
    2957                 :            :         {
    2958                 :            :         1,
    2959                 :            :         TLS1_TXT_ECDH_ECDSA_WITH_AES_256_GCM_SHA384,
    2960                 :            :         TLS1_CK_ECDH_ECDSA_WITH_AES_256_GCM_SHA384,
    2961                 :            :         SSL_kECDHe,
    2962                 :            :         SSL_aECDH,
    2963                 :            :         SSL_AES256GCM,
    2964                 :            :         SSL_AEAD,
    2965                 :            :         SSL_TLSV1_2,
    2966                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2967                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    2968                 :            :         256,
    2969                 :            :         256,
    2970                 :            :         },
    2971                 :            : 
    2972                 :            :         /* Cipher C02F */
    2973                 :            :         {
    2974                 :            :         1,
    2975                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
    2976                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
    2977                 :            :         SSL_kECDHE,
    2978                 :            :         SSL_aRSA,
    2979                 :            :         SSL_AES128GCM,
    2980                 :            :         SSL_AEAD,
    2981                 :            :         SSL_TLSV1_2,
    2982                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2983                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    2984                 :            :         128,
    2985                 :            :         128,
    2986                 :            :         },
    2987                 :            : 
    2988                 :            :         /* Cipher C030 */
    2989                 :            :         {
    2990                 :            :         1,
    2991                 :            :         TLS1_TXT_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
    2992                 :            :         TLS1_CK_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
    2993                 :            :         SSL_kECDHE,
    2994                 :            :         SSL_aRSA,
    2995                 :            :         SSL_AES256GCM,
    2996                 :            :         SSL_AEAD,
    2997                 :            :         SSL_TLSV1_2,
    2998                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    2999                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    3000                 :            :         256,
    3001                 :            :         256,
    3002                 :            :         },
    3003                 :            : 
    3004                 :            :         /* Cipher C031 */
    3005                 :            :         {
    3006                 :            :         1,
    3007                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_128_GCM_SHA256,
    3008                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_128_GCM_SHA256,
    3009                 :            :         SSL_kECDHr,
    3010                 :            :         SSL_aECDH,
    3011                 :            :         SSL_AES128GCM,
    3012                 :            :         SSL_AEAD,
    3013                 :            :         SSL_TLSV1_2,
    3014                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    3015                 :            :         SSL_HANDSHAKE_MAC_SHA256|TLS1_PRF_SHA256,
    3016                 :            :         128,
    3017                 :            :         128,
    3018                 :            :         },
    3019                 :            : 
    3020                 :            :         /* Cipher C032 */
    3021                 :            :         {
    3022                 :            :         1,
    3023                 :            :         TLS1_TXT_ECDH_RSA_WITH_AES_256_GCM_SHA384,
    3024                 :            :         TLS1_CK_ECDH_RSA_WITH_AES_256_GCM_SHA384,
    3025                 :            :         SSL_kECDHr,
    3026                 :            :         SSL_aECDH,
    3027                 :            :         SSL_AES256GCM,
    3028                 :            :         SSL_AEAD,
    3029                 :            :         SSL_TLSV1_2,
    3030                 :            :         SSL_NOT_EXP|SSL_HIGH|SSL_FIPS,
    3031                 :            :         SSL_HANDSHAKE_MAC_SHA384|TLS1_PRF_SHA384,
    3032                 :            :         256,
    3033                 :            :         256,
    3034                 :            :         },
    3035                 :            : 
    3036                 :            : #endif /* OPENSSL_NO_ECDH */
    3037                 :            : 
    3038                 :            : 
    3039                 :            : #ifdef TEMP_GOST_TLS
    3040                 :            : /* Cipher FF00 */
    3041                 :            :         {
    3042                 :            :         1,
    3043                 :            :         "GOST-MD5",
    3044                 :            :         0x0300ff00,
    3045                 :            :         SSL_kRSA,
    3046                 :            :         SSL_aRSA,
    3047                 :            :         SSL_eGOST2814789CNT,
    3048                 :            :         SSL_MD5,
    3049                 :            :         SSL_TLSV1,
    3050                 :            :         SSL_NOT_EXP|SSL_HIGH,
    3051                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    3052                 :            :         256,
    3053                 :            :         256,
    3054                 :            :         },
    3055                 :            :         {
    3056                 :            :         1,
    3057                 :            :         "GOST-GOST94",
    3058                 :            :         0x0300ff01,
    3059                 :            :         SSL_kRSA,
    3060                 :            :         SSL_aRSA,
    3061                 :            :         SSL_eGOST2814789CNT,
    3062                 :            :         SSL_GOST94,
    3063                 :            :         SSL_TLSV1,
    3064                 :            :         SSL_NOT_EXP|SSL_HIGH,
    3065                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    3066                 :            :         256,
    3067                 :            :         256
    3068                 :            :         },
    3069                 :            :         {
    3070                 :            :         1,
    3071                 :            :         "GOST-GOST89MAC",
    3072                 :            :         0x0300ff02,
    3073                 :            :         SSL_kRSA,
    3074                 :            :         SSL_aRSA,
    3075                 :            :         SSL_eGOST2814789CNT,
    3076                 :            :         SSL_GOST89MAC,
    3077                 :            :         SSL_TLSV1,
    3078                 :            :         SSL_NOT_EXP|SSL_HIGH,
    3079                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF,
    3080                 :            :         256,
    3081                 :            :         256
    3082                 :            :         },
    3083                 :            :         {
    3084                 :            :         1,
    3085                 :            :         "GOST-GOST89STREAM",
    3086                 :            :         0x0300ff03,
    3087                 :            :         SSL_kRSA,
    3088                 :            :         SSL_aRSA,
    3089                 :            :         SSL_eGOST2814789CNT,
    3090                 :            :         SSL_GOST89MAC,
    3091                 :            :         SSL_TLSV1,
    3092                 :            :         SSL_NOT_EXP|SSL_HIGH,
    3093                 :            :         SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF|TLS1_STREAM_MAC,
    3094                 :            :         256,
    3095                 :            :         256
    3096                 :            :         },
    3097                 :            : #endif
    3098                 :            : 
    3099                 :            : /* end of list */
    3100                 :            :         };
    3101                 :            : 
    3102                 :            : const SSL3_ENC_METHOD SSLv3_enc_data={
    3103                 :            :         ssl3_enc,
    3104                 :            :         n_ssl3_mac,
    3105                 :            :         ssl3_setup_key_block,
    3106                 :            :         ssl3_generate_master_secret,
    3107                 :            :         ssl3_change_cipher_state,
    3108                 :            :         ssl3_final_finish_mac,
    3109                 :            :         MD5_DIGEST_LENGTH+SHA_DIGEST_LENGTH,
    3110                 :            :         ssl3_cert_verify_mac,
    3111                 :            :         SSL3_MD_CLIENT_FINISHED_CONST,4,
    3112                 :            :         SSL3_MD_SERVER_FINISHED_CONST,4,
    3113                 :            :         ssl3_alert_code,
    3114                 :            :         (int (*)(SSL *, unsigned char *, size_t, const char *,
    3115                 :            :                  size_t, const unsigned char *, size_t,
    3116                 :            :                  int use_context))ssl_undefined_function,
    3117                 :            :         0,
    3118                 :            :         SSL3_HM_HEADER_LENGTH,
    3119                 :            :         ssl3_set_handshake_header,
    3120                 :            :         ssl3_handshake_write
    3121                 :            :         };
    3122                 :            : 
    3123                 :        506 : long ssl3_default_timeout(void)
    3124                 :            :         {
    3125                 :            :         /* 2 hours, the 24 hours mentioned in the SSLv3 spec
    3126                 :            :          * is way too long for http, the cache would over fill */
    3127                 :        506 :         return(60*60*2);
    3128                 :            :         }
    3129                 :            : 
    3130                 :      97882 : int ssl3_num_ciphers(void)
    3131                 :            :         {
    3132                 :      97882 :         return(SSL3_NUM_CIPHERS);
    3133                 :            :         }
    3134                 :            : 
    3135                 :     329074 : const SSL_CIPHER *ssl3_get_cipher(unsigned int u)
    3136                 :            :         {
    3137         [ +  + ]:     329074 :         if (u < SSL3_NUM_CIPHERS)
    3138                 :     329072 :                 return(&(ssl3_ciphers[SSL3_NUM_CIPHERS-1-u]));
    3139                 :            :         else
    3140                 :            :                 return(NULL);
    3141                 :            :         }
    3142                 :            : 
    3143                 :      22746 : int ssl3_pending(const SSL *s)
    3144                 :            :         {
    3145         [ +  - ]:      22746 :         if (s->rstate == SSL_ST_READ_BODY)
    3146                 :            :                 return 0;
    3147                 :            :         
    3148         [ +  + ]:      22746 :         return (s->s3->rrec.type == SSL3_RT_APPLICATION_DATA) ? s->s3->rrec.length : 0;
    3149                 :            :         }
    3150                 :            : 
    3151                 :       8946 : void ssl3_set_handshake_header(SSL *s, int htype, unsigned long len)
    3152                 :            :         {
    3153                 :       8946 :         unsigned char *p = (unsigned char *)s->init_buf->data;
    3154                 :       8946 :         *(p++) = htype;
    3155                 :       8946 :         l2n3(len, p);
    3156                 :       8946 :         s->init_num = (int)len + SSL3_HM_HEADER_LENGTH;
    3157                 :       8946 :         s->init_off = 0;
    3158                 :       8946 :         }
    3159                 :            : 
    3160                 :      11784 : int ssl3_handshake_write(SSL *s)
    3161                 :            :         {
    3162                 :      11784 :         return ssl3_do_write(s, SSL3_RT_HANDSHAKE);
    3163                 :            :         }
    3164                 :            : 
    3165                 :       1544 : int ssl3_new(SSL *s)
    3166                 :            :         {
    3167                 :            :         SSL3_STATE *s3;
    3168                 :            : 
    3169         [ +  - ]:       1544 :         if ((s3=OPENSSL_malloc(sizeof *s3)) == NULL) goto err;
    3170                 :            :         memset(s3,0,sizeof *s3);
    3171                 :       1544 :         memset(s3->rrec.seq_num,0,sizeof(s3->rrec.seq_num));
    3172                 :       1544 :         memset(s3->wrec.seq_num,0,sizeof(s3->wrec.seq_num));
    3173                 :            : 
    3174                 :       1544 :         s->s3=s3;
    3175                 :            : 
    3176                 :            : #ifndef OPENSSL_NO_SRP
    3177                 :       1544 :         SSL_SRP_CTX_init(s);
    3178                 :            : #endif
    3179                 :       1544 :         s->method->ssl_clear(s);
    3180                 :       1544 :         return(1);
    3181                 :            : err:
    3182                 :            :         return(0);
    3183                 :            :         }
    3184                 :            : 
    3185                 :       1544 : void ssl3_free(SSL *s)
    3186                 :            :         {
    3187         [ +  - ]:       1544 :         if(s == NULL)
    3188                 :       1544 :             return;
    3189                 :            : 
    3190                 :            : #ifdef TLSEXT_TYPE_opaque_prf_input
    3191                 :            :         if (s->s3->client_opaque_prf_input != NULL)
    3192                 :            :                 OPENSSL_free(s->s3->client_opaque_prf_input);
    3193                 :            :         if (s->s3->server_opaque_prf_input != NULL)
    3194                 :            :                 OPENSSL_free(s->s3->server_opaque_prf_input);
    3195                 :            : #endif
    3196                 :            : 
    3197                 :       1544 :         ssl3_cleanup_key_block(s);
    3198         [ +  + ]:       1544 :         if (s->s3->rbuf.buf != NULL)
    3199                 :       1522 :                 ssl3_release_read_buffer(s);
    3200         [ +  + ]:       1544 :         if (s->s3->wbuf.buf != NULL)
    3201                 :       1522 :                 ssl3_release_write_buffer(s);
    3202         [ -  + ]:       1544 :         if (s->s3->rrec.comp != NULL)
    3203                 :          0 :                 OPENSSL_free(s->s3->rrec.comp);
    3204                 :            : #ifndef OPENSSL_NO_DH
    3205         [ -  + ]:       1544 :         if (s->s3->tmp.dh != NULL)
    3206                 :          0 :                 DH_free(s->s3->tmp.dh);
    3207                 :            : #endif
    3208                 :            : #ifndef OPENSSL_NO_ECDH
    3209         [ -  + ]:       1544 :         if (s->s3->tmp.ecdh != NULL)
    3210                 :          0 :                 EC_KEY_free(s->s3->tmp.ecdh);
    3211                 :            : #endif
    3212                 :            : 
    3213         [ +  + ]:       1544 :         if (s->s3->tmp.ca_names != NULL)
    3214                 :         99 :                 sk_X509_NAME_pop_free(s->s3->tmp.ca_names,X509_NAME_free);
    3215         [ -  + ]:       1544 :         if (s->s3->handshake_buffer) {
    3216                 :          0 :                 BIO_free(s->s3->handshake_buffer);
    3217                 :            :         }
    3218         [ +  + ]:       1544 :         if (s->s3->handshake_dgst) ssl3_free_digest_list(s);
    3219                 :            : #ifndef OPENSSL_NO_TLSEXT
    3220         [ +  + ]:       1544 :         if (s->s3->alpn_selected)
    3221                 :        132 :                 OPENSSL_free(s->s3->alpn_selected);
    3222                 :            : #endif
    3223                 :            : 
    3224                 :            : #ifndef OPENSSL_NO_SRP
    3225                 :       1544 :         SSL_SRP_CTX_free(s);
    3226                 :            : #endif
    3227                 :            : #ifndef OPENSSL_NO_TLSEXT
    3228         [ +  + ]:       1544 :         if (s->s3->serverinfo_client_tlsext_custom_types != NULL)
    3229                 :         44 :                 OPENSSL_free(s->s3->serverinfo_client_tlsext_custom_types);
    3230                 :            : #endif
    3231                 :       1544 :         OPENSSL_cleanse(s->s3,sizeof *s->s3);
    3232                 :       1544 :         OPENSSL_free(s->s3);
    3233                 :       1544 :         s->s3=NULL;
    3234                 :            :         }
    3235                 :            : 
    3236                 :       6286 : void ssl3_clear(SSL *s)
    3237                 :            :         {
    3238                 :            :         unsigned char *rp,*wp;
    3239                 :            :         size_t rlen, wlen;
    3240                 :            :         int init_extra;
    3241                 :            : 
    3242                 :            : #ifdef TLSEXT_TYPE_opaque_prf_input
    3243                 :            :         if (s->s3->client_opaque_prf_input != NULL)
    3244                 :            :                 OPENSSL_free(s->s3->client_opaque_prf_input);
    3245                 :            :         s->s3->client_opaque_prf_input = NULL;
    3246                 :            :         if (s->s3->server_opaque_prf_input != NULL)
    3247                 :            :                 OPENSSL_free(s->s3->server_opaque_prf_input);
    3248                 :            :         s->s3->server_opaque_prf_input = NULL;
    3249                 :            : #endif
    3250                 :            : 
    3251                 :       6286 :         ssl3_cleanup_key_block(s);
    3252         [ -  + ]:       6286 :         if (s->s3->tmp.ca_names != NULL)
    3253                 :          0 :                 sk_X509_NAME_pop_free(s->s3->tmp.ca_names,X509_NAME_free);
    3254                 :            : 
    3255         [ -  + ]:       6286 :         if (s->s3->rrec.comp != NULL)
    3256                 :            :                 {
    3257                 :          0 :                 OPENSSL_free(s->s3->rrec.comp);
    3258                 :          0 :                 s->s3->rrec.comp=NULL;
    3259                 :            :                 }
    3260                 :            : #ifndef OPENSSL_NO_DH
    3261         [ -  + ]:       6286 :         if (s->s3->tmp.dh != NULL)
    3262                 :            :                 {
    3263                 :          0 :                 DH_free(s->s3->tmp.dh);
    3264                 :          0 :                 s->s3->tmp.dh = NULL;
    3265                 :            :                 }
    3266                 :            : #endif
    3267                 :            : #ifndef OPENSSL_NO_ECDH
    3268         [ -  + ]:       6286 :         if (s->s3->tmp.ecdh != NULL)
    3269                 :            :                 {
    3270                 :          0 :                 EC_KEY_free(s->s3->tmp.ecdh);
    3271                 :          0 :                 s->s3->tmp.ecdh = NULL;
    3272                 :            :                 }
    3273                 :            : #endif
    3274                 :            : #ifndef OPENSSL_NO_TLSEXT
    3275         [ -  + ]:       6286 :         if (s->s3->serverinfo_client_tlsext_custom_types != NULL)
    3276                 :            :                 {
    3277                 :          0 :                 OPENSSL_free(s->s3->serverinfo_client_tlsext_custom_types);
    3278                 :          0 :                 s->s3->serverinfo_client_tlsext_custom_types = NULL;
    3279                 :            :                 }
    3280                 :       6286 :         s->s3->serverinfo_client_tlsext_custom_types_count = 0;
    3281                 :            : #ifndef OPENSSL_NO_EC
    3282                 :       6286 :         s->s3->is_probably_safari = 0;
    3283                 :            : #endif /* !OPENSSL_NO_EC */
    3284                 :            : #endif /* !OPENSSL_NO_TLSEXT */
    3285                 :            : 
    3286                 :       6286 :         rp = s->s3->rbuf.buf;
    3287                 :       6286 :         wp = s->s3->wbuf.buf;
    3288                 :       6286 :         rlen = s->s3->rbuf.len;
    3289                 :       6286 :         wlen = s->s3->wbuf.len;
    3290                 :       6286 :         init_extra = s->s3->init_extra;
    3291         [ -  + ]:       6286 :         if (s->s3->handshake_buffer) {
    3292                 :          0 :                 BIO_free(s->s3->handshake_buffer);
    3293                 :          0 :                 s->s3->handshake_buffer = NULL;
    3294                 :            :         }
    3295         [ +  + ]:       6286 :         if (s->s3->handshake_dgst) {
    3296                 :        638 :                 ssl3_free_digest_list(s);
    3297                 :            :         }       
    3298                 :            : 
    3299                 :            : #if !defined(OPENSSL_NO_TLSEXT)
    3300         [ -  + ]:       6286 :         if (s->s3->alpn_selected)
    3301                 :            :                 {
    3302                 :          0 :                 free(s->s3->alpn_selected);
    3303                 :          0 :                 s->s3->alpn_selected = NULL;
    3304                 :            :                 }
    3305                 :            : #endif
    3306                 :       6286 :         memset(s->s3,0,sizeof *s->s3);
    3307                 :       6286 :         s->s3->rbuf.buf = rp;
    3308                 :       6286 :         s->s3->wbuf.buf = wp;
    3309                 :       6286 :         s->s3->rbuf.len = rlen;
    3310                 :       6286 :         s->s3->wbuf.len = wlen;
    3311                 :       6286 :         s->s3->init_extra = init_extra;
    3312                 :            : 
    3313                 :       6286 :         ssl_free_wbio_buffer(s);
    3314                 :            : 
    3315                 :       6286 :         s->packet_length=0;
    3316                 :       6286 :         s->s3->renegotiate=0;
    3317                 :       6286 :         s->s3->total_renegotiations=0;
    3318                 :       6286 :         s->s3->num_renegotiations=0;
    3319                 :       6286 :         s->s3->in_read_app_data=0;
    3320                 :       6286 :         s->version=SSL3_VERSION;
    3321                 :            : 
    3322                 :            : #if !defined(OPENSSL_NO_TLSEXT) && !defined(OPENSSL_NO_NEXTPROTONEG)
    3323         [ +  + ]:       6286 :         if (s->next_proto_negotiated)
    3324                 :            :                 {
    3325                 :         44 :                 OPENSSL_free(s->next_proto_negotiated);
    3326                 :         44 :                 s->next_proto_negotiated = NULL;
    3327                 :         44 :                 s->next_proto_negotiated_len = 0;
    3328                 :            :                 }
    3329                 :            : #endif
    3330                 :       6286 :         }
    3331                 :            : 
    3332                 :            : #ifndef OPENSSL_NO_SRP
    3333                 :          0 : static char * MS_CALLBACK srp_password_from_info_cb(SSL *s, void *arg)
    3334                 :            :         {
    3335                 :          0 :         return BUF_strdup(s->srp_ctx.info) ;
    3336                 :            :         }
    3337                 :            : #endif
    3338                 :            : 
    3339                 :            : static int ssl3_set_req_cert_type(CERT *c, const unsigned char *p, size_t len);
    3340                 :            : 
    3341                 :          0 : long ssl3_ctrl(SSL *s, int cmd, long larg, void *parg)
    3342                 :            :         {
    3343                 :          0 :         int ret=0;
    3344                 :            : 
    3345                 :            : #if !defined(OPENSSL_NO_DSA) || !defined(OPENSSL_NO_RSA)
    3346         [ #  # ]:          0 :         if (
    3347                 :            : #ifndef OPENSSL_NO_RSA
    3348                 :          0 :             cmd == SSL_CTRL_SET_TMP_RSA ||
    3349                 :          0 :             cmd == SSL_CTRL_SET_TMP_RSA_CB ||
    3350                 :            : #endif
    3351                 :            : #ifndef OPENSSL_NO_DSA
    3352                 :          0 :             cmd == SSL_CTRL_SET_TMP_DH ||
    3353         [ #  # ]:          0 :             cmd == SSL_CTRL_SET_TMP_DH_CB ||
    3354                 :            : #endif
    3355                 :            :                 0)
    3356                 :            :                 {
    3357         [ #  # ]:          0 :                 if (!ssl_cert_inst(&s->cert))
    3358                 :            :                         {
    3359                 :          0 :                         SSLerr(SSL_F_SSL3_CTRL, ERR_R_MALLOC_FAILURE);
    3360                 :          0 :                         return(0);
    3361                 :            :                         }
    3362                 :            :                 }
    3363                 :            : #endif
    3364                 :            : 
    3365   [ #  #  #  #  :          0 :         switch (cmd)
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
          #  #  #  #  #  
             #  #  #  # ]
    3366                 :            :                 {
    3367                 :            :         case SSL_CTRL_GET_SESSION_REUSED:
    3368                 :          0 :                 ret=s->hit;
    3369                 :          0 :                 break;
    3370                 :            :         case SSL_CTRL_GET_CLIENT_CERT_REQUEST:
    3371                 :            :                 break;
    3372                 :            :         case SSL_CTRL_GET_NUM_RENEGOTIATIONS:
    3373                 :          0 :                 ret=s->s3->num_renegotiations;
    3374                 :          0 :                 break;
    3375                 :            :         case SSL_CTRL_CLEAR_NUM_RENEGOTIATIONS:
    3376                 :          0 :                 ret=s->s3->num_renegotiations;
    3377                 :          0 :                 s->s3->num_renegotiations=0;
    3378                 :          0 :                 break;
    3379                 :            :         case SSL_CTRL_GET_TOTAL_RENEGOTIATIONS:
    3380                 :          0 :                 ret=s->s3->total_renegotiations;
    3381                 :          0 :                 break;
    3382                 :            :         case SSL_CTRL_GET_FLAGS:
    3383                 :          0 :                 ret=(int)(s->s3->flags);
    3384                 :          0 :                 break;
    3385                 :            : #ifndef OPENSSL_NO_RSA
    3386                 :            :         case SSL_CTRL_NEED_TMP_RSA:
    3387 [ #  # ][ #  # ]:          0 :                 if ((s->cert != NULL) && (s->cert->rsa_tmp == NULL) &&
                 [ #  # ]
    3388         [ #  # ]:          0 :                     ((s->cert->pkeys[SSL_PKEY_RSA_ENC].privatekey == NULL) ||
    3389                 :          0 :                      (EVP_PKEY_size(s->cert->pkeys[SSL_PKEY_RSA_ENC].privatekey) > (512/8))))
    3390                 :            :                         ret = 1;
    3391                 :            :                 break;
    3392                 :            :         case SSL_CTRL_SET_TMP_RSA:
    3393                 :            :                 {
    3394                 :          0 :                         RSA *rsa = (RSA *)parg;
    3395         [ #  # ]:          0 :                         if (rsa == NULL)
    3396                 :            :                                 {
    3397                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_PASSED_NULL_PARAMETER);
    3398                 :          0 :                                 return(ret);
    3399                 :            :                                 }
    3400         [ #  # ]:          0 :                         if ((rsa = RSAPrivateKey_dup(rsa)) == NULL)
    3401                 :            :                                 {
    3402                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_RSA_LIB);
    3403                 :          0 :                                 return(ret);
    3404                 :            :                                 }
    3405         [ #  # ]:          0 :                         if (s->cert->rsa_tmp != NULL)
    3406                 :          0 :                                 RSA_free(s->cert->rsa_tmp);
    3407                 :          0 :                         s->cert->rsa_tmp = rsa;
    3408                 :          0 :                         ret = 1;
    3409                 :            :                 }
    3410                 :          0 :                 break;
    3411                 :            :         case SSL_CTRL_SET_TMP_RSA_CB:
    3412                 :            :                 {
    3413                 :          0 :                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    3414                 :          0 :                 return(ret);
    3415                 :            :                 }
    3416                 :            :                 break;
    3417                 :            : #endif
    3418                 :            : #ifndef OPENSSL_NO_DH
    3419                 :            :         case SSL_CTRL_SET_TMP_DH:
    3420                 :            :                 {
    3421                 :          0 :                         DH *dh = (DH *)parg;
    3422         [ #  # ]:          0 :                         if (dh == NULL)
    3423                 :            :                                 {
    3424                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_PASSED_NULL_PARAMETER);
    3425                 :          0 :                                 return(ret);
    3426                 :            :                                 }
    3427         [ #  # ]:          0 :                         if (!ssl_security(s, SSL_SECOP_TMP_DH,
    3428                 :            :                                                 DH_security_bits(dh), 0, dh))
    3429                 :            :                                 {
    3430                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, SSL_R_DH_KEY_TOO_SMALL);
    3431                 :          0 :                                 return(ret);
    3432                 :            :                                 }
    3433         [ #  # ]:          0 :                         if ((dh = DHparams_dup(dh)) == NULL)
    3434                 :            :                                 {
    3435                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_DH_LIB);
    3436                 :          0 :                                 return(ret);
    3437                 :            :                                 }
    3438         [ #  # ]:          0 :                         if (!(s->options & SSL_OP_SINGLE_DH_USE))
    3439                 :            :                                 {
    3440         [ #  # ]:          0 :                                 if (!DH_generate_key(dh))
    3441                 :            :                                         {
    3442                 :          0 :                                         DH_free(dh);
    3443                 :          0 :                                         SSLerr(SSL_F_SSL3_CTRL, ERR_R_DH_LIB);
    3444                 :          0 :                                         return(ret);
    3445                 :            :                                         }
    3446                 :            :                                 }
    3447         [ #  # ]:          0 :                         if (s->cert->dh_tmp != NULL)
    3448                 :          0 :                                 DH_free(s->cert->dh_tmp);
    3449                 :          0 :                         s->cert->dh_tmp = dh;
    3450                 :          0 :                         ret = 1;
    3451                 :            :                 }
    3452                 :          0 :                 break;
    3453                 :            :         case SSL_CTRL_SET_TMP_DH_CB:
    3454                 :            :                 {
    3455                 :          0 :                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    3456                 :          0 :                 return(ret);
    3457                 :            :                 }
    3458                 :            :                 break;
    3459                 :            :         case SSL_CTRL_SET_DH_AUTO:
    3460                 :          0 :                 s->cert->dh_tmp_auto = larg;
    3461                 :          0 :                 return 1;
    3462                 :            : #endif
    3463                 :            : #ifndef OPENSSL_NO_ECDH
    3464                 :            :         case SSL_CTRL_SET_TMP_ECDH:
    3465                 :            :                 {
    3466                 :          0 :                 EC_KEY *ecdh = NULL;
    3467                 :            :                         
    3468         [ #  # ]:          0 :                 if (parg == NULL)
    3469                 :            :                         {
    3470                 :          0 :                         SSLerr(SSL_F_SSL3_CTRL, ERR_R_PASSED_NULL_PARAMETER);
    3471                 :          0 :                         return(ret);
    3472                 :            :                         }
    3473         [ #  # ]:          0 :                 if (!EC_KEY_up_ref((EC_KEY *)parg))
    3474                 :            :                         {
    3475                 :          0 :                         SSLerr(SSL_F_SSL3_CTRL,ERR_R_ECDH_LIB);
    3476                 :          0 :                         return(ret);
    3477                 :            :                         }
    3478                 :          0 :                 ecdh = (EC_KEY *)parg;
    3479         [ #  # ]:          0 :                 if (!(s->options & SSL_OP_SINGLE_ECDH_USE))
    3480                 :            :                         {
    3481         [ #  # ]:          0 :                         if (!EC_KEY_generate_key(ecdh))
    3482                 :            :                                 {
    3483                 :          0 :                                 EC_KEY_free(ecdh);
    3484                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL,ERR_R_ECDH_LIB);
    3485                 :          0 :                                 return(ret);
    3486                 :            :                                 }
    3487                 :            :                         }
    3488         [ #  # ]:          0 :                 if (s->cert->ecdh_tmp != NULL)
    3489                 :          0 :                         EC_KEY_free(s->cert->ecdh_tmp);
    3490                 :          0 :                 s->cert->ecdh_tmp = ecdh;
    3491                 :          0 :                 ret = 1;
    3492                 :            :                 }
    3493                 :          0 :                 break;
    3494                 :            :         case SSL_CTRL_SET_TMP_ECDH_CB:
    3495                 :            :                 {
    3496                 :          0 :                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    3497                 :          0 :                 return(ret);
    3498                 :            :                 }
    3499                 :            :                 break;
    3500                 :            : #endif /* !OPENSSL_NO_ECDH */
    3501                 :            : #ifndef OPENSSL_NO_TLSEXT
    3502                 :            :         case SSL_CTRL_SET_TLSEXT_HOSTNAME:
    3503         [ #  # ]:          0 :                 if (larg == TLSEXT_NAMETYPE_host_name)
    3504                 :            :                         {
    3505         [ #  # ]:          0 :                         if (s->tlsext_hostname != NULL) 
    3506                 :          0 :                                 OPENSSL_free(s->tlsext_hostname);
    3507                 :          0 :                         s->tlsext_hostname = NULL;
    3508                 :            : 
    3509                 :          0 :                         ret = 1;
    3510         [ #  # ]:          0 :                         if (parg == NULL) 
    3511                 :            :                                 break;
    3512         [ #  # ]:          0 :                         if (strlen((char *)parg) > TLSEXT_MAXLEN_host_name)
    3513                 :            :                                 {
    3514                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, SSL_R_SSL3_EXT_INVALID_SERVERNAME);
    3515                 :          0 :                                 return 0;
    3516                 :            :                                 }
    3517         [ #  # ]:          0 :                         if ((s->tlsext_hostname = BUF_strdup((char *)parg)) == NULL)
    3518                 :            :                                 {
    3519                 :          0 :                                 SSLerr(SSL_F_SSL3_CTRL, ERR_R_INTERNAL_ERROR);
    3520                 :          0 :                                 return 0;
    3521                 :            :                                 }
    3522                 :            :                         }
    3523                 :            :                 else
    3524                 :            :                         {
    3525                 :          0 :                         SSLerr(SSL_F_SSL3_CTRL, SSL_R_SSL3_EXT_INVALID_SERVERNAME_TYPE);
    3526                 :          0 :                         return 0;
    3527                 :            :                         }
    3528                 :            :                 break;
    3529                 :            :         case SSL_CTRL_SET_TLSEXT_DEBUG_ARG:
    3530                 :          0 :                 s->tlsext_debug_arg=parg;
    3531                 :          0 :                 ret = 1;
    3532                 :          0 :                 break;
    3533                 :            : 
    3534                 :            : #ifdef TLSEXT_TYPE_opaque_prf_input
    3535                 :            :         case SSL_CTRL_SET_TLSEXT_OPAQUE_PRF_INPUT:
    3536                 :            :                 if (larg > 12288) /* actual internal limit is 2^16 for the complete hello message
    3537                 :            :                                    * (including the cert chain and everything) */
    3538                 :            :                         {
    3539                 :            :                         SSLerr(SSL_F_SSL3_CTRL, SSL_R_OPAQUE_PRF_INPUT_TOO_LONG);
    3540                 :            :                         break;
    3541                 :            :                         }
    3542                 :            :                 if (s->tlsext_opaque_prf_input != NULL)
    3543                 :            :                         OPENSSL_free(s->tlsext_opaque_prf_input);
    3544                 :            :                 if ((size_t)larg == 0)
    3545                 :            :                         s->tlsext_opaque_prf_input = OPENSSL_malloc(1); /* dummy byte just to get non-NULL */
    3546                 :            :                 else
    3547                 :            :                         s->tlsext_opaque_prf_input = BUF_memdup(parg, (size_t)larg);
    3548                 :            :                 if (s->tlsext_opaque_prf_input != NULL)
    3549                 :            :                         {
    3550                 :            :                         s->tlsext_opaque_prf_input_len = (size_t)larg;
    3551                 :            :                         ret = 1;
    3552                 :            :                         }
    3553                 :            :                 else
    3554                 :            :                         s->tlsext_opaque_prf_input_len = 0;
    3555                 :            :                 break;
    3556                 :            : #endif
    3557                 :            : 
    3558                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_TYPE:
    3559                 :          0 :                 s->tlsext_status_type=larg;
    3560                 :          0 :                 ret = 1;
    3561                 :          0 :                 break;
    3562                 :            : 
    3563                 :            :         case SSL_CTRL_GET_TLSEXT_STATUS_REQ_EXTS:
    3564                 :          0 :                 *(STACK_OF(X509_EXTENSION) **)parg = s->tlsext_ocsp_exts;
    3565                 :          0 :                 ret = 1;
    3566                 :          0 :                 break;
    3567                 :            : 
    3568                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_EXTS:
    3569                 :          0 :                 s->tlsext_ocsp_exts = parg;
    3570                 :          0 :                 ret = 1;
    3571                 :          0 :                 break;
    3572                 :            : 
    3573                 :            :         case SSL_CTRL_GET_TLSEXT_STATUS_REQ_IDS:
    3574                 :          0 :                 *(STACK_OF(OCSP_RESPID) **)parg = s->tlsext_ocsp_ids;
    3575                 :          0 :                 ret = 1;
    3576                 :          0 :                 break;
    3577                 :            : 
    3578                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_IDS:
    3579                 :          0 :                 s->tlsext_ocsp_ids = parg;
    3580                 :          0 :                 ret = 1;
    3581                 :          0 :                 break;
    3582                 :            : 
    3583                 :            :         case SSL_CTRL_GET_TLSEXT_STATUS_REQ_OCSP_RESP:
    3584                 :          0 :                 *(unsigned char **)parg = s->tlsext_ocsp_resp;
    3585                 :          0 :                 return s->tlsext_ocsp_resplen;
    3586                 :            :                 
    3587                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_OCSP_RESP:
    3588         [ #  # ]:          0 :                 if (s->tlsext_ocsp_resp)
    3589                 :          0 :                         OPENSSL_free(s->tlsext_ocsp_resp);
    3590                 :          0 :                 s->tlsext_ocsp_resp = parg;
    3591                 :          0 :                 s->tlsext_ocsp_resplen = larg;
    3592                 :          0 :                 ret = 1;
    3593                 :          0 :                 break;
    3594                 :            : 
    3595                 :            : #ifndef OPENSSL_NO_HEARTBEATS
    3596                 :            :         case SSL_CTRL_TLS_EXT_SEND_HEARTBEAT:
    3597         [ #  # ]:          0 :                 if (SSL_IS_DTLS(s))
    3598                 :          0 :                         ret = dtls1_heartbeat(s);
    3599                 :            :                 else
    3600                 :          0 :                         ret = tls1_heartbeat(s);
    3601                 :            :                 break;
    3602                 :            : 
    3603                 :            :         case SSL_CTRL_GET_TLS_EXT_HEARTBEAT_PENDING:
    3604                 :          0 :                 ret = s->tlsext_hb_pending;
    3605                 :          0 :                 break;
    3606                 :            : 
    3607                 :            :         case SSL_CTRL_SET_TLS_EXT_HEARTBEAT_NO_REQUESTS:
    3608         [ #  # ]:          0 :                 if (larg)
    3609                 :          0 :                         s->tlsext_heartbeat |= SSL_TLSEXT_HB_DONT_RECV_REQUESTS;
    3610                 :            :                 else
    3611                 :          0 :                         s->tlsext_heartbeat &= ~SSL_TLSEXT_HB_DONT_RECV_REQUESTS;
    3612                 :            :                 ret = 1;
    3613                 :            :                 break;
    3614                 :            : #endif
    3615                 :            : 
    3616                 :            : #endif /* !OPENSSL_NO_TLSEXT */
    3617                 :            : 
    3618                 :            :         case SSL_CTRL_CHAIN:
    3619         [ #  # ]:          0 :                 if (larg)
    3620                 :          0 :                         return ssl_cert_set1_chain(s, NULL,
    3621                 :            :                                                 (STACK_OF (X509) *)parg);
    3622                 :            :                 else
    3623                 :          0 :                         return ssl_cert_set0_chain(s, NULL,
    3624                 :            :                                                 (STACK_OF (X509) *)parg);
    3625                 :            : 
    3626                 :            :         case SSL_CTRL_CHAIN_CERT:
    3627         [ #  # ]:          0 :                 if (larg)
    3628                 :          0 :                         return ssl_cert_add1_chain_cert(s, NULL, (X509 *)parg);
    3629                 :            :                 else
    3630                 :          0 :                         return ssl_cert_add0_chain_cert(s, NULL, (X509 *)parg);
    3631                 :            : 
    3632                 :            :         case SSL_CTRL_GET_CHAIN_CERTS:
    3633                 :          0 :                 *(STACK_OF(X509) **)parg = s->cert->key->chain;
    3634                 :          0 :                 break;
    3635                 :            : 
    3636                 :            :         case SSL_CTRL_SELECT_CURRENT_CERT:
    3637                 :          0 :                 return ssl_cert_select_current(s->cert, (X509 *)parg);
    3638                 :            : 
    3639                 :            :         case SSL_CTRL_SET_CURRENT_CERT:
    3640         [ #  # ]:          0 :                 if (larg == SSL_CERT_SET_SERVER)
    3641                 :            :                         {
    3642                 :            :                         CERT_PKEY *cpk;
    3643                 :            :                         const SSL_CIPHER *cipher;
    3644         [ #  # ]:          0 :                         if (!s->server)
    3645                 :            :                                 return 0;
    3646                 :          0 :                         cipher = s->s3->tmp.new_cipher;
    3647         [ #  # ]:          0 :                         if (!cipher)
    3648                 :            :                                 return 0;
    3649                 :            :                         /* No certificate for unauthenticated ciphersuites */
    3650         [ #  # ]:          0 :                         if (cipher->algorithm_auth & SSL_aNULL)
    3651                 :            :                                 return 2;
    3652                 :          0 :                         cpk = ssl_get_server_send_pkey(s);
    3653         [ #  # ]:          0 :                         if (!cpk)
    3654                 :            :                                 return 0;
    3655                 :          0 :                         s->cert->key = cpk;
    3656                 :          0 :                         return 1;
    3657                 :            :                         }
    3658                 :          0 :                 return ssl_cert_set_current(s->cert, larg);
    3659                 :            : 
    3660                 :            : #ifndef OPENSSL_NO_EC
    3661                 :            :         case SSL_CTRL_GET_CURVES:
    3662                 :            :                 {
    3663                 :            :                 unsigned char *clist;
    3664                 :            :                 size_t clistlen;
    3665         [ #  # ]:          0 :                 if (!s->session)
    3666                 :            :                         return 0;
    3667                 :          0 :                 clist = s->session->tlsext_ellipticcurvelist;
    3668                 :          0 :                 clistlen = s->session->tlsext_ellipticcurvelist_length / 2;
    3669         [ #  # ]:          0 :                 if (parg)
    3670                 :            :                         {
    3671                 :            :                         size_t i;
    3672                 :            :                         int *cptr = parg;
    3673                 :            :                         unsigned int cid, nid;
    3674         [ #  # ]:          0 :                         for (i = 0; i < clistlen; i++)
    3675                 :            :                                 {
    3676                 :          0 :                                 n2s(clist, cid);
    3677                 :          0 :                                 nid = tls1_ec_curve_id2nid(cid);
    3678         [ #  # ]:          0 :                                 if (nid != 0)
    3679                 :          0 :                                         cptr[i] = nid;
    3680                 :            :                                 else
    3681                 :          0 :                                         cptr[i] = TLSEXT_nid_unknown | cid;
    3682                 :            :                                 }
    3683                 :            :                         }
    3684                 :          0 :                 return (int)clistlen;
    3685                 :            :                 }
    3686                 :            : 
    3687                 :            :         case SSL_CTRL_SET_CURVES:
    3688                 :          0 :                 return tls1_set_curves(&s->tlsext_ellipticcurvelist,
    3689                 :            :                                         &s->tlsext_ellipticcurvelist_length,
    3690                 :            :                                                                 parg, larg);
    3691                 :            : 
    3692                 :            :         case SSL_CTRL_SET_CURVES_LIST:
    3693                 :          0 :                 return tls1_set_curves_list(&s->tlsext_ellipticcurvelist,
    3694                 :            :                                         &s->tlsext_ellipticcurvelist_length,
    3695                 :            :                                                                 parg);
    3696                 :            : 
    3697                 :            :         case SSL_CTRL_GET_SHARED_CURVE:
    3698                 :          0 :                 return tls1_shared_curve(s, larg);
    3699                 :            : 
    3700                 :            :         case SSL_CTRL_SET_ECDH_AUTO:
    3701                 :          0 :                 s->cert->ecdh_tmp_auto = larg;
    3702                 :          0 :                 return 1;
    3703                 :            : #endif
    3704                 :            :         case SSL_CTRL_SET_SIGALGS:
    3705                 :          0 :                 return tls1_set_sigalgs(s->cert, parg, larg, 0);
    3706                 :            : 
    3707                 :            :         case SSL_CTRL_SET_SIGALGS_LIST:
    3708                 :          0 :                 return tls1_set_sigalgs_list(s->cert, parg, 0);
    3709                 :            : 
    3710                 :            :         case SSL_CTRL_SET_CLIENT_SIGALGS:
    3711                 :          0 :                 return tls1_set_sigalgs(s->cert, parg, larg, 1);
    3712                 :            : 
    3713                 :            :         case SSL_CTRL_SET_CLIENT_SIGALGS_LIST:
    3714                 :          0 :                 return tls1_set_sigalgs_list(s->cert, parg, 1);
    3715                 :            : 
    3716                 :            :         case SSL_CTRL_GET_CLIENT_CERT_TYPES:
    3717                 :            :                 {
    3718                 :          0 :                 const unsigned char **pctype = parg;
    3719 [ #  # ][ #  # ]:          0 :                 if (s->server || !s->s3->tmp.cert_req)
    3720                 :            :                         return 0;
    3721         [ #  # ]:          0 :                 if (s->cert->ctypes)
    3722                 :            :                         {
    3723         [ #  # ]:          0 :                         if (pctype)
    3724                 :          0 :                                 *pctype = s->cert->ctypes;
    3725                 :          0 :                         return (int)s->cert->ctype_num;
    3726                 :            :                         }
    3727         [ #  # ]:          0 :                 if (pctype)
    3728                 :          0 :                         *pctype = (unsigned char *)s->s3->tmp.ctype;
    3729                 :          0 :                 return s->s3->tmp.ctype_num;
    3730                 :            :                 }
    3731                 :            : 
    3732                 :            :         case SSL_CTRL_SET_CLIENT_CERT_TYPES:
    3733         [ #  # ]:          0 :                 if (!s->server)
    3734                 :            :                         return 0;
    3735                 :          0 :                 return ssl3_set_req_cert_type(s->cert, parg, larg);
    3736                 :            : 
    3737                 :            :         case SSL_CTRL_BUILD_CERT_CHAIN:
    3738                 :          0 :                 return ssl_build_cert_chain(s, NULL, larg);
    3739                 :            : 
    3740                 :            :         case SSL_CTRL_SET_VERIFY_CERT_STORE:
    3741                 :          0 :                 return ssl_cert_set_cert_store(s->cert, parg, 0, larg);
    3742                 :            : 
    3743                 :            :         case SSL_CTRL_SET_CHAIN_CERT_STORE:
    3744                 :          0 :                 return ssl_cert_set_cert_store(s->cert, parg, 1, larg);
    3745                 :            : 
    3746                 :            :         case SSL_CTRL_GET_PEER_SIGNATURE_NID:
    3747         [ #  # ]:          0 :                 if (SSL_USE_SIGALGS(s))
    3748                 :            :                         {
    3749 [ #  # ][ #  # ]:          0 :                         if (s->session && s->session->sess_cert)
    3750                 :            :                                 {
    3751                 :            :                                 const EVP_MD *sig;
    3752                 :          0 :                                 sig = s->session->sess_cert->peer_key->digest;
    3753         [ #  # ]:          0 :                                 if (sig)
    3754                 :            :                                         {
    3755                 :          0 :                                         *(int *)parg = EVP_MD_type(sig);
    3756                 :          0 :                                         return 1;
    3757                 :            :                                         }
    3758                 :            :                                 }
    3759                 :            :                         return 0;
    3760                 :            :                         }
    3761                 :            :                 /* Might want to do something here for other versions */
    3762                 :            :                 else
    3763                 :            :                         return 0;
    3764                 :            : 
    3765                 :            :         case SSL_CTRL_GET_SERVER_TMP_KEY:
    3766 [ #  # ][ #  # ]:          0 :                 if (s->server || !s->session || !s->session->sess_cert)
                 [ #  # ]
    3767                 :            :                         return 0;
    3768                 :            :                 else
    3769                 :            :                         {
    3770                 :            :                         SESS_CERT *sc;
    3771                 :            :                         EVP_PKEY *ptmp;
    3772                 :          0 :                         int rv = 0;
    3773                 :          0 :                         sc = s->session->sess_cert;
    3774                 :            : #if !defined(OPENSSL_NO_RSA) && !defined(OPENSSL_NO_DH) && !defined(OPENSSL_NO_EC)
    3775 [ #  # ][ #  # ]:          0 :                         if (!sc->peer_rsa_tmp && !sc->peer_dh_tmp
    3776         [ #  # ]:          0 :                                                         && !sc->peer_ecdh_tmp)
    3777                 :            :                                 return 0;
    3778                 :            : #endif
    3779                 :          0 :                         ptmp = EVP_PKEY_new();
    3780         [ #  # ]:          0 :                         if (!ptmp)
    3781                 :            :                                 return 0;
    3782                 :            :                         if (0);
    3783                 :            : #ifndef OPENSSL_NO_RSA
    3784         [ #  # ]:          0 :                         else if (sc->peer_rsa_tmp)
    3785                 :          0 :                                 rv = EVP_PKEY_set1_RSA(ptmp, sc->peer_rsa_tmp);
    3786                 :            : #endif
    3787                 :            : #ifndef OPENSSL_NO_DH
    3788         [ #  # ]:          0 :                         else if (sc->peer_dh_tmp)
    3789                 :          0 :                                 rv = EVP_PKEY_set1_DH(ptmp, sc->peer_dh_tmp);
    3790                 :            : #endif
    3791                 :            : #ifndef OPENSSL_NO_ECDH
    3792         [ #  # ]:          0 :                         else if (sc->peer_ecdh_tmp)
    3793                 :          0 :                                 rv = EVP_PKEY_set1_EC_KEY(ptmp, sc->peer_ecdh_tmp);
    3794                 :            : #endif
    3795         [ #  # ]:          0 :                         if (rv)
    3796                 :            :                                 {
    3797                 :          0 :                                 *(EVP_PKEY **)parg = ptmp;
    3798                 :          0 :                                 return 1;
    3799                 :            :                                 }
    3800                 :          0 :                         EVP_PKEY_free(ptmp);
    3801                 :          0 :                         return 0;
    3802                 :            :                         }
    3803                 :            : #ifndef OPENSSL_NO_EC
    3804                 :            :         case SSL_CTRL_GET_EC_POINT_FORMATS:
    3805                 :            :                 {
    3806                 :          0 :                 SSL_SESSION *sess = s->session;
    3807                 :          0 :                 const unsigned char **pformat = parg;
    3808 [ #  # ][ #  # ]:          0 :                 if (!sess || !sess->tlsext_ecpointformatlist)
    3809                 :            :                         return 0;
    3810                 :          0 :                 *pformat = sess->tlsext_ecpointformatlist;
    3811                 :          0 :                 return (int)sess->tlsext_ecpointformatlist_length;
    3812                 :            :                 }
    3813                 :            : #endif
    3814                 :            :         default:
    3815                 :            :                 break;
    3816                 :            :                 }
    3817                 :          0 :         return(ret);
    3818                 :            :         }
    3819                 :            : 
    3820                 :          0 : long ssl3_callback_ctrl(SSL *s, int cmd, void (*fp)(void))
    3821                 :            :         {
    3822                 :          0 :         int ret=0;
    3823                 :            : 
    3824                 :            : #if !defined(OPENSSL_NO_DSA) || !defined(OPENSSL_NO_RSA)
    3825         [ #  # ]:          0 :         if (
    3826                 :            : #ifndef OPENSSL_NO_RSA
    3827                 :          0 :             cmd == SSL_CTRL_SET_TMP_RSA_CB ||
    3828                 :            : #endif
    3829                 :            : #ifndef OPENSSL_NO_DSA
    3830                 :            :             cmd == SSL_CTRL_SET_TMP_DH_CB ||
    3831                 :            : #endif
    3832                 :            :                 0)
    3833                 :            :                 {
    3834         [ #  # ]:          0 :                 if (!ssl_cert_inst(&s->cert))
    3835                 :            :                         {
    3836                 :          0 :                         SSLerr(SSL_F_SSL3_CALLBACK_CTRL, ERR_R_MALLOC_FAILURE);
    3837                 :          0 :                         return(0);
    3838                 :            :                         }
    3839                 :            :                 }
    3840                 :            : #endif
    3841                 :            : 
    3842   [ #  #  #  #  :          0 :         switch (cmd)
                   #  # ]
    3843                 :            :                 {
    3844                 :            : #ifndef OPENSSL_NO_RSA
    3845                 :            :         case SSL_CTRL_SET_TMP_RSA_CB:
    3846                 :            :                 {
    3847                 :          0 :                 s->cert->rsa_tmp_cb = (RSA *(*)(SSL *, int, int))fp;
    3848                 :            :                 }
    3849                 :          0 :                 break;
    3850                 :            : #endif
    3851                 :            : #ifndef OPENSSL_NO_DH
    3852                 :            :         case SSL_CTRL_SET_TMP_DH_CB:
    3853                 :            :                 {
    3854                 :          0 :                 s->cert->dh_tmp_cb = (DH *(*)(SSL *, int, int))fp;
    3855                 :            :                 }
    3856                 :          0 :                 break;
    3857                 :            : #endif
    3858                 :            : #ifndef OPENSSL_NO_ECDH
    3859                 :            :         case SSL_CTRL_SET_TMP_ECDH_CB:
    3860                 :            :                 {
    3861                 :          0 :                 s->cert->ecdh_tmp_cb = (EC_KEY *(*)(SSL *, int, int))fp;
    3862                 :            :                 }
    3863                 :          0 :                 break;
    3864                 :            : #endif
    3865                 :            : #ifndef OPENSSL_NO_TLSEXT
    3866                 :            :         case SSL_CTRL_SET_TLSEXT_DEBUG_CB:
    3867                 :          0 :                 s->tlsext_debug_cb=(void (*)(SSL *,int ,int,
    3868                 :            :                                         unsigned char *, int, void *))fp;
    3869                 :          0 :                 break;
    3870                 :            : #endif
    3871                 :            :         case SSL_CTRL_SET_NOT_RESUMABLE_SESS_CB:
    3872                 :            :                 {
    3873                 :          0 :                 s->not_resumable_session_cb = (int (*)(SSL *, int))fp;
    3874                 :            :                 }
    3875                 :          0 :                 break;
    3876                 :            :         default:
    3877                 :            :                 break;
    3878                 :            :                 }
    3879                 :            :         return(ret);
    3880                 :            :         }
    3881                 :            : 
    3882                 :       1544 : long ssl3_ctx_ctrl(SSL_CTX *ctx, int cmd, long larg, void *parg)
    3883                 :            :         {
    3884                 :            :         CERT *cert;
    3885                 :            : 
    3886                 :       1544 :         cert=ctx->cert;
    3887                 :            : 
    3888   [ -  -  -  +  :       1544 :         switch (cmd)
          -  -  +  -  -  
          -  -  +  -  +  
          -  -  -  -  -  
          -  -  -  -  -  
          -  -  -  -  -  
          -  -  -  -  -  
                      - ]
    3889                 :            :                 {
    3890                 :            : #ifndef OPENSSL_NO_RSA
    3891                 :            :         case SSL_CTRL_NEED_TMP_RSA:
    3892 [ #  # ][ #  # ]:          0 :                 if (    (cert->rsa_tmp == NULL) &&
    3893         [ #  # ]:          0 :                         ((cert->pkeys[SSL_PKEY_RSA_ENC].privatekey == NULL) ||
    3894                 :          0 :                          (EVP_PKEY_size(cert->pkeys[SSL_PKEY_RSA_ENC].privatekey) > (512/8)))
    3895                 :            :                         )
    3896                 :            :                         return(1);
    3897                 :            :                 else
    3898                 :            :                         return(0);
    3899                 :            :                 /* break; */
    3900                 :            :         case SSL_CTRL_SET_TMP_RSA:
    3901                 :            :                 {
    3902                 :            :                 RSA *rsa;
    3903                 :            :                 int i;
    3904                 :            : 
    3905                 :          0 :                 rsa=(RSA *)parg;
    3906                 :          0 :                 i=1;
    3907         [ #  # ]:          0 :                 if (rsa == NULL)
    3908                 :            :                         i=0;
    3909                 :            :                 else
    3910                 :            :                         {
    3911         [ #  # ]:          0 :                         if ((rsa=RSAPrivateKey_dup(rsa)) == NULL)
    3912                 :          0 :                                 i=0;
    3913                 :            :                         }
    3914         [ #  # ]:          0 :                 if (!i)
    3915                 :            :                         {
    3916                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_RSA_LIB);
    3917                 :          0 :                         return(0);
    3918                 :            :                         }
    3919                 :            :                 else
    3920                 :            :                         {
    3921         [ #  # ]:          0 :                         if (cert->rsa_tmp != NULL)
    3922                 :          0 :                                 RSA_free(cert->rsa_tmp);
    3923                 :          0 :                         cert->rsa_tmp=rsa;
    3924                 :          0 :                         return(1);
    3925                 :            :                         }
    3926                 :            :                 }
    3927                 :            :                 /* break; */
    3928                 :            :         case SSL_CTRL_SET_TMP_RSA_CB:
    3929                 :            :                 {
    3930                 :          0 :                 SSLerr(SSL_F_SSL3_CTX_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    3931                 :          0 :                 return(0);
    3932                 :            :                 }
    3933                 :            :                 break;
    3934                 :            : #endif
    3935                 :            : #ifndef OPENSSL_NO_DH
    3936                 :            :         case SSL_CTRL_SET_TMP_DH:
    3937                 :            :                 {
    3938                 :        739 :                 DH *new=NULL,*dh;
    3939                 :            : 
    3940                 :        739 :                 dh=(DH *)parg;
    3941         [ -  + ]:        739 :                 if (!ssl_ctx_security(ctx, SSL_SECOP_TMP_DH,
    3942                 :            :                                                 DH_security_bits(dh), 0, dh))
    3943                 :            :                         {
    3944                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL, SSL_R_DH_KEY_TOO_SMALL);
    3945                 :          0 :                         return 0;
    3946                 :            :                         }
    3947         [ -  + ]:        739 :                 if ((new=DHparams_dup(dh)) == NULL)
    3948                 :            :                         {
    3949                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_DH_LIB);
    3950                 :          0 :                         return 0;
    3951                 :            :                         }
    3952         [ +  + ]:        739 :                 if (!(ctx->options & SSL_OP_SINGLE_DH_USE))
    3953                 :            :                         {
    3954         [ -  + ]:        706 :                         if (!DH_generate_key(new))
    3955                 :            :                                 {
    3956                 :          0 :                                 SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_DH_LIB);
    3957                 :          0 :                                 DH_free(new);
    3958                 :          0 :                                 return 0;
    3959                 :            :                                 }
    3960                 :            :                         }
    3961         [ -  + ]:        739 :                 if (cert->dh_tmp != NULL)
    3962                 :          0 :                         DH_free(cert->dh_tmp);
    3963                 :        739 :                 cert->dh_tmp=new;
    3964                 :        739 :                 return 1;
    3965                 :            :                 }
    3966                 :            :                 /*break; */
    3967                 :            :         case SSL_CTRL_SET_TMP_DH_CB:
    3968                 :            :                 {
    3969                 :          0 :                 SSLerr(SSL_F_SSL3_CTX_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    3970                 :          0 :                 return(0);
    3971                 :            :                 }
    3972                 :            :                 break;
    3973                 :            :         case SSL_CTRL_SET_DH_AUTO:
    3974                 :          0 :                 ctx->cert->dh_tmp_auto = larg;
    3975                 :          0 :                 return 1;
    3976                 :            : #endif
    3977                 :            : #ifndef OPENSSL_NO_ECDH
    3978                 :            :         case SSL_CTRL_SET_TMP_ECDH:
    3979                 :            :                 {
    3980                 :        739 :                 EC_KEY *ecdh = NULL;
    3981                 :            :                         
    3982         [ -  + ]:        739 :                 if (parg == NULL)
    3983                 :            :                         {
    3984                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_ECDH_LIB);
    3985                 :          0 :                         return 0;
    3986                 :            :                         }
    3987                 :        739 :                 ecdh = EC_KEY_dup((EC_KEY *)parg);
    3988         [ -  + ]:        739 :                 if (ecdh == NULL)
    3989                 :            :                         {
    3990                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_EC_LIB);
    3991                 :          0 :                         return 0;
    3992                 :            :                         }
    3993         [ +  - ]:        739 :                 if (!(ctx->options & SSL_OP_SINGLE_ECDH_USE))
    3994                 :            :                         {
    3995         [ -  + ]:        739 :                         if (!EC_KEY_generate_key(ecdh))
    3996                 :            :                                 {
    3997                 :          0 :                                 EC_KEY_free(ecdh);
    3998                 :          0 :                                 SSLerr(SSL_F_SSL3_CTX_CTRL,ERR_R_ECDH_LIB);
    3999                 :          0 :                                 return 0;
    4000                 :            :                                 }
    4001                 :            :                         }
    4002                 :            : 
    4003         [ -  + ]:        739 :                 if (cert->ecdh_tmp != NULL)
    4004                 :            :                         {
    4005                 :          0 :                         EC_KEY_free(cert->ecdh_tmp);
    4006                 :            :                         }
    4007                 :        739 :                 cert->ecdh_tmp = ecdh;
    4008                 :        739 :                 return 1;
    4009                 :            :                 }
    4010                 :            :                 /* break; */
    4011                 :            :         case SSL_CTRL_SET_TMP_ECDH_CB:
    4012                 :            :                 {
    4013                 :          0 :                 SSLerr(SSL_F_SSL3_CTX_CTRL, ERR_R_SHOULD_NOT_HAVE_BEEN_CALLED);
    4014                 :          0 :                 return(0);
    4015                 :            :                 }
    4016                 :            :                 break;
    4017                 :            : #endif /* !OPENSSL_NO_ECDH */
    4018                 :            : #ifndef OPENSSL_NO_TLSEXT
    4019                 :            :         case SSL_CTRL_SET_TLSEXT_SERVERNAME_ARG:
    4020                 :          0 :                 ctx->tlsext_servername_arg=parg;
    4021                 :          0 :                 break;
    4022                 :            :         case SSL_CTRL_SET_TLSEXT_TICKET_KEYS:
    4023                 :            :         case SSL_CTRL_GET_TLSEXT_TICKET_KEYS:
    4024                 :            :                 {
    4025                 :          0 :                 unsigned char *keys = parg;
    4026         [ #  # ]:          0 :                 if (!keys)
    4027                 :            :                         return 48;
    4028         [ #  # ]:          0 :                 if (larg != 48)
    4029                 :            :                         {
    4030                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL, SSL_R_INVALID_TICKET_KEYS_LENGTH);
    4031                 :          0 :                         return 0;
    4032                 :            :                         }
    4033         [ #  # ]:          0 :                 if (cmd == SSL_CTRL_SET_TLSEXT_TICKET_KEYS)
    4034                 :            :                         {
    4035                 :          0 :                         memcpy(ctx->tlsext_tick_key_name, keys, 16);
    4036                 :          0 :                         memcpy(ctx->tlsext_tick_hmac_key, keys + 16, 16);
    4037                 :          0 :                         memcpy(ctx->tlsext_tick_aes_key, keys + 32, 16);
    4038                 :            :                         }
    4039                 :            :                 else
    4040                 :            :                         {
    4041                 :          0 :                         memcpy(keys, ctx->tlsext_tick_key_name, 16);
    4042                 :          0 :                         memcpy(keys + 16, ctx->tlsext_tick_hmac_key, 16);
    4043                 :          0 :                         memcpy(keys + 32, ctx->tlsext_tick_aes_key, 16);
    4044                 :            :                         }
    4045                 :            :                 return 1;
    4046                 :            :                 }
    4047                 :            : 
    4048                 :            : #ifdef TLSEXT_TYPE_opaque_prf_input
    4049                 :            :         case SSL_CTRL_SET_TLSEXT_OPAQUE_PRF_INPUT_CB_ARG:
    4050                 :            :                 ctx->tlsext_opaque_prf_input_callback_arg = parg;
    4051                 :            :                 return 1;
    4052                 :            : #endif
    4053                 :            : 
    4054                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_CB_ARG:
    4055                 :          0 :                 ctx->tlsext_status_arg=parg;
    4056                 :          0 :                 return 1;
    4057                 :            :                 break;
    4058                 :            : 
    4059                 :            : #ifndef OPENSSL_NO_SRP
    4060                 :            :         case SSL_CTRL_SET_TLS_EXT_SRP_USERNAME:
    4061                 :         22 :                 ctx->srp_ctx.srp_Mask|=SSL_kSRP;
    4062         [ -  + ]:         22 :                 if (ctx->srp_ctx.login != NULL)
    4063                 :          0 :                         OPENSSL_free(ctx->srp_ctx.login);
    4064                 :         22 :                 ctx->srp_ctx.login = NULL;
    4065         [ +  - ]:         22 :                 if (parg == NULL)
    4066                 :            :                         break;
    4067 [ +  - ][ -  + ]:         22 :                 if (strlen((const char *)parg) > 255 || strlen((const char *)parg) < 1)
    4068                 :            :                         {
    4069                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL, SSL_R_INVALID_SRP_USERNAME);
    4070                 :          0 :                         return 0;
    4071                 :            :                         } 
    4072         [ -  + ]:         22 :                 if ((ctx->srp_ctx.login = BUF_strdup((char *)parg)) == NULL)
    4073                 :            :                         {
    4074                 :          0 :                         SSLerr(SSL_F_SSL3_CTX_CTRL, ERR_R_INTERNAL_ERROR);
    4075                 :          0 :                         return 0;
    4076                 :            :                         }
    4077                 :            :                 break;
    4078                 :            :         case SSL_CTRL_SET_TLS_EXT_SRP_PASSWORD:
    4079                 :          0 :                 ctx->srp_ctx.SRP_give_srp_client_pwd_callback=srp_password_from_info_cb;
    4080                 :          0 :                 ctx->srp_ctx.info=parg;
    4081                 :          0 :                 break;
    4082                 :            :         case SSL_CTRL_SET_SRP_ARG:
    4083                 :         44 :                 ctx->srp_ctx.srp_Mask|=SSL_kSRP;
    4084                 :         44 :                 ctx->srp_ctx.SRP_cb_arg=parg;
    4085                 :         44 :                 break;
    4086                 :            : 
    4087                 :            :         case SSL_CTRL_SET_TLS_EXT_SRP_STRENGTH:
    4088                 :          0 :                 ctx->srp_ctx.strength=larg;
    4089                 :          0 :                 break;
    4090                 :            : #endif
    4091                 :            : 
    4092                 :            : #ifndef OPENSSL_NO_EC
    4093                 :            :         case SSL_CTRL_SET_CURVES:
    4094                 :          0 :                 return tls1_set_curves(&ctx->tlsext_ellipticcurvelist,
    4095                 :            :                                         &ctx->tlsext_ellipticcurvelist_length,
    4096                 :            :                                                                 parg, larg);
    4097                 :            : 
    4098                 :            :         case SSL_CTRL_SET_CURVES_LIST:
    4099                 :          0 :                 return tls1_set_curves_list(&ctx->tlsext_ellipticcurvelist,
    4100                 :            :                                         &ctx->tlsext_ellipticcurvelist_length,
    4101                 :            :                                                                 parg);
    4102                 :            :         case SSL_CTRL_SET_ECDH_AUTO:
    4103                 :          0 :                 ctx->cert->ecdh_tmp_auto = larg;
    4104                 :          0 :                 return 1;
    4105                 :            : #endif
    4106                 :            :         case SSL_CTRL_SET_SIGALGS:
    4107                 :          0 :                 return tls1_set_sigalgs(ctx->cert, parg, larg, 0);
    4108                 :            : 
    4109                 :            :         case SSL_CTRL_SET_SIGALGS_LIST:
    4110                 :          0 :                 return tls1_set_sigalgs_list(ctx->cert, parg, 0);
    4111                 :            : 
    4112                 :            :         case SSL_CTRL_SET_CLIENT_SIGALGS:
    4113                 :          0 :                 return tls1_set_sigalgs(ctx->cert, parg, larg, 1);
    4114                 :            : 
    4115                 :            :         case SSL_CTRL_SET_CLIENT_SIGALGS_LIST:
    4116                 :          0 :                 return tls1_set_sigalgs_list(ctx->cert, parg, 1);
    4117                 :            : 
    4118                 :            :         case SSL_CTRL_SET_CLIENT_CERT_TYPES:
    4119                 :          0 :                 return ssl3_set_req_cert_type(ctx->cert, parg, larg);
    4120                 :            : 
    4121                 :            :         case SSL_CTRL_BUILD_CERT_CHAIN:
    4122                 :          0 :                 return ssl_build_cert_chain(NULL, ctx, larg);
    4123                 :            : 
    4124                 :            :         case SSL_CTRL_SET_VERIFY_CERT_STORE:
    4125                 :          0 :                 return ssl_cert_set_cert_store(ctx->cert, parg, 0, larg);
    4126                 :            : 
    4127                 :            :         case SSL_CTRL_SET_CHAIN_CERT_STORE:
    4128                 :          0 :                 return ssl_cert_set_cert_store(ctx->cert, parg, 1, larg);
    4129                 :            : 
    4130                 :            : #endif /* !OPENSSL_NO_TLSEXT */
    4131                 :            : 
    4132                 :            :         /* A Thawte special :-) */
    4133                 :            :         case SSL_CTRL_EXTRA_CHAIN_CERT:
    4134         [ #  # ]:          0 :                 if (ctx->extra_certs == NULL)
    4135                 :            :                         {
    4136         [ #  # ]:          0 :                         if ((ctx->extra_certs=sk_X509_new_null()) == NULL)
    4137                 :            :                                 return(0);
    4138                 :            :                         }
    4139                 :          0 :                 sk_X509_push(ctx->extra_certs,(X509 *)parg);
    4140                 :          0 :                 break;
    4141                 :            : 
    4142                 :            :         case SSL_CTRL_GET_EXTRA_CHAIN_CERTS:
    4143 [ #  # ][ #  # ]:          0 :                 if (ctx->extra_certs == NULL && larg == 0)
    4144                 :          0 :                         *(STACK_OF(X509) **)parg =  ctx->cert->key->chain;
    4145                 :            :                 else
    4146                 :          0 :                         *(STACK_OF(X509) **)parg =  ctx->extra_certs;
    4147                 :            :                 break;
    4148                 :            : 
    4149                 :            :         case SSL_CTRL_CLEAR_EXTRA_CHAIN_CERTS:
    4150         [ #  # ]:          0 :                 if (ctx->extra_certs)
    4151                 :            :                         {
    4152                 :          0 :                         sk_X509_pop_free(ctx->extra_certs, X509_free);
    4153                 :          0 :                         ctx->extra_certs = NULL;
    4154                 :            :                         }
    4155                 :            :                 break;
    4156                 :            : 
    4157                 :            :         case SSL_CTRL_CHAIN:
    4158         [ #  # ]:          0 :                 if (larg)
    4159                 :          0 :                         return ssl_cert_set1_chain(NULL, ctx,
    4160                 :            :                                                 (STACK_OF (X509) *)parg);
    4161                 :            :                 else
    4162                 :          0 :                         return ssl_cert_set0_chain(NULL, ctx,
    4163                 :            :                                                 (STACK_OF (X509) *)parg);
    4164                 :            : 
    4165                 :            :         case SSL_CTRL_CHAIN_CERT:
    4166         [ #  # ]:          0 :                 if (larg)
    4167                 :          0 :                         return ssl_cert_add1_chain_cert(NULL, ctx, (X509 *)parg);
    4168                 :            :                 else
    4169                 :          0 :                         return ssl_cert_add0_chain_cert(NULL, ctx, (X509 *)parg);
    4170                 :            : 
    4171                 :            :         case SSL_CTRL_GET_CHAIN_CERTS:
    4172                 :          0 :                 *(STACK_OF(X509) **)parg = ctx->cert->key->chain;
    4173                 :          0 :                 break;
    4174                 :            : 
    4175                 :            :         case SSL_CTRL_SELECT_CURRENT_CERT:
    4176                 :          0 :                 return ssl_cert_select_current(ctx->cert, (X509 *)parg);
    4177                 :            : 
    4178                 :            :         case SSL_CTRL_SET_CURRENT_CERT:
    4179                 :          0 :                 return ssl_cert_set_current(ctx->cert, larg);
    4180                 :            : 
    4181                 :            :         default:
    4182                 :            :                 return(0);
    4183                 :            :                 }
    4184                 :            :         return(1);
    4185                 :            :         }
    4186                 :            : 
    4187                 :        805 : long ssl3_ctx_callback_ctrl(SSL_CTX *ctx, int cmd, void (*fp)(void))
    4188                 :            :         {
    4189                 :            :         CERT *cert;
    4190                 :            : 
    4191                 :        805 :         cert=ctx->cert;
    4192                 :            : 
    4193   [ +  -  -  -  :        805 :         switch (cmd)
          -  -  -  +  +  
                   -  - ]
    4194                 :            :                 {
    4195                 :            : #ifndef OPENSSL_NO_RSA
    4196                 :            :         case SSL_CTRL_SET_TMP_RSA_CB:
    4197                 :            :                 {
    4198                 :        761 :                 cert->rsa_tmp_cb = (RSA *(*)(SSL *, int, int))fp;
    4199                 :            :                 }
    4200                 :        761 :                 break;
    4201                 :            : #endif
    4202                 :            : #ifndef OPENSSL_NO_DH
    4203                 :            :         case SSL_CTRL_SET_TMP_DH_CB:
    4204                 :            :                 {
    4205                 :          0 :                 cert->dh_tmp_cb = (DH *(*)(SSL *, int, int))fp;
    4206                 :            :                 }
    4207                 :          0 :                 break;
    4208                 :            : #endif
    4209                 :            : #ifndef OPENSSL_NO_ECDH
    4210                 :            :         case SSL_CTRL_SET_TMP_ECDH_CB:
    4211                 :            :                 {
    4212                 :          0 :                 cert->ecdh_tmp_cb = (EC_KEY *(*)(SSL *, int, int))fp;
    4213                 :            :                 }
    4214                 :          0 :                 break;
    4215                 :            : #endif
    4216                 :            : #ifndef OPENSSL_NO_TLSEXT
    4217                 :            :         case SSL_CTRL_SET_TLSEXT_SERVERNAME_CB:
    4218                 :          0 :                 ctx->tlsext_servername_callback=(int (*)(SSL *,int *,void *))fp;
    4219                 :          0 :                 break;
    4220                 :            : 
    4221                 :            : #ifdef TLSEXT_TYPE_opaque_prf_input
    4222                 :            :         case SSL_CTRL_SET_TLSEXT_OPAQUE_PRF_INPUT_CB:
    4223                 :            :                 ctx->tlsext_opaque_prf_input_callback = (int (*)(SSL *,void *, size_t, void *))fp;
    4224                 :            :                 break;
    4225                 :            : #endif
    4226                 :            : 
    4227                 :            :         case SSL_CTRL_SET_TLSEXT_STATUS_REQ_CB:
    4228                 :          0 :                 ctx->tlsext_status_cb=(int (*)(SSL *,void *))fp;
    4229                 :          0 :                 break;
    4230                 :            : 
    4231                 :            :         case SSL_CTRL_SET_TLSEXT_TICKET_KEY_CB:
    4232                 :          0 :                 ctx->tlsext_ticket_key_cb=(int (*)(SSL *,unsigned char  *,
    4233                 :            :                                                 unsigned char *,
    4234                 :            :                                                 EVP_CIPHER_CTX *,
    4235                 :            :                                                 HMAC_CTX *, int))fp;
    4236                 :          0 :                 break;
    4237                 :            : 
    4238                 :            : #ifndef OPENSSL_NO_SRP
    4239                 :            :         case SSL_CTRL_SET_SRP_VERIFY_PARAM_CB:
    4240                 :          0 :                 ctx->srp_ctx.srp_Mask|=SSL_kSRP;
    4241                 :          0 :                 ctx->srp_ctx.SRP_verify_param_callback=(int (*)(SSL *,void *))fp;
    4242                 :          0 :                 break;
    4243                 :            :         case SSL_CTRL_SET_TLS_EXT_SRP_USERNAME_CB:
    4244                 :         22 :                 ctx->srp_ctx.srp_Mask|=SSL_kSRP;
    4245                 :         22 :                 ctx->srp_ctx.TLS_ext_srp_username_callback=(int (*)(SSL *,int *,void *))fp;
    4246                 :         22 :                 break;
    4247                 :            :         case SSL_CTRL_SET_SRP_GIVE_CLIENT_PWD_CB:
    4248                 :         22 :                 ctx->srp_ctx.srp_Mask|=SSL_kSRP;
    4249                 :         22 :                 ctx->srp_ctx.SRP_give_srp_client_pwd_callback=(char *(*)(SSL *,void *))fp;
    4250                 :         22 :                 break;
    4251                 :            : #endif
    4252                 :            : #endif
    4253                 :            :         case SSL_CTRL_SET_NOT_RESUMABLE_SESS_CB:
    4254                 :            :                 {
    4255                 :          0 :                 ctx->not_resumable_session_cb = (int (*)(SSL *, int))fp;
    4256                 :            :                 }
    4257                 :          0 :                 break;
    4258                 :            :         default:
    4259                 :            :                 return(0);
    4260                 :            :                 }
    4261                 :            :         return(1);
    4262                 :            :         }
    4263                 :            : 
    4264                 :            : /* This function needs to check if the ciphers required are actually
    4265                 :            :  * available */
    4266                 :      56027 : const SSL_CIPHER *ssl3_get_cipher_by_char(const unsigned char *p)
    4267                 :            :         {
    4268                 :            :         SSL_CIPHER c;
    4269                 :            :         const SSL_CIPHER *cp;
    4270                 :            :         unsigned long id;
    4271                 :            : 
    4272                 :      56027 :         id=0x03000000L|((unsigned long)p[0]<<8L)|(unsigned long)p[1];
    4273                 :      56027 :         c.id=id;
    4274                 :      56027 :         cp = OBJ_bsearch_ssl_cipher_id(&c, ssl3_ciphers, SSL3_NUM_CIPHERS);
    4275                 :            : #ifdef DEBUG_PRINT_UNKNOWN_CIPHERSUITES
    4276                 :            : if (cp == NULL) fprintf(stderr, "Unknown cipher ID %x\n", (p[0] << 8) | p[1]);
    4277                 :            : #endif
    4278                 :      56027 :         return cp;
    4279                 :            :         }
    4280                 :            : 
    4281                 :      59256 : int ssl3_put_cipher_by_char(const SSL_CIPHER *c, unsigned char *p)
    4282                 :            :         {
    4283                 :            :         long l;
    4284                 :            : 
    4285         [ +  + ]:      59256 :         if (p != NULL)
    4286                 :            :                 {
    4287                 :      57096 :                 l=c->id;
    4288         [ +  - ]:      57096 :                 if ((l & 0xff000000) != 0x03000000) return(0);
    4289                 :      57096 :                 p[0]=((unsigned char)(l>> 8L))&0xFF;
    4290                 :      57096 :                 p[1]=((unsigned char)(l     ))&0xFF;
    4291                 :            :                 }
    4292                 :            :         return(2);
    4293                 :            :         }
    4294                 :            : 
    4295                 :       1069 : SSL_CIPHER *ssl3_choose_cipher(SSL *s, STACK_OF(SSL_CIPHER) *clnt,
    4296                 :            :              STACK_OF(SSL_CIPHER) *srvr)
    4297                 :            :         {
    4298                 :       1069 :         SSL_CIPHER *c,*ret=NULL;
    4299                 :            :         STACK_OF(SSL_CIPHER) *prio, *allow;
    4300                 :            :         int i,ii,ok;
    4301                 :            :         CERT *cert;
    4302                 :            :         unsigned long alg_k,alg_a,mask_k,mask_a,emask_k,emask_a;
    4303                 :            : 
    4304                 :            :         /* Let's see which ciphers we can support */
    4305                 :       1069 :         cert=s->cert;
    4306                 :            : 
    4307                 :            : #if 0
    4308                 :            :         /* Do not set the compare functions, because this may lead to a
    4309                 :            :          * reordering by "id". We want to keep the original ordering.
    4310                 :            :          * We may pay a price in performance during sk_SSL_CIPHER_find(),
    4311                 :            :          * but would have to pay with the price of sk_SSL_CIPHER_dup().
    4312                 :            :          */
    4313                 :            :         sk_SSL_CIPHER_set_cmp_func(srvr, ssl_cipher_ptr_id_cmp);
    4314                 :            :         sk_SSL_CIPHER_set_cmp_func(clnt, ssl_cipher_ptr_id_cmp);
    4315                 :            : #endif
    4316                 :            : 
    4317                 :            : #ifdef CIPHER_DEBUG
    4318                 :            :         printf("Server has %d from %p:\n", sk_SSL_CIPHER_num(srvr), (void *)srvr);
    4319                 :            :         for(i=0 ; i < sk_SSL_CIPHER_num(srvr) ; ++i)
    4320                 :            :                 {
    4321                 :            :                 c=sk_SSL_CIPHER_value(srvr,i);
    4322                 :            :                 printf("%p:%s\n",(void *)c,c->name);
    4323                 :            :                 }
    4324                 :            :         printf("Client sent %d from %p:\n", sk_SSL_CIPHER_num(clnt), (void *)clnt);
    4325                 :            :         for(i=0 ; i < sk_SSL_CIPHER_num(clnt) ; ++i)
    4326                 :            :             {
    4327                 :            :             c=sk_SSL_CIPHER_value(clnt,i);
    4328                 :            :             printf("%p:%s\n",(void *)c,c->name);
    4329                 :            :             }
    4330                 :            : #endif
    4331                 :            : 
    4332 [ +  - ][ +  - ]:       1069 :         if (s->options & SSL_OP_CIPHER_SERVER_PREFERENCE || tls1_suiteb(s))
    4333                 :            :                 {
    4334                 :            :                 prio = srvr;
    4335                 :            :                 allow = clnt;
    4336                 :            :                 }
    4337                 :            :         else
    4338                 :            :                 {
    4339                 :       1069 :                 prio = clnt;
    4340                 :       1069 :                 allow = srvr;
    4341                 :            :                 }
    4342                 :            : 
    4343                 :       1069 :         tls1_set_cert_validity(s);
    4344                 :            : 
    4345         [ +  - ]:       3566 :         for (i=0; i<sk_SSL_CIPHER_num(prio); i++)
    4346                 :            :                 {
    4347                 :       3566 :                 c=sk_SSL_CIPHER_value(prio,i);
    4348                 :            : 
    4349                 :            :                 /* Skip TLS v1.2 only ciphersuites if not supported */
    4350 [ +  + ][ -  + ]:       3566 :                 if ((c->algorithm_ssl & SSL_TLSV1_2) && 
    4351                 :        419 :                         !SSL_USE_TLS1_2_CIPHERS(s))
    4352                 :          0 :                         continue;
    4353                 :            : 
    4354                 :       3566 :                 ssl_set_cert_masks(cert,c);
    4355                 :       3566 :                 mask_k = cert->mask_k;
    4356                 :       3566 :                 mask_a = cert->mask_a;
    4357                 :       3566 :                 emask_k = cert->export_mask_k;
    4358                 :       3566 :                 emask_a = cert->export_mask_a;
    4359                 :            : #ifndef OPENSSL_NO_SRP
    4360                 :       3566 :                 mask_k=cert->mask_k | s->srp_ctx.srp_Mask;
    4361                 :       3566 :                 emask_k=cert->export_mask_k | s->srp_ctx.srp_Mask;
    4362                 :            : #endif
    4363                 :            :                         
    4364                 :            : #ifdef KSSL_DEBUG
    4365                 :            : /*              printf("ssl3_choose_cipher %d alg= %lx\n", i,c->algorithms);*/
    4366                 :            : #endif    /* KSSL_DEBUG */
    4367                 :            : 
    4368                 :       3566 :                 alg_k=c->algorithm_mkey;
    4369                 :       3566 :                 alg_a=c->algorithm_auth;
    4370                 :            : 
    4371                 :            : #ifndef OPENSSL_NO_KRB5
    4372                 :            :                 if (alg_k & SSL_kKRB5)
    4373                 :            :                         {
    4374                 :            :                         if ( !kssl_keytab_is_available(s->kssl_ctx) )
    4375                 :            :                             continue;
    4376                 :            :                         }
    4377                 :            : #endif /* OPENSSL_NO_KRB5 */
    4378                 :            : #ifndef OPENSSL_NO_PSK
    4379                 :            :                 /* with PSK there must be server callback set */
    4380 [ +  + ][ -  + ]:       3566 :                 if ((alg_k & SSL_kPSK) && s->psk_server_callback == NULL)
    4381                 :          0 :                         continue;
    4382                 :            : #endif /* OPENSSL_NO_PSK */
    4383                 :            : 
    4384         [ +  + ]:       3566 :                 if (SSL_C_IS_EXPORT(c))
    4385                 :            :                         {
    4386 [ +  - ][ -  + ]:         33 :                         ok = (alg_k & emask_k) && (alg_a & emask_a);
    4387                 :            : #ifdef CIPHER_DEBUG
    4388                 :            :                         printf("%d:[%08lX:%08lX:%08lX:%08lX]%p:%s (export)\n",ok,alg_k,alg_a,emask_k,emask_a,
    4389                 :            :                                (void *)c,c->name);
    4390                 :            : #endif
    4391                 :            :                         }
    4392                 :            :                 else
    4393                 :            :                         {
    4394 [ +  + ][ +  + ]:       3533 :                         ok = (alg_k & mask_k) && (alg_a & mask_a);
    4395                 :            : #ifdef CIPHER_DEBUG
    4396                 :            :                         printf("%d:[%08lX:%08lX:%08lX:%08lX]%p:%s\n",ok,alg_k,alg_a,mask_k,mask_a,(void *)c,
    4397                 :            :                                c->name);
    4398                 :            : #endif
    4399                 :            :                         }
    4400                 :            : 
    4401                 :            : #ifndef OPENSSL_NO_TLSEXT
    4402                 :            : #ifndef OPENSSL_NO_EC
    4403                 :            :                 /* if we are considering an ECC cipher suite that uses
    4404                 :            :                  * an ephemeral EC key check it */
    4405         [ +  + ]:       3566 :                 if (alg_k & SSL_kECDHE)
    4406 [ +  + ][ +  + ]:        924 :                         ok = ok && tls1_check_ec_tmp_key(s, c->id);
    4407                 :            : #endif /* OPENSSL_NO_EC */
    4408                 :            : #endif /* OPENSSL_NO_TLSEXT */
    4409                 :            : 
    4410         [ +  + ]:       3566 :                 if (!ok) continue;
    4411                 :       1069 :                 ii=sk_SSL_CIPHER_find(allow,c);
    4412         [ +  - ]:       1069 :                 if (ii >= 0)
    4413                 :            :                         {
    4414                 :            :                         /* Check security callback permits this cipher */
    4415         [ -  + ]:       1069 :                         if (!ssl_security(s, SSL_SECOP_CIPHER_SHARED,
    4416                 :            :                                                 c->strength_bits, 0, c))
    4417                 :          0 :                                 continue;
    4418                 :            : #if !defined(OPENSSL_NO_EC) && !defined(OPENSSL_NO_TLSEXT)
    4419 [ +  + ][ -  + ]:       1069 :                         if ((alg_k & SSL_kECDHE) && (alg_a & SSL_aECDSA) && s->s3->is_probably_safari)
                 [ #  # ]
    4420                 :            :                                 {
    4421         [ #  # ]:          0 :                                 if (!ret) ret=sk_SSL_CIPHER_value(allow,ii);
    4422                 :          0 :                                 continue;
    4423                 :            :                                 }
    4424                 :            : #endif
    4425                 :       1069 :                         ret=sk_SSL_CIPHER_value(allow,ii);
    4426                 :       1069 :                         break;
    4427                 :            :                         }
    4428                 :            :                 }
    4429                 :       1069 :         return(ret);
    4430                 :            :         }
    4431                 :            : 
    4432                 :         99 : int ssl3_get_req_cert_type(SSL *s, unsigned char *p)
    4433                 :            :         {
    4434                 :         99 :         int ret=0;
    4435                 :         99 :         int nostrict = 1;
    4436                 :         99 :         unsigned long alg_k, alg_a = 0;
    4437                 :            : 
    4438                 :            :         /* If we have custom certificate types set, use them */
    4439         [ -  + ]:         99 :         if (s->cert->ctypes)
    4440                 :            :                 {
    4441                 :          0 :                 memcpy(p, s->cert->ctypes, s->cert->ctype_num);
    4442                 :          0 :                 return (int)s->cert->ctype_num;
    4443                 :            :                 }
    4444                 :            :         /* Get mask of algorithms disabled by signature list */
    4445                 :         99 :         ssl_set_sig_mask(&alg_a, s, SSL_SECOP_SIGALG_MASK);
    4446         [ -  + ]:         99 :         if (s->cert->cert_flags & SSL_CERT_FLAGS_CHECK_TLS_STRICT)
    4447                 :          0 :                 nostrict = 0;
    4448                 :            : 
    4449                 :         99 :         alg_k = s->s3->tmp.new_cipher->algorithm_mkey;
    4450                 :            : 
    4451                 :            : #ifndef OPENSSL_NO_GOST
    4452         [ +  + ]:         99 :         if (s->version >= TLS1_VERSION)
    4453                 :            :                 {
    4454         [ -  + ]:         55 :                 if (alg_k & SSL_kGOST)
    4455                 :            :                         {
    4456                 :          0 :                         p[ret++]=TLS_CT_GOST94_SIGN;
    4457                 :          0 :                         p[ret++]=TLS_CT_GOST01_SIGN;
    4458                 :          0 :                         return(ret);
    4459                 :            :                         }
    4460                 :            :                 }
    4461                 :            : #endif
    4462                 :            : 
    4463                 :            : #ifndef OPENSSL_NO_DH
    4464         [ +  + ]:         99 :         if (alg_k & (SSL_kDHr|SSL_kDHE))
    4465                 :            :                 {
    4466                 :            : #  ifndef OPENSSL_NO_RSA
    4467                 :            :                 /* Since this refers to a certificate signed with an RSA
    4468                 :            :                  * algorithm, only check for rsa signing in strict mode.
    4469                 :            :                  */
    4470 [ -  + ][ #  # ]:         44 :                 if (nostrict || !(alg_a & SSL_aRSA))
    4471                 :         44 :                         p[ret++]=SSL3_CT_RSA_FIXED_DH;
    4472                 :            : #  endif
    4473                 :            : #  ifndef OPENSSL_NO_DSA
    4474 [ -  + ][ #  # ]:         44 :                 if (nostrict || !(alg_a & SSL_aDSS))
    4475                 :         44 :                         p[ret++]=SSL3_CT_DSS_FIXED_DH;
    4476                 :            : #  endif
    4477                 :            :                 }
    4478 [ +  + ][ +  - ]:         99 :         if ((s->version == SSL3_VERSION) &&
    4479                 :         44 :                 (alg_k & (SSL_kDHE|SSL_kDHd|SSL_kDHr)))
    4480                 :            :                 {
    4481                 :            : #  ifndef OPENSSL_NO_RSA
    4482                 :         44 :                 p[ret++]=SSL3_CT_RSA_EPHEMERAL_DH;
    4483                 :            : #  endif
    4484                 :            : #  ifndef OPENSSL_NO_DSA
    4485                 :         44 :                 p[ret++]=SSL3_CT_DSS_EPHEMERAL_DH;
    4486                 :            : #  endif
    4487                 :            :                 }
    4488                 :            : #endif /* !OPENSSL_NO_DH */
    4489                 :            : #ifndef OPENSSL_NO_RSA
    4490         [ +  - ]:         99 :         if (!(alg_a & SSL_aRSA))
    4491                 :         99 :                 p[ret++]=SSL3_CT_RSA_SIGN;
    4492                 :            : #endif
    4493                 :            : #ifndef OPENSSL_NO_DSA
    4494         [ +  - ]:         99 :         if (!(alg_a & SSL_aDSS))
    4495                 :         99 :                 p[ret++]=SSL3_CT_DSS_SIGN;
    4496                 :            : #endif
    4497                 :            : #ifndef OPENSSL_NO_ECDH
    4498 [ -  + ][ #  # ]:         99 :         if ((alg_k & (SSL_kECDHr|SSL_kECDHe)) && (s->version >= TLS1_VERSION))
    4499                 :            :                 {
    4500 [ #  # ][ #  # ]:          0 :                 if (nostrict || !(alg_a & SSL_aRSA))
    4501                 :          0 :                         p[ret++]=TLS_CT_RSA_FIXED_ECDH;
    4502 [ #  # ][ #  # ]:          0 :                 if (nostrict || !(alg_a & SSL_aECDSA))
    4503                 :          0 :                         p[ret++]=TLS_CT_ECDSA_FIXED_ECDH;
    4504                 :            :                 }
    4505                 :            : #endif
    4506                 :            : 
    4507                 :            : #ifndef OPENSSL_NO_ECDSA
    4508                 :            :         /* ECDSA certs can be used with RSA cipher suites as well 
    4509                 :            :          * so we don't need to check for SSL_kECDH or SSL_kECDHE
    4510                 :            :          */
    4511         [ +  + ]:         99 :         if (s->version >= TLS1_VERSION)
    4512                 :            :                 {
    4513         [ +  - ]:         55 :                 if (!(alg_a & SSL_aECDSA))
    4514                 :         55 :                         p[ret++]=TLS_CT_ECDSA_SIGN;
    4515                 :            :                 }
    4516                 :            : #endif  
    4517                 :         99 :         return(ret);
    4518                 :            :         }
    4519                 :            : 
    4520                 :          0 : static int ssl3_set_req_cert_type(CERT *c, const unsigned char *p, size_t len)
    4521                 :            :         {
    4522         [ #  # ]:          0 :         if (c->ctypes)
    4523                 :            :                 {
    4524                 :          0 :                 OPENSSL_free(c->ctypes);
    4525                 :          0 :                 c->ctypes = NULL;
    4526                 :            :                 }
    4527         [ #  # ]:          0 :         if (!p || !len)
    4528                 :            :                 return 1;
    4529         [ #  # ]:          0 :         if (len > 0xff)
    4530                 :            :                 return 0;
    4531                 :          0 :         c->ctypes = OPENSSL_malloc(len);
    4532         [ #  # ]:          0 :         if (!c->ctypes)
    4533                 :            :                 return 0;
    4534                 :          0 :         memcpy(c->ctypes, p, len);
    4535                 :          0 :         c->ctype_num = len;
    4536                 :            :         return 1;
    4537                 :            :         }
    4538                 :            : 
    4539                 :       2160 : int ssl3_shutdown(SSL *s)
    4540                 :            :         {
    4541                 :            :         int ret;
    4542                 :            : 
    4543                 :            :         /* Don't do anything much if we have not done the handshake or
    4544                 :            :          * we don't want to send messages :-) */
    4545 [ +  - ][ -  + ]:       2160 :         if ((s->quiet_shutdown) || (s->state == SSL_ST_BEFORE))
    4546                 :            :                 {
    4547                 :          0 :                 s->shutdown=(SSL_SENT_SHUTDOWN|SSL_RECEIVED_SHUTDOWN);
    4548                 :          0 :                 return(1);
    4549                 :            :                 }
    4550                 :            : 
    4551         [ +  - ]:       2160 :         if (!(s->shutdown & SSL_SENT_SHUTDOWN))
    4552                 :            :                 {
    4553                 :       2160 :                 s->shutdown|=SSL_SENT_SHUTDOWN;
    4554                 :            : #if 1
    4555                 :       2160 :                 ssl3_send_alert(s,SSL3_AL_WARNING,SSL_AD_CLOSE_NOTIFY);
    4556                 :            : #endif
    4557                 :            :                 /* our shutdown alert has been sent now, and if it still needs
    4558                 :            :                  * to be written, s->s3->alert_dispatch will be true */
    4559         [ -  + ]:       2160 :                 if (s->s3->alert_dispatch)
    4560                 :            :                         return(-1);     /* return WANT_WRITE */
    4561                 :            :                 }
    4562         [ #  # ]:          0 :         else if (s->s3->alert_dispatch)
    4563                 :            :                 {
    4564                 :            :                 /* resend it if not sent */
    4565                 :            : #if 1
    4566                 :          0 :                 ret=s->method->ssl_dispatch_alert(s);
    4567         [ #  # ]:          0 :                 if(ret == -1)
    4568                 :            :                         {
    4569                 :            :                         /* we only get to return -1 here the 2nd/Nth
    4570                 :            :                          * invocation, we must  have already signalled
    4571                 :            :                          * return 0 upon a previous invoation,
    4572                 :            :                          * return WANT_WRITE */
    4573                 :            :                         return(ret);
    4574                 :            :                         }
    4575                 :            : #endif
    4576                 :            :                 }
    4577         [ #  # ]:          0 :         else if (!(s->shutdown & SSL_RECEIVED_SHUTDOWN))
    4578                 :            :                 {
    4579                 :            :                 /* If we are waiting for a close from our peer, we are closed */
    4580                 :          0 :                 s->method->ssl_read_bytes(s,0,NULL,0,0);
    4581         [ #  # ]:          0 :                 if(!(s->shutdown & SSL_RECEIVED_SHUTDOWN))
    4582                 :            :                         {
    4583                 :            :                         return(-1);     /* return WANT_READ */
    4584                 :            :                         }
    4585                 :            :                 }
    4586                 :            : 
    4587 [ #  # ][ #  # ]:          0 :         if ((s->shutdown == (SSL_SENT_SHUTDOWN|SSL_RECEIVED_SHUTDOWN)) &&
    4588                 :          0 :                 !s->s3->alert_dispatch)
    4589                 :            :                 return(1);
    4590                 :            :         else
    4591                 :          0 :                 return(0);
    4592                 :            :         }
    4593                 :            : 
    4594                 :      42191 : int ssl3_write(SSL *s, const void *buf, int len)
    4595                 :            :         {
    4596                 :            :         int ret,n;
    4597                 :            : 
    4598                 :            : #if 0
    4599                 :            :         if (s->shutdown & SSL_SEND_SHUTDOWN)
    4600                 :            :                 {
    4601                 :            :                 s->rwstate=SSL_NOTHING;
    4602                 :            :                 return(0);
    4603                 :            :                 }
    4604                 :            : #endif
    4605                 :      42191 :         clear_sys_error();
    4606         [ -  + ]:      42191 :         if (s->s3->renegotiate) ssl3_renegotiate_check(s);
    4607                 :            : 
    4608                 :            :         /* This is an experimental flag that sends the
    4609                 :            :          * last handshake message in the same packet as the first
    4610                 :            :          * use data - used to see if it helps the TCP protocol during
    4611                 :            :          * session-id reuse */
    4612                 :            :         /* The second test is because the buffer may have been removed */
    4613 [ -  + ][ #  # ]:      42191 :         if ((s->s3->flags & SSL3_FLAGS_POP_BUFFER) && (s->wbio == s->bbio))
    4614                 :            :                 {
    4615                 :            :                 /* First time through, we write into the buffer */
    4616         [ #  # ]:          0 :                 if (s->s3->delay_buf_pop_ret == 0)
    4617                 :            :                         {
    4618                 :          0 :                         ret=ssl3_write_bytes(s,SSL3_RT_APPLICATION_DATA,
    4619                 :            :                                              buf,len);
    4620         [ #  # ]:          0 :                         if (ret <= 0) return(ret);
    4621                 :            : 
    4622                 :          0 :                         s->s3->delay_buf_pop_ret=ret;
    4623                 :            :                         }
    4624                 :            : 
    4625                 :          0 :                 s->rwstate=SSL_WRITING;
    4626                 :          0 :                 n=BIO_flush(s->wbio);
    4627         [ #  # ]:          0 :                 if (n <= 0) return(n);
    4628                 :          0 :                 s->rwstate=SSL_NOTHING;
    4629                 :            : 
    4630                 :            :                 /* We have flushed the buffer, so remove it */
    4631                 :          0 :                 ssl_free_wbio_buffer(s);
    4632                 :          0 :                 s->s3->flags&= ~SSL3_FLAGS_POP_BUFFER;
    4633                 :            : 
    4634                 :          0 :                 ret=s->s3->delay_buf_pop_ret;
    4635                 :          0 :                 s->s3->delay_buf_pop_ret=0;
    4636                 :            :                 }
    4637                 :            :         else
    4638                 :            :                 {
    4639                 :      42191 :                 ret=s->method->ssl_write_bytes(s,SSL3_RT_APPLICATION_DATA,
    4640                 :            :                         buf,len);
    4641         [ +  + ]:      42191 :                 if (ret <= 0) return(ret);
    4642                 :            :                 }
    4643                 :            : 
    4644                 :       2976 :         return(ret);
    4645                 :            :         }
    4646                 :            : 
    4647                 :      52576 : static int ssl3_read_internal(SSL *s, void *buf, int len, int peek)
    4648                 :            :         {
    4649                 :            :         int ret;
    4650                 :            :         
    4651                 :      52576 :         clear_sys_error();
    4652         [ -  + ]:      52576 :         if (s->s3->renegotiate) ssl3_renegotiate_check(s);
    4653                 :      52576 :         s->s3->in_read_app_data=1;
    4654                 :      52576 :         ret=s->method->ssl_read_bytes(s,SSL3_RT_APPLICATION_DATA,buf,len,peek);
    4655 [ +  + ][ -  + ]:      52576 :         if ((ret == -1) && (s->s3->in_read_app_data == 2))
    4656                 :            :                 {
    4657                 :            :                 /* ssl3_read_bytes decided to call s->handshake_func, which
    4658                 :            :                  * called ssl3_read_bytes to read handshake data.
    4659                 :            :                  * However, ssl3_read_bytes actually found application data
    4660                 :            :                  * and thinks that application data makes sense here; so disable
    4661                 :            :                  * handshake processing and try to read application data again. */
    4662                 :          0 :                 s->in_handshake++;
    4663                 :          0 :                 ret=s->method->ssl_read_bytes(s,SSL3_RT_APPLICATION_DATA,buf,len,peek);
    4664                 :          0 :                 s->in_handshake--;
    4665                 :            :                 }
    4666                 :            :         else
    4667                 :      52576 :                 s->s3->in_read_app_data=0;
    4668                 :            : 
    4669                 :      52576 :         return(ret);
    4670                 :            :         }
    4671                 :            : 
    4672                 :      52576 : int ssl3_read(SSL *s, void *buf, int len)
    4673                 :            :         {
    4674                 :      52576 :         return ssl3_read_internal(s, buf, len, 0);
    4675                 :            :         }
    4676                 :            : 
    4677                 :          0 : int ssl3_peek(SSL *s, void *buf, int len)
    4678                 :            :         {
    4679                 :          0 :         return ssl3_read_internal(s, buf, len, 1);
    4680                 :            :         }
    4681                 :            : 
    4682                 :          0 : int ssl3_renegotiate(SSL *s)
    4683                 :            :         {
    4684         [ #  # ]:          0 :         if (s->handshake_func == NULL)
    4685                 :            :                 return(1);
    4686                 :            : 
    4687         [ #  # ]:          0 :         if (s->s3->flags & SSL3_FLAGS_NO_RENEGOTIATE_CIPHERS)
    4688                 :            :                 return(0);
    4689                 :            : 
    4690                 :          0 :         s->s3->renegotiate=1;
    4691                 :          0 :         return(1);
    4692                 :            :         }
    4693                 :            : 
    4694                 :          0 : int ssl3_renegotiate_check(SSL *s)
    4695                 :            :         {
    4696                 :          0 :         int ret=0;
    4697                 :            : 
    4698         [ #  # ]:          0 :         if (s->s3->renegotiate)
    4699                 :            :                 {
    4700 [ #  # ][ #  # ]:          0 :                 if (    (s->s3->rbuf.left == 0) &&
    4701         [ #  # ]:          0 :                         (s->s3->wbuf.left == 0) &&
    4702                 :          0 :                         !SSL_in_init(s))
    4703                 :            :                         {
    4704                 :            : /*
    4705                 :            : if we are the server, and we have sent a 'RENEGOTIATE' message, we
    4706                 :            : need to go to SSL_ST_ACCEPT.
    4707                 :            : */
    4708                 :            :                         /* SSL_ST_ACCEPT */
    4709                 :          0 :                         s->state=SSL_ST_RENEGOTIATE;
    4710                 :          0 :                         s->s3->renegotiate=0;
    4711                 :          0 :                         s->s3->num_renegotiations++;
    4712                 :          0 :                         s->s3->total_renegotiations++;
    4713                 :          0 :                         ret=1;
    4714                 :            :                         }
    4715                 :            :                 }
    4716                 :          0 :         return(ret);
    4717                 :            :         }
    4718                 :            : /* If we are using default SHA1+MD5 algorithms switch to new SHA256 PRF
    4719                 :            :  * and handshake macs if required.
    4720                 :            :  */
    4721                 :      50980 : long ssl_get_algorithm2(SSL *s)
    4722                 :            :         {
    4723                 :      50980 :         long alg2 = s->s3->tmp.new_cipher->algorithm2;
    4724         [ +  + ]:      50980 :         if (s->method->ssl3_enc->enc_flags & SSL_ENC_FLAG_SHA256_PRF
    4725         [ +  + ]:      11600 :             && alg2 == (SSL_HANDSHAKE_MAC_DEFAULT|TLS1_PRF))
    4726                 :            :                 return SSL_HANDSHAKE_MAC_SHA256 | TLS1_PRF_SHA256;
    4727                 :      48950 :         return alg2;
    4728                 :            :         }
    4729                 :            : 

Generated by: LCOV version 1.9