ssl_err.c 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497
  1. /* ssl/ssl_err.c */
  2. /* ====================================================================
  3. * Copyright (c) 1999-2005 The OpenSSL Project. All rights reserved.
  4. *
  5. * Redistribution and use in source and binary forms, with or without
  6. * modification, are permitted provided that the following conditions
  7. * are met:
  8. *
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. *
  12. * 2. Redistributions in binary form must reproduce the above copyright
  13. * notice, this list of conditions and the following disclaimer in
  14. * the documentation and/or other materials provided with the
  15. * distribution.
  16. *
  17. * 3. All advertising materials mentioning features or use of this
  18. * software must display the following acknowledgment:
  19. * "This product includes software developed by the OpenSSL Project
  20. * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
  21. *
  22. * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
  23. * endorse or promote products derived from this software without
  24. * prior written permission. For written permission, please contact
  25. * openssl-core@OpenSSL.org.
  26. *
  27. * 5. Products derived from this software may not be called "OpenSSL"
  28. * nor may "OpenSSL" appear in their names without prior written
  29. * permission of the OpenSSL Project.
  30. *
  31. * 6. Redistributions of any form whatsoever must retain the following
  32. * acknowledgment:
  33. * "This product includes software developed by the OpenSSL Project
  34. * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
  35. *
  36. * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
  37. * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  38. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  39. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
  40. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  41. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  42. * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
  43. * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  44. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  45. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  46. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
  47. * OF THE POSSIBILITY OF SUCH DAMAGE.
  48. * ====================================================================
  49. *
  50. * This product includes cryptographic software written by Eric Young
  51. * (eay@cryptsoft.com). This product includes software written by Tim
  52. * Hudson (tjh@cryptsoft.com).
  53. *
  54. */
  55. /* NOTE: this file was auto generated by the mkerr.pl script: any changes
  56. * made to it will be overwritten when the script next updates this file,
  57. * only reason strings will be preserved.
  58. */
  59. #include <stdio.h>
  60. #include <openssl/err.h>
  61. #include <openssl/ssl.h>
  62. /* BEGIN ERROR CODES */
  63. #ifndef OPENSSL_NO_ERR
  64. #define ERR_FUNC(func) ERR_PACK(ERR_LIB_SSL,func,0)
  65. #define ERR_REASON(reason) ERR_PACK(ERR_LIB_SSL,0,reason)
  66. static ERR_STRING_DATA SSL_str_functs[]=
  67. {
  68. {ERR_FUNC(SSL_F_CLIENT_CERTIFICATE), "CLIENT_CERTIFICATE"},
  69. {ERR_FUNC(SSL_F_CLIENT_FINISHED), "CLIENT_FINISHED"},
  70. {ERR_FUNC(SSL_F_CLIENT_HELLO), "CLIENT_HELLO"},
  71. {ERR_FUNC(SSL_F_CLIENT_MASTER_KEY), "CLIENT_MASTER_KEY"},
  72. {ERR_FUNC(SSL_F_D2I_SSL_SESSION), "d2i_SSL_SESSION"},
  73. {ERR_FUNC(SSL_F_DO_DTLS1_WRITE), "DO_DTLS1_WRITE"},
  74. {ERR_FUNC(SSL_F_DO_SSL3_WRITE), "DO_SSL3_WRITE"},
  75. {ERR_FUNC(SSL_F_DTLS1_ACCEPT), "DTLS1_ACCEPT"},
  76. {ERR_FUNC(SSL_F_DTLS1_BUFFER_RECORD), "DTLS1_BUFFER_RECORD"},
  77. {ERR_FUNC(SSL_F_DTLS1_CLIENT_HELLO), "DTLS1_CLIENT_HELLO"},
  78. {ERR_FUNC(SSL_F_DTLS1_CONNECT), "DTLS1_CONNECT"},
  79. {ERR_FUNC(SSL_F_DTLS1_ENC), "DTLS1_ENC"},
  80. {ERR_FUNC(SSL_F_DTLS1_GET_HELLO_VERIFY), "DTLS1_GET_HELLO_VERIFY"},
  81. {ERR_FUNC(SSL_F_DTLS1_GET_MESSAGE), "DTLS1_GET_MESSAGE"},
  82. {ERR_FUNC(SSL_F_DTLS1_GET_MESSAGE_FRAGMENT), "DTLS1_GET_MESSAGE_FRAGMENT"},
  83. {ERR_FUNC(SSL_F_DTLS1_GET_RECORD), "DTLS1_GET_RECORD"},
  84. {ERR_FUNC(SSL_F_DTLS1_OUTPUT_CERT_CHAIN), "DTLS1_OUTPUT_CERT_CHAIN"},
  85. {ERR_FUNC(SSL_F_DTLS1_PROCESS_OUT_OF_SEQ_MESSAGE), "DTLS1_PROCESS_OUT_OF_SEQ_MESSAGE"},
  86. {ERR_FUNC(SSL_F_DTLS1_PROCESS_RECORD), "DTLS1_PROCESS_RECORD"},
  87. {ERR_FUNC(SSL_F_DTLS1_READ_BYTES), "DTLS1_READ_BYTES"},
  88. {ERR_FUNC(SSL_F_DTLS1_READ_FAILED), "DTLS1_READ_FAILED"},
  89. {ERR_FUNC(SSL_F_DTLS1_SEND_CERTIFICATE_REQUEST), "DTLS1_SEND_CERTIFICATE_REQUEST"},
  90. {ERR_FUNC(SSL_F_DTLS1_SEND_CLIENT_CERTIFICATE), "DTLS1_SEND_CLIENT_CERTIFICATE"},
  91. {ERR_FUNC(SSL_F_DTLS1_SEND_CLIENT_KEY_EXCHANGE), "DTLS1_SEND_CLIENT_KEY_EXCHANGE"},
  92. {ERR_FUNC(SSL_F_DTLS1_SEND_CLIENT_VERIFY), "DTLS1_SEND_CLIENT_VERIFY"},
  93. {ERR_FUNC(SSL_F_DTLS1_SEND_HELLO_VERIFY_REQUEST), "DTLS1_SEND_HELLO_VERIFY_REQUEST"},
  94. {ERR_FUNC(SSL_F_DTLS1_SEND_SERVER_CERTIFICATE), "DTLS1_SEND_SERVER_CERTIFICATE"},
  95. {ERR_FUNC(SSL_F_DTLS1_SEND_SERVER_HELLO), "DTLS1_SEND_SERVER_HELLO"},
  96. {ERR_FUNC(SSL_F_DTLS1_SEND_SERVER_KEY_EXCHANGE), "DTLS1_SEND_SERVER_KEY_EXCHANGE"},
  97. {ERR_FUNC(SSL_F_DTLS1_WRITE_APP_DATA_BYTES), "DTLS1_WRITE_APP_DATA_BYTES"},
  98. {ERR_FUNC(SSL_F_GET_CLIENT_FINISHED), "GET_CLIENT_FINISHED"},
  99. {ERR_FUNC(SSL_F_GET_CLIENT_HELLO), "GET_CLIENT_HELLO"},
  100. {ERR_FUNC(SSL_F_GET_CLIENT_MASTER_KEY), "GET_CLIENT_MASTER_KEY"},
  101. {ERR_FUNC(SSL_F_GET_SERVER_FINISHED), "GET_SERVER_FINISHED"},
  102. {ERR_FUNC(SSL_F_GET_SERVER_HELLO), "GET_SERVER_HELLO"},
  103. {ERR_FUNC(SSL_F_GET_SERVER_VERIFY), "GET_SERVER_VERIFY"},
  104. {ERR_FUNC(SSL_F_I2D_SSL_SESSION), "i2d_SSL_SESSION"},
  105. {ERR_FUNC(SSL_F_READ_N), "READ_N"},
  106. {ERR_FUNC(SSL_F_REQUEST_CERTIFICATE), "REQUEST_CERTIFICATE"},
  107. {ERR_FUNC(SSL_F_SERVER_FINISH), "SERVER_FINISH"},
  108. {ERR_FUNC(SSL_F_SERVER_HELLO), "SERVER_HELLO"},
  109. {ERR_FUNC(SSL_F_SERVER_VERIFY), "SERVER_VERIFY"},
  110. {ERR_FUNC(SSL_F_SSL23_ACCEPT), "SSL23_ACCEPT"},
  111. {ERR_FUNC(SSL_F_SSL23_CLIENT_HELLO), "SSL23_CLIENT_HELLO"},
  112. {ERR_FUNC(SSL_F_SSL23_CONNECT), "SSL23_CONNECT"},
  113. {ERR_FUNC(SSL_F_SSL23_GET_CLIENT_HELLO), "SSL23_GET_CLIENT_HELLO"},
  114. {ERR_FUNC(SSL_F_SSL23_GET_SERVER_HELLO), "SSL23_GET_SERVER_HELLO"},
  115. {ERR_FUNC(SSL_F_SSL23_PEEK), "SSL23_PEEK"},
  116. {ERR_FUNC(SSL_F_SSL23_READ), "SSL23_READ"},
  117. {ERR_FUNC(SSL_F_SSL23_WRITE), "SSL23_WRITE"},
  118. {ERR_FUNC(SSL_F_SSL2_ACCEPT), "SSL2_ACCEPT"},
  119. {ERR_FUNC(SSL_F_SSL2_CONNECT), "SSL2_CONNECT"},
  120. {ERR_FUNC(SSL_F_SSL2_ENC_INIT), "SSL2_ENC_INIT"},
  121. {ERR_FUNC(SSL_F_SSL2_GENERATE_KEY_MATERIAL), "SSL2_GENERATE_KEY_MATERIAL"},
  122. {ERR_FUNC(SSL_F_SSL2_PEEK), "SSL2_PEEK"},
  123. {ERR_FUNC(SSL_F_SSL2_READ), "SSL2_READ"},
  124. {ERR_FUNC(SSL_F_SSL2_READ_INTERNAL), "SSL2_READ_INTERNAL"},
  125. {ERR_FUNC(SSL_F_SSL2_SET_CERTIFICATE), "SSL2_SET_CERTIFICATE"},
  126. {ERR_FUNC(SSL_F_SSL2_WRITE), "SSL2_WRITE"},
  127. {ERR_FUNC(SSL_F_SSL3_ACCEPT), "SSL3_ACCEPT"},
  128. {ERR_FUNC(SSL_F_SSL3_CALLBACK_CTRL), "SSL3_CALLBACK_CTRL"},
  129. {ERR_FUNC(SSL_F_SSL3_CHANGE_CIPHER_STATE), "SSL3_CHANGE_CIPHER_STATE"},
  130. {ERR_FUNC(SSL_F_SSL3_CHECK_CERT_AND_ALGORITHM), "SSL3_CHECK_CERT_AND_ALGORITHM"},
  131. {ERR_FUNC(SSL_F_SSL3_CLIENT_HELLO), "SSL3_CLIENT_HELLO"},
  132. {ERR_FUNC(SSL_F_SSL3_CONNECT), "SSL3_CONNECT"},
  133. {ERR_FUNC(SSL_F_SSL3_CTRL), "SSL3_CTRL"},
  134. {ERR_FUNC(SSL_F_SSL3_CTX_CTRL), "SSL3_CTX_CTRL"},
  135. {ERR_FUNC(SSL_F_SSL3_ENC), "SSL3_ENC"},
  136. {ERR_FUNC(SSL_F_SSL3_GENERATE_KEY_BLOCK), "SSL3_GENERATE_KEY_BLOCK"},
  137. {ERR_FUNC(SSL_F_SSL3_GET_CERTIFICATE_REQUEST), "SSL3_GET_CERTIFICATE_REQUEST"},
  138. {ERR_FUNC(SSL_F_SSL3_GET_CERT_VERIFY), "SSL3_GET_CERT_VERIFY"},
  139. {ERR_FUNC(SSL_F_SSL3_GET_CLIENT_CERTIFICATE), "SSL3_GET_CLIENT_CERTIFICATE"},
  140. {ERR_FUNC(SSL_F_SSL3_GET_CLIENT_HELLO), "SSL3_GET_CLIENT_HELLO"},
  141. {ERR_FUNC(SSL_F_SSL3_GET_CLIENT_KEY_EXCHANGE), "SSL3_GET_CLIENT_KEY_EXCHANGE"},
  142. {ERR_FUNC(SSL_F_SSL3_GET_FINISHED), "SSL3_GET_FINISHED"},
  143. {ERR_FUNC(SSL_F_SSL3_GET_KEY_EXCHANGE), "SSL3_GET_KEY_EXCHANGE"},
  144. {ERR_FUNC(SSL_F_SSL3_GET_MESSAGE), "SSL3_GET_MESSAGE"},
  145. {ERR_FUNC(SSL_F_SSL3_GET_RECORD), "SSL3_GET_RECORD"},
  146. {ERR_FUNC(SSL_F_SSL3_GET_SERVER_CERTIFICATE), "SSL3_GET_SERVER_CERTIFICATE"},
  147. {ERR_FUNC(SSL_F_SSL3_GET_SERVER_DONE), "SSL3_GET_SERVER_DONE"},
  148. {ERR_FUNC(SSL_F_SSL3_GET_SERVER_HELLO), "SSL3_GET_SERVER_HELLO"},
  149. {ERR_FUNC(SSL_F_SSL3_OUTPUT_CERT_CHAIN), "SSL3_OUTPUT_CERT_CHAIN"},
  150. {ERR_FUNC(SSL_F_SSL3_PEEK), "SSL3_PEEK"},
  151. {ERR_FUNC(SSL_F_SSL3_READ_BYTES), "SSL3_READ_BYTES"},
  152. {ERR_FUNC(SSL_F_SSL3_READ_N), "SSL3_READ_N"},
  153. {ERR_FUNC(SSL_F_SSL3_SEND_CERTIFICATE_REQUEST), "SSL3_SEND_CERTIFICATE_REQUEST"},
  154. {ERR_FUNC(SSL_F_SSL3_SEND_CLIENT_CERTIFICATE), "SSL3_SEND_CLIENT_CERTIFICATE"},
  155. {ERR_FUNC(SSL_F_SSL3_SEND_CLIENT_KEY_EXCHANGE), "SSL3_SEND_CLIENT_KEY_EXCHANGE"},
  156. {ERR_FUNC(SSL_F_SSL3_SEND_CLIENT_VERIFY), "SSL3_SEND_CLIENT_VERIFY"},
  157. {ERR_FUNC(SSL_F_SSL3_SEND_SERVER_CERTIFICATE), "SSL3_SEND_SERVER_CERTIFICATE"},
  158. {ERR_FUNC(SSL_F_SSL3_SEND_SERVER_HELLO), "SSL3_SEND_SERVER_HELLO"},
  159. {ERR_FUNC(SSL_F_SSL3_SEND_SERVER_KEY_EXCHANGE), "SSL3_SEND_SERVER_KEY_EXCHANGE"},
  160. {ERR_FUNC(SSL_F_SSL3_SETUP_BUFFERS), "SSL3_SETUP_BUFFERS"},
  161. {ERR_FUNC(SSL_F_SSL3_SETUP_KEY_BLOCK), "SSL3_SETUP_KEY_BLOCK"},
  162. {ERR_FUNC(SSL_F_SSL3_WRITE_BYTES), "SSL3_WRITE_BYTES"},
  163. {ERR_FUNC(SSL_F_SSL3_WRITE_PENDING), "SSL3_WRITE_PENDING"},
  164. {ERR_FUNC(SSL_F_SSL_ADD_DIR_CERT_SUBJECTS_TO_STACK), "SSL_add_dir_cert_subjects_to_stack"},
  165. {ERR_FUNC(SSL_F_SSL_ADD_FILE_CERT_SUBJECTS_TO_STACK), "SSL_add_file_cert_subjects_to_stack"},
  166. {ERR_FUNC(SSL_F_SSL_BAD_METHOD), "SSL_BAD_METHOD"},
  167. {ERR_FUNC(SSL_F_SSL_BYTES_TO_CIPHER_LIST), "SSL_BYTES_TO_CIPHER_LIST"},
  168. {ERR_FUNC(SSL_F_SSL_CERT_DUP), "SSL_CERT_DUP"},
  169. {ERR_FUNC(SSL_F_SSL_CERT_INST), "SSL_CERT_INST"},
  170. {ERR_FUNC(SSL_F_SSL_CERT_INSTANTIATE), "SSL_CERT_INSTANTIATE"},
  171. {ERR_FUNC(SSL_F_SSL_CERT_NEW), "SSL_CERT_NEW"},
  172. {ERR_FUNC(SSL_F_SSL_CHECK_PRIVATE_KEY), "SSL_check_private_key"},
  173. {ERR_FUNC(SSL_F_SSL_CIPHER_PROCESS_RULESTR), "SSL_CIPHER_PROCESS_RULESTR"},
  174. {ERR_FUNC(SSL_F_SSL_CIPHER_STRENGTH_SORT), "SSL_CIPHER_STRENGTH_SORT"},
  175. {ERR_FUNC(SSL_F_SSL_CLEAR), "SSL_clear"},
  176. {ERR_FUNC(SSL_F_SSL_COMP_ADD_COMPRESSION_METHOD), "SSL_COMP_add_compression_method"},
  177. {ERR_FUNC(SSL_F_SSL_CREATE_CIPHER_LIST), "SSL_CREATE_CIPHER_LIST"},
  178. {ERR_FUNC(SSL_F_SSL_CTRL), "SSL_ctrl"},
  179. {ERR_FUNC(SSL_F_SSL_CTX_CHECK_PRIVATE_KEY), "SSL_CTX_check_private_key"},
  180. {ERR_FUNC(SSL_F_SSL_CTX_NEW), "SSL_CTX_new"},
  181. {ERR_FUNC(SSL_F_SSL_CTX_SET_CIPHER_LIST), "SSL_CTX_set_cipher_list"},
  182. {ERR_FUNC(SSL_F_SSL_CTX_SET_PURPOSE), "SSL_CTX_set_purpose"},
  183. {ERR_FUNC(SSL_F_SSL_CTX_SET_SESSION_ID_CONTEXT), "SSL_CTX_set_session_id_context"},
  184. {ERR_FUNC(SSL_F_SSL_CTX_SET_SSL_VERSION), "SSL_CTX_set_ssl_version"},
  185. {ERR_FUNC(SSL_F_SSL_CTX_SET_TRUST), "SSL_CTX_set_trust"},
  186. {ERR_FUNC(SSL_F_SSL_CTX_USE_CERTIFICATE), "SSL_CTX_use_certificate"},
  187. {ERR_FUNC(SSL_F_SSL_CTX_USE_CERTIFICATE_ASN1), "SSL_CTX_use_certificate_ASN1"},
  188. {ERR_FUNC(SSL_F_SSL_CTX_USE_CERTIFICATE_CHAIN_FILE), "SSL_CTX_use_certificate_chain_file"},
  189. {ERR_FUNC(SSL_F_SSL_CTX_USE_CERTIFICATE_FILE), "SSL_CTX_use_certificate_file"},
  190. {ERR_FUNC(SSL_F_SSL_CTX_USE_PRIVATEKEY), "SSL_CTX_use_PrivateKey"},
  191. {ERR_FUNC(SSL_F_SSL_CTX_USE_PRIVATEKEY_ASN1), "SSL_CTX_use_PrivateKey_ASN1"},
  192. {ERR_FUNC(SSL_F_SSL_CTX_USE_PRIVATEKEY_FILE), "SSL_CTX_use_PrivateKey_file"},
  193. {ERR_FUNC(SSL_F_SSL_CTX_USE_RSAPRIVATEKEY), "SSL_CTX_use_RSAPrivateKey"},
  194. {ERR_FUNC(SSL_F_SSL_CTX_USE_RSAPRIVATEKEY_ASN1), "SSL_CTX_use_RSAPrivateKey_ASN1"},
  195. {ERR_FUNC(SSL_F_SSL_CTX_USE_RSAPRIVATEKEY_FILE), "SSL_CTX_use_RSAPrivateKey_file"},
  196. {ERR_FUNC(SSL_F_SSL_DO_HANDSHAKE), "SSL_do_handshake"},
  197. {ERR_FUNC(SSL_F_SSL_GET_NEW_SESSION), "SSL_GET_NEW_SESSION"},
  198. {ERR_FUNC(SSL_F_SSL_GET_PREV_SESSION), "SSL_GET_PREV_SESSION"},
  199. {ERR_FUNC(SSL_F_SSL_GET_SERVER_SEND_CERT), "SSL_GET_SERVER_SEND_CERT"},
  200. {ERR_FUNC(SSL_F_SSL_GET_SIGN_PKEY), "SSL_GET_SIGN_PKEY"},
  201. {ERR_FUNC(SSL_F_SSL_INIT_WBIO_BUFFER), "SSL_INIT_WBIO_BUFFER"},
  202. {ERR_FUNC(SSL_F_SSL_LOAD_CLIENT_CA_FILE), "SSL_load_client_CA_file"},
  203. {ERR_FUNC(SSL_F_SSL_NEW), "SSL_new"},
  204. {ERR_FUNC(SSL_F_SSL_PEEK), "SSL_peek"},
  205. {ERR_FUNC(SSL_F_SSL_READ), "SSL_read"},
  206. {ERR_FUNC(SSL_F_SSL_RSA_PRIVATE_DECRYPT), "SSL_RSA_PRIVATE_DECRYPT"},
  207. {ERR_FUNC(SSL_F_SSL_RSA_PUBLIC_ENCRYPT), "SSL_RSA_PUBLIC_ENCRYPT"},
  208. {ERR_FUNC(SSL_F_SSL_SESSION_NEW), "SSL_SESSION_new"},
  209. {ERR_FUNC(SSL_F_SSL_SESSION_PRINT_FP), "SSL_SESSION_print_fp"},
  210. {ERR_FUNC(SSL_F_SSL_SESS_CERT_NEW), "SSL_SESS_CERT_NEW"},
  211. {ERR_FUNC(SSL_F_SSL_SET_CERT), "SSL_SET_CERT"},
  212. {ERR_FUNC(SSL_F_SSL_SET_CIPHER_LIST), "SSL_set_cipher_list"},
  213. {ERR_FUNC(SSL_F_SSL_SET_FD), "SSL_set_fd"},
  214. {ERR_FUNC(SSL_F_SSL_SET_PKEY), "SSL_SET_PKEY"},
  215. {ERR_FUNC(SSL_F_SSL_SET_PURPOSE), "SSL_set_purpose"},
  216. {ERR_FUNC(SSL_F_SSL_SET_RFD), "SSL_set_rfd"},
  217. {ERR_FUNC(SSL_F_SSL_SET_SESSION), "SSL_set_session"},
  218. {ERR_FUNC(SSL_F_SSL_SET_SESSION_ID_CONTEXT), "SSL_set_session_id_context"},
  219. {ERR_FUNC(SSL_F_SSL_SET_TRUST), "SSL_set_trust"},
  220. {ERR_FUNC(SSL_F_SSL_SET_WFD), "SSL_set_wfd"},
  221. {ERR_FUNC(SSL_F_SSL_SHUTDOWN), "SSL_shutdown"},
  222. {ERR_FUNC(SSL_F_SSL_UNDEFINED_CONST_FUNCTION), "SSL_UNDEFINED_CONST_FUNCTION"},
  223. {ERR_FUNC(SSL_F_SSL_UNDEFINED_FUNCTION), "SSL_UNDEFINED_FUNCTION"},
  224. {ERR_FUNC(SSL_F_SSL_UNDEFINED_VOID_FUNCTION), "SSL_UNDEFINED_VOID_FUNCTION"},
  225. {ERR_FUNC(SSL_F_SSL_USE_CERTIFICATE), "SSL_use_certificate"},
  226. {ERR_FUNC(SSL_F_SSL_USE_CERTIFICATE_ASN1), "SSL_use_certificate_ASN1"},
  227. {ERR_FUNC(SSL_F_SSL_USE_CERTIFICATE_FILE), "SSL_use_certificate_file"},
  228. {ERR_FUNC(SSL_F_SSL_USE_PRIVATEKEY), "SSL_use_PrivateKey"},
  229. {ERR_FUNC(SSL_F_SSL_USE_PRIVATEKEY_ASN1), "SSL_use_PrivateKey_ASN1"},
  230. {ERR_FUNC(SSL_F_SSL_USE_PRIVATEKEY_FILE), "SSL_use_PrivateKey_file"},
  231. {ERR_FUNC(SSL_F_SSL_USE_RSAPRIVATEKEY), "SSL_use_RSAPrivateKey"},
  232. {ERR_FUNC(SSL_F_SSL_USE_RSAPRIVATEKEY_ASN1), "SSL_use_RSAPrivateKey_ASN1"},
  233. {ERR_FUNC(SSL_F_SSL_USE_RSAPRIVATEKEY_FILE), "SSL_use_RSAPrivateKey_file"},
  234. {ERR_FUNC(SSL_F_SSL_VERIFY_CERT_CHAIN), "SSL_VERIFY_CERT_CHAIN"},
  235. {ERR_FUNC(SSL_F_SSL_WRITE), "SSL_write"},
  236. {ERR_FUNC(SSL_F_TLS1_CHANGE_CIPHER_STATE), "TLS1_CHANGE_CIPHER_STATE"},
  237. {ERR_FUNC(SSL_F_TLS1_ENC), "TLS1_ENC"},
  238. {ERR_FUNC(SSL_F_TLS1_SETUP_KEY_BLOCK), "TLS1_SETUP_KEY_BLOCK"},
  239. {ERR_FUNC(SSL_F_WRITE_PENDING), "WRITE_PENDING"},
  240. {0,NULL}
  241. };
  242. static ERR_STRING_DATA SSL_str_reasons[]=
  243. {
  244. {ERR_REASON(SSL_R_APP_DATA_IN_HANDSHAKE) ,"app data in handshake"},
  245. {ERR_REASON(SSL_R_ATTEMPT_TO_REUSE_SESSION_IN_DIFFERENT_CONTEXT),"attempt to reuse session in different context"},
  246. {ERR_REASON(SSL_R_BAD_ALERT_RECORD) ,"bad alert record"},
  247. {ERR_REASON(SSL_R_BAD_AUTHENTICATION_TYPE),"bad authentication type"},
  248. {ERR_REASON(SSL_R_BAD_CHANGE_CIPHER_SPEC),"bad change cipher spec"},
  249. {ERR_REASON(SSL_R_BAD_CHECKSUM) ,"bad checksum"},
  250. {ERR_REASON(SSL_R_BAD_DATA_RETURNED_BY_CALLBACK),"bad data returned by callback"},
  251. {ERR_REASON(SSL_R_BAD_DECOMPRESSION) ,"bad decompression"},
  252. {ERR_REASON(SSL_R_BAD_DH_G_LENGTH) ,"bad dh g length"},
  253. {ERR_REASON(SSL_R_BAD_DH_PUB_KEY_LENGTH) ,"bad dh pub key length"},
  254. {ERR_REASON(SSL_R_BAD_DH_P_LENGTH) ,"bad dh p length"},
  255. {ERR_REASON(SSL_R_BAD_DIGEST_LENGTH) ,"bad digest length"},
  256. {ERR_REASON(SSL_R_BAD_DSA_SIGNATURE) ,"bad dsa signature"},
  257. {ERR_REASON(SSL_R_BAD_ECC_CERT) ,"bad ecc cert"},
  258. {ERR_REASON(SSL_R_BAD_ECDSA_SIGNATURE) ,"bad ecdsa signature"},
  259. {ERR_REASON(SSL_R_BAD_ECPOINT) ,"bad ecpoint"},
  260. {ERR_REASON(SSL_R_BAD_HELLO_REQUEST) ,"bad hello request"},
  261. {ERR_REASON(SSL_R_BAD_LENGTH) ,"bad length"},
  262. {ERR_REASON(SSL_R_BAD_MAC_DECODE) ,"bad mac decode"},
  263. {ERR_REASON(SSL_R_BAD_MESSAGE_TYPE) ,"bad message type"},
  264. {ERR_REASON(SSL_R_BAD_PACKET_LENGTH) ,"bad packet length"},
  265. {ERR_REASON(SSL_R_BAD_PROTOCOL_VERSION_NUMBER),"bad protocol version number"},
  266. {ERR_REASON(SSL_R_BAD_RESPONSE_ARGUMENT) ,"bad response argument"},
  267. {ERR_REASON(SSL_R_BAD_RSA_DECRYPT) ,"bad rsa decrypt"},
  268. {ERR_REASON(SSL_R_BAD_RSA_ENCRYPT) ,"bad rsa encrypt"},
  269. {ERR_REASON(SSL_R_BAD_RSA_E_LENGTH) ,"bad rsa e length"},
  270. {ERR_REASON(SSL_R_BAD_RSA_MODULUS_LENGTH),"bad rsa modulus length"},
  271. {ERR_REASON(SSL_R_BAD_RSA_SIGNATURE) ,"bad rsa signature"},
  272. {ERR_REASON(SSL_R_BAD_SIGNATURE) ,"bad signature"},
  273. {ERR_REASON(SSL_R_BAD_SSL_FILETYPE) ,"bad ssl filetype"},
  274. {ERR_REASON(SSL_R_BAD_SSL_SESSION_ID_LENGTH),"bad ssl session id length"},
  275. {ERR_REASON(SSL_R_BAD_STATE) ,"bad state"},
  276. {ERR_REASON(SSL_R_BAD_WRITE_RETRY) ,"bad write retry"},
  277. {ERR_REASON(SSL_R_BIO_NOT_SET) ,"bio not set"},
  278. {ERR_REASON(SSL_R_BLOCK_CIPHER_PAD_IS_WRONG),"block cipher pad is wrong"},
  279. {ERR_REASON(SSL_R_BN_LIB) ,"bn lib"},
  280. {ERR_REASON(SSL_R_CA_DN_LENGTH_MISMATCH) ,"ca dn length mismatch"},
  281. {ERR_REASON(SSL_R_CA_DN_TOO_LONG) ,"ca dn too long"},
  282. {ERR_REASON(SSL_R_CCS_RECEIVED_EARLY) ,"ccs received early"},
  283. {ERR_REASON(SSL_R_CERTIFICATE_VERIFY_FAILED),"certificate verify failed"},
  284. {ERR_REASON(SSL_R_CERT_LENGTH_MISMATCH) ,"cert length mismatch"},
  285. {ERR_REASON(SSL_R_CHALLENGE_IS_DIFFERENT),"challenge is different"},
  286. {ERR_REASON(SSL_R_CIPHER_CODE_WRONG_LENGTH),"cipher code wrong length"},
  287. {ERR_REASON(SSL_R_CIPHER_OR_HASH_UNAVAILABLE),"cipher or hash unavailable"},
  288. {ERR_REASON(SSL_R_CIPHER_TABLE_SRC_ERROR),"cipher table src error"},
  289. {ERR_REASON(SSL_R_COMPRESSED_LENGTH_TOO_LONG),"compressed length too long"},
  290. {ERR_REASON(SSL_R_COMPRESSION_FAILURE) ,"compression failure"},
  291. {ERR_REASON(SSL_R_COMPRESSION_ID_NOT_WITHIN_PRIVATE_RANGE),"compression id not within private range"},
  292. {ERR_REASON(SSL_R_COMPRESSION_LIBRARY_ERROR),"compression library error"},
  293. {ERR_REASON(SSL_R_CONNECTION_ID_IS_DIFFERENT),"connection id is different"},
  294. {ERR_REASON(SSL_R_CONNECTION_TYPE_NOT_SET),"connection type not set"},
  295. {ERR_REASON(SSL_R_COOKIE_MISMATCH) ,"cookie mismatch"},
  296. {ERR_REASON(SSL_R_DATA_BETWEEN_CCS_AND_FINISHED),"data between ccs and finished"},
  297. {ERR_REASON(SSL_R_DATA_LENGTH_TOO_LONG) ,"data length too long"},
  298. {ERR_REASON(SSL_R_DECRYPTION_FAILED) ,"decryption failed"},
  299. {ERR_REASON(SSL_R_DECRYPTION_FAILED_OR_BAD_RECORD_MAC),"decryption failed or bad record mac"},
  300. {ERR_REASON(SSL_R_DH_PUBLIC_VALUE_LENGTH_IS_WRONG),"dh public value length is wrong"},
  301. {ERR_REASON(SSL_R_DIGEST_CHECK_FAILED) ,"digest check failed"},
  302. {ERR_REASON(SSL_R_DUPLICATE_COMPRESSION_ID),"duplicate compression id"},
  303. {ERR_REASON(SSL_R_ECGROUP_TOO_LARGE_FOR_CIPHER),"ecgroup too large for cipher"},
  304. {ERR_REASON(SSL_R_ENCRYPTED_LENGTH_TOO_LONG),"encrypted length too long"},
  305. {ERR_REASON(SSL_R_ERROR_GENERATING_TMP_RSA_KEY),"error generating tmp rsa key"},
  306. {ERR_REASON(SSL_R_ERROR_IN_RECEIVED_CIPHER_LIST),"error in received cipher list"},
  307. {ERR_REASON(SSL_R_EXCESSIVE_MESSAGE_SIZE),"excessive message size"},
  308. {ERR_REASON(SSL_R_EXTRA_DATA_IN_MESSAGE) ,"extra data in message"},
  309. {ERR_REASON(SSL_R_GOT_A_FIN_BEFORE_A_CCS),"got a fin before a ccs"},
  310. {ERR_REASON(SSL_R_HTTPS_PROXY_REQUEST) ,"https proxy request"},
  311. {ERR_REASON(SSL_R_HTTP_REQUEST) ,"http request"},
  312. {ERR_REASON(SSL_R_ILLEGAL_PADDING) ,"illegal padding"},
  313. {ERR_REASON(SSL_R_INVALID_CHALLENGE_LENGTH),"invalid challenge length"},
  314. {ERR_REASON(SSL_R_INVALID_COMMAND) ,"invalid command"},
  315. {ERR_REASON(SSL_R_INVALID_PURPOSE) ,"invalid purpose"},
  316. {ERR_REASON(SSL_R_INVALID_TRUST) ,"invalid trust"},
  317. {ERR_REASON(SSL_R_KEY_ARG_TOO_LONG) ,"key arg too long"},
  318. {ERR_REASON(SSL_R_KRB5) ,"krb5"},
  319. {ERR_REASON(SSL_R_KRB5_C_CC_PRINC) ,"krb5 client cc principal (no tkt?)"},
  320. {ERR_REASON(SSL_R_KRB5_C_GET_CRED) ,"krb5 client get cred"},
  321. {ERR_REASON(SSL_R_KRB5_C_INIT) ,"krb5 client init"},
  322. {ERR_REASON(SSL_R_KRB5_C_MK_REQ) ,"krb5 client mk_req (expired tkt?)"},
  323. {ERR_REASON(SSL_R_KRB5_S_BAD_TICKET) ,"krb5 server bad ticket"},
  324. {ERR_REASON(SSL_R_KRB5_S_INIT) ,"krb5 server init"},
  325. {ERR_REASON(SSL_R_KRB5_S_RD_REQ) ,"krb5 server rd_req (keytab perms?)"},
  326. {ERR_REASON(SSL_R_KRB5_S_TKT_EXPIRED) ,"krb5 server tkt expired"},
  327. {ERR_REASON(SSL_R_KRB5_S_TKT_NYV) ,"krb5 server tkt not yet valid"},
  328. {ERR_REASON(SSL_R_KRB5_S_TKT_SKEW) ,"krb5 server tkt skew"},
  329. {ERR_REASON(SSL_R_LENGTH_MISMATCH) ,"length mismatch"},
  330. {ERR_REASON(SSL_R_LENGTH_TOO_SHORT) ,"length too short"},
  331. {ERR_REASON(SSL_R_LIBRARY_BUG) ,"library bug"},
  332. {ERR_REASON(SSL_R_LIBRARY_HAS_NO_CIPHERS),"library has no ciphers"},
  333. {ERR_REASON(SSL_R_MESSAGE_TOO_LONG) ,"message too long"},
  334. {ERR_REASON(SSL_R_MISSING_DH_DSA_CERT) ,"missing dh dsa cert"},
  335. {ERR_REASON(SSL_R_MISSING_DH_KEY) ,"missing dh key"},
  336. {ERR_REASON(SSL_R_MISSING_DH_RSA_CERT) ,"missing dh rsa cert"},
  337. {ERR_REASON(SSL_R_MISSING_DSA_SIGNING_CERT),"missing dsa signing cert"},
  338. {ERR_REASON(SSL_R_MISSING_EXPORT_TMP_DH_KEY),"missing export tmp dh key"},
  339. {ERR_REASON(SSL_R_MISSING_EXPORT_TMP_RSA_KEY),"missing export tmp rsa key"},
  340. {ERR_REASON(SSL_R_MISSING_RSA_CERTIFICATE),"missing rsa certificate"},
  341. {ERR_REASON(SSL_R_MISSING_RSA_ENCRYPTING_CERT),"missing rsa encrypting cert"},
  342. {ERR_REASON(SSL_R_MISSING_RSA_SIGNING_CERT),"missing rsa signing cert"},
  343. {ERR_REASON(SSL_R_MISSING_TMP_DH_KEY) ,"missing tmp dh key"},
  344. {ERR_REASON(SSL_R_MISSING_TMP_ECDH_KEY) ,"missing tmp ecdh key"},
  345. {ERR_REASON(SSL_R_MISSING_TMP_RSA_KEY) ,"missing tmp rsa key"},
  346. {ERR_REASON(SSL_R_MISSING_TMP_RSA_PKEY) ,"missing tmp rsa pkey"},
  347. {ERR_REASON(SSL_R_MISSING_VERIFY_MESSAGE),"missing verify message"},
  348. {ERR_REASON(SSL_R_NON_SSLV2_INITIAL_PACKET),"non sslv2 initial packet"},
  349. {ERR_REASON(SSL_R_NO_CERTIFICATES_RETURNED),"no certificates returned"},
  350. {ERR_REASON(SSL_R_NO_CERTIFICATE_ASSIGNED),"no certificate assigned"},
  351. {ERR_REASON(SSL_R_NO_CERTIFICATE_RETURNED),"no certificate returned"},
  352. {ERR_REASON(SSL_R_NO_CERTIFICATE_SET) ,"no certificate set"},
  353. {ERR_REASON(SSL_R_NO_CERTIFICATE_SPECIFIED),"no certificate specified"},
  354. {ERR_REASON(SSL_R_NO_CIPHERS_AVAILABLE) ,"no ciphers available"},
  355. {ERR_REASON(SSL_R_NO_CIPHERS_PASSED) ,"no ciphers passed"},
  356. {ERR_REASON(SSL_R_NO_CIPHERS_SPECIFIED) ,"no ciphers specified"},
  357. {ERR_REASON(SSL_R_NO_CIPHER_LIST) ,"no cipher list"},
  358. {ERR_REASON(SSL_R_NO_CIPHER_MATCH) ,"no cipher match"},
  359. {ERR_REASON(SSL_R_NO_CLIENT_CERT_RECEIVED),"no client cert received"},
  360. {ERR_REASON(SSL_R_NO_COMPRESSION_SPECIFIED),"no compression specified"},
  361. {ERR_REASON(SSL_R_NO_METHOD_SPECIFIED) ,"no method specified"},
  362. {ERR_REASON(SSL_R_NO_PRIVATEKEY) ,"no privatekey"},
  363. {ERR_REASON(SSL_R_NO_PRIVATE_KEY_ASSIGNED),"no private key assigned"},
  364. {ERR_REASON(SSL_R_NO_PROTOCOLS_AVAILABLE),"no protocols available"},
  365. {ERR_REASON(SSL_R_NO_PUBLICKEY) ,"no publickey"},
  366. {ERR_REASON(SSL_R_NO_SHARED_CIPHER) ,"no shared cipher"},
  367. {ERR_REASON(SSL_R_NO_VERIFY_CALLBACK) ,"no verify callback"},
  368. {ERR_REASON(SSL_R_NULL_SSL_CTX) ,"null ssl ctx"},
  369. {ERR_REASON(SSL_R_NULL_SSL_METHOD_PASSED),"null ssl method passed"},
  370. {ERR_REASON(SSL_R_OLD_SESSION_CIPHER_NOT_RETURNED),"old session cipher not returned"},
  371. {ERR_REASON(SSL_R_ONLY_TLS_ALLOWED_IN_FIPS_MODE),"only tls allowed in fips mode"},
  372. {ERR_REASON(SSL_R_PACKET_LENGTH_TOO_LONG),"packet length too long"},
  373. {ERR_REASON(SSL_R_PATH_TOO_LONG) ,"path too long"},
  374. {ERR_REASON(SSL_R_PEER_DID_NOT_RETURN_A_CERTIFICATE),"peer did not return a certificate"},
  375. {ERR_REASON(SSL_R_PEER_ERROR) ,"peer error"},
  376. {ERR_REASON(SSL_R_PEER_ERROR_CERTIFICATE),"peer error certificate"},
  377. {ERR_REASON(SSL_R_PEER_ERROR_NO_CERTIFICATE),"peer error no certificate"},
  378. {ERR_REASON(SSL_R_PEER_ERROR_NO_CIPHER) ,"peer error no cipher"},
  379. {ERR_REASON(SSL_R_PEER_ERROR_UNSUPPORTED_CERTIFICATE_TYPE),"peer error unsupported certificate type"},
  380. {ERR_REASON(SSL_R_PRE_MAC_LENGTH_TOO_LONG),"pre mac length too long"},
  381. {ERR_REASON(SSL_R_PROBLEMS_MAPPING_CIPHER_FUNCTIONS),"problems mapping cipher functions"},
  382. {ERR_REASON(SSL_R_PROTOCOL_IS_SHUTDOWN) ,"protocol is shutdown"},
  383. {ERR_REASON(SSL_R_PUBLIC_KEY_ENCRYPT_ERROR),"public key encrypt error"},
  384. {ERR_REASON(SSL_R_PUBLIC_KEY_IS_NOT_RSA) ,"public key is not rsa"},
  385. {ERR_REASON(SSL_R_PUBLIC_KEY_NOT_RSA) ,"public key not rsa"},
  386. {ERR_REASON(SSL_R_READ_BIO_NOT_SET) ,"read bio not set"},
  387. {ERR_REASON(SSL_R_READ_TIMEOUT_EXPIRED) ,"read timeout expired"},
  388. {ERR_REASON(SSL_R_READ_WRONG_PACKET_TYPE),"read wrong packet type"},
  389. {ERR_REASON(SSL_R_RECORD_LENGTH_MISMATCH),"record length mismatch"},
  390. {ERR_REASON(SSL_R_RECORD_TOO_LARGE) ,"record too large"},
  391. {ERR_REASON(SSL_R_RECORD_TOO_SMALL) ,"record too small"},
  392. {ERR_REASON(SSL_R_REQUIRED_CIPHER_MISSING),"required cipher missing"},
  393. {ERR_REASON(SSL_R_REUSE_CERT_LENGTH_NOT_ZERO),"reuse cert length not zero"},
  394. {ERR_REASON(SSL_R_REUSE_CERT_TYPE_NOT_ZERO),"reuse cert type not zero"},
  395. {ERR_REASON(SSL_R_REUSE_CIPHER_LIST_NOT_ZERO),"reuse cipher list not zero"},
  396. {ERR_REASON(SSL_R_SESSION_ID_CONTEXT_UNINITIALIZED),"session id context uninitialized"},
  397. {ERR_REASON(SSL_R_SHORT_READ) ,"short read"},
  398. {ERR_REASON(SSL_R_SIGNATURE_FOR_NON_SIGNING_CERTIFICATE),"signature for non signing certificate"},
  399. {ERR_REASON(SSL_R_SSL23_DOING_SESSION_ID_REUSE),"ssl23 doing session id reuse"},
  400. {ERR_REASON(SSL_R_SSL2_CONNECTION_ID_TOO_LONG),"ssl2 connection id too long"},
  401. {ERR_REASON(SSL_R_SSL3_SESSION_ID_TOO_LONG),"ssl3 session id too long"},
  402. {ERR_REASON(SSL_R_SSL3_SESSION_ID_TOO_SHORT),"ssl3 session id too short"},
  403. {ERR_REASON(SSL_R_SSLV3_ALERT_BAD_CERTIFICATE),"sslv3 alert bad certificate"},
  404. {ERR_REASON(SSL_R_SSLV3_ALERT_BAD_RECORD_MAC),"sslv3 alert bad record mac"},
  405. {ERR_REASON(SSL_R_SSLV3_ALERT_CERTIFICATE_EXPIRED),"sslv3 alert certificate expired"},
  406. {ERR_REASON(SSL_R_SSLV3_ALERT_CERTIFICATE_REVOKED),"sslv3 alert certificate revoked"},
  407. {ERR_REASON(SSL_R_SSLV3_ALERT_CERTIFICATE_UNKNOWN),"sslv3 alert certificate unknown"},
  408. {ERR_REASON(SSL_R_SSLV3_ALERT_DECOMPRESSION_FAILURE),"sslv3 alert decompression failure"},
  409. {ERR_REASON(SSL_R_SSLV3_ALERT_HANDSHAKE_FAILURE),"sslv3 alert handshake failure"},
  410. {ERR_REASON(SSL_R_SSLV3_ALERT_ILLEGAL_PARAMETER),"sslv3 alert illegal parameter"},
  411. {ERR_REASON(SSL_R_SSLV3_ALERT_NO_CERTIFICATE),"sslv3 alert no certificate"},
  412. {ERR_REASON(SSL_R_SSLV3_ALERT_UNEXPECTED_MESSAGE),"sslv3 alert unexpected message"},
  413. {ERR_REASON(SSL_R_SSLV3_ALERT_UNSUPPORTED_CERTIFICATE),"sslv3 alert unsupported certificate"},
  414. {ERR_REASON(SSL_R_SSL_CTX_HAS_NO_DEFAULT_SSL_VERSION),"ssl ctx has no default ssl version"},
  415. {ERR_REASON(SSL_R_SSL_HANDSHAKE_FAILURE) ,"ssl handshake failure"},
  416. {ERR_REASON(SSL_R_SSL_LIBRARY_HAS_NO_CIPHERS),"ssl library has no ciphers"},
  417. {ERR_REASON(SSL_R_SSL_SESSION_ID_CALLBACK_FAILED),"ssl session id callback failed"},
  418. {ERR_REASON(SSL_R_SSL_SESSION_ID_CONFLICT),"ssl session id conflict"},
  419. {ERR_REASON(SSL_R_SSL_SESSION_ID_CONTEXT_TOO_LONG),"ssl session id context too long"},
  420. {ERR_REASON(SSL_R_SSL_SESSION_ID_HAS_BAD_LENGTH),"ssl session id has bad length"},
  421. {ERR_REASON(SSL_R_SSL_SESSION_ID_IS_DIFFERENT),"ssl session id is different"},
  422. {ERR_REASON(SSL_R_TLSV1_ALERT_ACCESS_DENIED),"tlsv1 alert access denied"},
  423. {ERR_REASON(SSL_R_TLSV1_ALERT_DECODE_ERROR),"tlsv1 alert decode error"},
  424. {ERR_REASON(SSL_R_TLSV1_ALERT_DECRYPTION_FAILED),"tlsv1 alert decryption failed"},
  425. {ERR_REASON(SSL_R_TLSV1_ALERT_DECRYPT_ERROR),"tlsv1 alert decrypt error"},
  426. {ERR_REASON(SSL_R_TLSV1_ALERT_EXPORT_RESTRICTION),"tlsv1 alert export restriction"},
  427. {ERR_REASON(SSL_R_TLSV1_ALERT_INSUFFICIENT_SECURITY),"tlsv1 alert insufficient security"},
  428. {ERR_REASON(SSL_R_TLSV1_ALERT_INTERNAL_ERROR),"tlsv1 alert internal error"},
  429. {ERR_REASON(SSL_R_TLSV1_ALERT_NO_RENEGOTIATION),"tlsv1 alert no renegotiation"},
  430. {ERR_REASON(SSL_R_TLSV1_ALERT_PROTOCOL_VERSION),"tlsv1 alert protocol version"},
  431. {ERR_REASON(SSL_R_TLSV1_ALERT_RECORD_OVERFLOW),"tlsv1 alert record overflow"},
  432. {ERR_REASON(SSL_R_TLSV1_ALERT_UNKNOWN_CA),"tlsv1 alert unknown ca"},
  433. {ERR_REASON(SSL_R_TLSV1_ALERT_USER_CANCELLED),"tlsv1 alert user cancelled"},
  434. {ERR_REASON(SSL_R_TLS_CLIENT_CERT_REQ_WITH_ANON_CIPHER),"tls client cert req with anon cipher"},
  435. {ERR_REASON(SSL_R_TLS_PEER_DID_NOT_RESPOND_WITH_CERTIFICATE_LIST),"tls peer did not respond with certificate list"},
  436. {ERR_REASON(SSL_R_TLS_RSA_ENCRYPTED_VALUE_LENGTH_IS_WRONG),"tls rsa encrypted value length is wrong"},
  437. {ERR_REASON(SSL_R_TRIED_TO_USE_UNSUPPORTED_CIPHER),"tried to use unsupported cipher"},
  438. {ERR_REASON(SSL_R_UNABLE_TO_DECODE_DH_CERTS),"unable to decode dh certs"},
  439. {ERR_REASON(SSL_R_UNABLE_TO_DECODE_ECDH_CERTS),"unable to decode ecdh certs"},
  440. {ERR_REASON(SSL_R_UNABLE_TO_EXTRACT_PUBLIC_KEY),"unable to extract public key"},
  441. {ERR_REASON(SSL_R_UNABLE_TO_FIND_DH_PARAMETERS),"unable to find dh parameters"},
  442. {ERR_REASON(SSL_R_UNABLE_TO_FIND_ECDH_PARAMETERS),"unable to find ecdh parameters"},
  443. {ERR_REASON(SSL_R_UNABLE_TO_FIND_PUBLIC_KEY_PARAMETERS),"unable to find public key parameters"},
  444. {ERR_REASON(SSL_R_UNABLE_TO_FIND_SSL_METHOD),"unable to find ssl method"},
  445. {ERR_REASON(SSL_R_UNABLE_TO_LOAD_SSL2_MD5_ROUTINES),"unable to load ssl2 md5 routines"},
  446. {ERR_REASON(SSL_R_UNABLE_TO_LOAD_SSL3_MD5_ROUTINES),"unable to load ssl3 md5 routines"},
  447. {ERR_REASON(SSL_R_UNABLE_TO_LOAD_SSL3_SHA1_ROUTINES),"unable to load ssl3 sha1 routines"},
  448. {ERR_REASON(SSL_R_UNEXPECTED_MESSAGE) ,"unexpected message"},
  449. {ERR_REASON(SSL_R_UNEXPECTED_RECORD) ,"unexpected record"},
  450. {ERR_REASON(SSL_R_UNINITIALIZED) ,"uninitialized"},
  451. {ERR_REASON(SSL_R_UNKNOWN_ALERT_TYPE) ,"unknown alert type"},
  452. {ERR_REASON(SSL_R_UNKNOWN_CERTIFICATE_TYPE),"unknown certificate type"},
  453. {ERR_REASON(SSL_R_UNKNOWN_CIPHER_RETURNED),"unknown cipher returned"},
  454. {ERR_REASON(SSL_R_UNKNOWN_CIPHER_TYPE) ,"unknown cipher type"},
  455. {ERR_REASON(SSL_R_UNKNOWN_KEY_EXCHANGE_TYPE),"unknown key exchange type"},
  456. {ERR_REASON(SSL_R_UNKNOWN_PKEY_TYPE) ,"unknown pkey type"},
  457. {ERR_REASON(SSL_R_UNKNOWN_PROTOCOL) ,"unknown protocol"},
  458. {ERR_REASON(SSL_R_UNKNOWN_REMOTE_ERROR_TYPE),"unknown remote error type"},
  459. {ERR_REASON(SSL_R_UNKNOWN_SSL_VERSION) ,"unknown ssl version"},
  460. {ERR_REASON(SSL_R_UNKNOWN_STATE) ,"unknown state"},
  461. {ERR_REASON(SSL_R_UNSUPPORTED_CIPHER) ,"unsupported cipher"},
  462. {ERR_REASON(SSL_R_UNSUPPORTED_COMPRESSION_ALGORITHM),"unsupported compression algorithm"},
  463. {ERR_REASON(SSL_R_UNSUPPORTED_ELLIPTIC_CURVE),"unsupported elliptic curve"},
  464. {ERR_REASON(SSL_R_UNSUPPORTED_PROTOCOL) ,"unsupported protocol"},
  465. {ERR_REASON(SSL_R_UNSUPPORTED_SSL_VERSION),"unsupported ssl version"},
  466. {ERR_REASON(SSL_R_WRITE_BIO_NOT_SET) ,"write bio not set"},
  467. {ERR_REASON(SSL_R_WRONG_CIPHER_RETURNED) ,"wrong cipher returned"},
  468. {ERR_REASON(SSL_R_WRONG_MESSAGE_TYPE) ,"wrong message type"},
  469. {ERR_REASON(SSL_R_WRONG_NUMBER_OF_KEY_BITS),"wrong number of key bits"},
  470. {ERR_REASON(SSL_R_WRONG_SIGNATURE_LENGTH),"wrong signature length"},
  471. {ERR_REASON(SSL_R_WRONG_SIGNATURE_SIZE) ,"wrong signature size"},
  472. {ERR_REASON(SSL_R_WRONG_SSL_VERSION) ,"wrong ssl version"},
  473. {ERR_REASON(SSL_R_WRONG_VERSION_NUMBER) ,"wrong version number"},
  474. {ERR_REASON(SSL_R_X509_LIB) ,"x509 lib"},
  475. {ERR_REASON(SSL_R_X509_VERIFICATION_SETUP_PROBLEMS),"x509 verification setup problems"},
  476. {0,NULL}
  477. };
  478. #endif
  479. void ERR_load_SSL_strings(void)
  480. {
  481. #ifndef OPENSSL_NO_ERR
  482. if (ERR_func_error_string(SSL_str_functs[0].error) == NULL)
  483. {
  484. ERR_load_strings(0,SSL_str_functs);
  485. ERR_load_strings(0,SSL_str_reasons);
  486. }
  487. #endif
  488. }