1*817466cbSJens Wiklander /* 2*817466cbSJens Wiklander * Error message information 3*817466cbSJens Wiklander * 4*817466cbSJens Wiklander * Copyright (C) 2006-2015, ARM Limited, All Rights Reserved 5*817466cbSJens Wiklander * SPDX-License-Identifier: Apache-2.0 6*817466cbSJens Wiklander * 7*817466cbSJens Wiklander * Licensed under the Apache License, Version 2.0 (the "License"); you may 8*817466cbSJens Wiklander * not use this file except in compliance with the License. 9*817466cbSJens Wiklander * You may obtain a copy of the License at 10*817466cbSJens Wiklander * 11*817466cbSJens Wiklander * http://www.apache.org/licenses/LICENSE-2.0 12*817466cbSJens Wiklander * 13*817466cbSJens Wiklander * Unless required by applicable law or agreed to in writing, software 14*817466cbSJens Wiklander * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT 15*817466cbSJens Wiklander * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 16*817466cbSJens Wiklander * See the License for the specific language governing permissions and 17*817466cbSJens Wiklander * limitations under the License. 18*817466cbSJens Wiklander * 19*817466cbSJens Wiklander * This file is part of mbed TLS (https://tls.mbed.org) 20*817466cbSJens Wiklander */ 21*817466cbSJens Wiklander 22*817466cbSJens Wiklander #if !defined(MBEDTLS_CONFIG_FILE) 23*817466cbSJens Wiklander #include "mbedtls/config.h" 24*817466cbSJens Wiklander #else 25*817466cbSJens Wiklander #include MBEDTLS_CONFIG_FILE 26*817466cbSJens Wiklander #endif 27*817466cbSJens Wiklander 28*817466cbSJens Wiklander #if defined(MBEDTLS_ERROR_C) || defined(MBEDTLS_ERROR_STRERROR_DUMMY) 29*817466cbSJens Wiklander #include "mbedtls/error.h" 30*817466cbSJens Wiklander #include <string.h> 31*817466cbSJens Wiklander #endif 32*817466cbSJens Wiklander 33*817466cbSJens Wiklander #if defined(MBEDTLS_PLATFORM_C) 34*817466cbSJens Wiklander #include "mbedtls/platform.h" 35*817466cbSJens Wiklander #else 36*817466cbSJens Wiklander #define mbedtls_snprintf snprintf 37*817466cbSJens Wiklander #define mbedtls_time_t time_t 38*817466cbSJens Wiklander #endif 39*817466cbSJens Wiklander 40*817466cbSJens Wiklander #if defined(MBEDTLS_ERROR_C) 41*817466cbSJens Wiklander 42*817466cbSJens Wiklander #include <stdio.h> 43*817466cbSJens Wiklander 44*817466cbSJens Wiklander #if defined(MBEDTLS_AES_C) 45*817466cbSJens Wiklander #include "mbedtls/aes.h" 46*817466cbSJens Wiklander #endif 47*817466cbSJens Wiklander 48*817466cbSJens Wiklander #if defined(MBEDTLS_BASE64_C) 49*817466cbSJens Wiklander #include "mbedtls/base64.h" 50*817466cbSJens Wiklander #endif 51*817466cbSJens Wiklander 52*817466cbSJens Wiklander #if defined(MBEDTLS_BIGNUM_C) 53*817466cbSJens Wiklander #include "mbedtls/bignum.h" 54*817466cbSJens Wiklander #endif 55*817466cbSJens Wiklander 56*817466cbSJens Wiklander #if defined(MBEDTLS_BLOWFISH_C) 57*817466cbSJens Wiklander #include "mbedtls/blowfish.h" 58*817466cbSJens Wiklander #endif 59*817466cbSJens Wiklander 60*817466cbSJens Wiklander #if defined(MBEDTLS_CAMELLIA_C) 61*817466cbSJens Wiklander #include "mbedtls/camellia.h" 62*817466cbSJens Wiklander #endif 63*817466cbSJens Wiklander 64*817466cbSJens Wiklander #if defined(MBEDTLS_CCM_C) 65*817466cbSJens Wiklander #include "mbedtls/ccm.h" 66*817466cbSJens Wiklander #endif 67*817466cbSJens Wiklander 68*817466cbSJens Wiklander #if defined(MBEDTLS_CIPHER_C) 69*817466cbSJens Wiklander #include "mbedtls/cipher.h" 70*817466cbSJens Wiklander #endif 71*817466cbSJens Wiklander 72*817466cbSJens Wiklander #if defined(MBEDTLS_CTR_DRBG_C) 73*817466cbSJens Wiklander #include "mbedtls/ctr_drbg.h" 74*817466cbSJens Wiklander #endif 75*817466cbSJens Wiklander 76*817466cbSJens Wiklander #if defined(MBEDTLS_DES_C) 77*817466cbSJens Wiklander #include "mbedtls/des.h" 78*817466cbSJens Wiklander #endif 79*817466cbSJens Wiklander 80*817466cbSJens Wiklander #if defined(MBEDTLS_DHM_C) 81*817466cbSJens Wiklander #include "mbedtls/dhm.h" 82*817466cbSJens Wiklander #endif 83*817466cbSJens Wiklander 84*817466cbSJens Wiklander #if defined(MBEDTLS_ECP_C) 85*817466cbSJens Wiklander #include "mbedtls/ecp.h" 86*817466cbSJens Wiklander #endif 87*817466cbSJens Wiklander 88*817466cbSJens Wiklander #if defined(MBEDTLS_ENTROPY_C) 89*817466cbSJens Wiklander #include "mbedtls/entropy.h" 90*817466cbSJens Wiklander #endif 91*817466cbSJens Wiklander 92*817466cbSJens Wiklander #if defined(MBEDTLS_GCM_C) 93*817466cbSJens Wiklander #include "mbedtls/gcm.h" 94*817466cbSJens Wiklander #endif 95*817466cbSJens Wiklander 96*817466cbSJens Wiklander #if defined(MBEDTLS_HMAC_DRBG_C) 97*817466cbSJens Wiklander #include "mbedtls/hmac_drbg.h" 98*817466cbSJens Wiklander #endif 99*817466cbSJens Wiklander 100*817466cbSJens Wiklander #if defined(MBEDTLS_MD_C) 101*817466cbSJens Wiklander #include "mbedtls/md.h" 102*817466cbSJens Wiklander #endif 103*817466cbSJens Wiklander 104*817466cbSJens Wiklander #if defined(MBEDTLS_NET_C) 105*817466cbSJens Wiklander #include "mbedtls/net_sockets.h" 106*817466cbSJens Wiklander #endif 107*817466cbSJens Wiklander 108*817466cbSJens Wiklander #if defined(MBEDTLS_OID_C) 109*817466cbSJens Wiklander #include "mbedtls/oid.h" 110*817466cbSJens Wiklander #endif 111*817466cbSJens Wiklander 112*817466cbSJens Wiklander #if defined(MBEDTLS_PADLOCK_C) 113*817466cbSJens Wiklander #include "mbedtls/padlock.h" 114*817466cbSJens Wiklander #endif 115*817466cbSJens Wiklander 116*817466cbSJens Wiklander #if defined(MBEDTLS_PEM_PARSE_C) || defined(MBEDTLS_PEM_WRITE_C) 117*817466cbSJens Wiklander #include "mbedtls/pem.h" 118*817466cbSJens Wiklander #endif 119*817466cbSJens Wiklander 120*817466cbSJens Wiklander #if defined(MBEDTLS_PK_C) 121*817466cbSJens Wiklander #include "mbedtls/pk.h" 122*817466cbSJens Wiklander #endif 123*817466cbSJens Wiklander 124*817466cbSJens Wiklander #if defined(MBEDTLS_PKCS12_C) 125*817466cbSJens Wiklander #include "mbedtls/pkcs12.h" 126*817466cbSJens Wiklander #endif 127*817466cbSJens Wiklander 128*817466cbSJens Wiklander #if defined(MBEDTLS_PKCS5_C) 129*817466cbSJens Wiklander #include "mbedtls/pkcs5.h" 130*817466cbSJens Wiklander #endif 131*817466cbSJens Wiklander 132*817466cbSJens Wiklander #if defined(MBEDTLS_RSA_C) 133*817466cbSJens Wiklander #include "mbedtls/rsa.h" 134*817466cbSJens Wiklander #endif 135*817466cbSJens Wiklander 136*817466cbSJens Wiklander #if defined(MBEDTLS_SSL_TLS_C) 137*817466cbSJens Wiklander #include "mbedtls/ssl.h" 138*817466cbSJens Wiklander #endif 139*817466cbSJens Wiklander 140*817466cbSJens Wiklander #if defined(MBEDTLS_THREADING_C) 141*817466cbSJens Wiklander #include "mbedtls/threading.h" 142*817466cbSJens Wiklander #endif 143*817466cbSJens Wiklander 144*817466cbSJens Wiklander #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C) 145*817466cbSJens Wiklander #include "mbedtls/x509.h" 146*817466cbSJens Wiklander #endif 147*817466cbSJens Wiklander 148*817466cbSJens Wiklander #if defined(MBEDTLS_XTEA_C) 149*817466cbSJens Wiklander #include "mbedtls/xtea.h" 150*817466cbSJens Wiklander #endif 151*817466cbSJens Wiklander 152*817466cbSJens Wiklander 153*817466cbSJens Wiklander void mbedtls_strerror( int ret, char *buf, size_t buflen ) 154*817466cbSJens Wiklander { 155*817466cbSJens Wiklander size_t len; 156*817466cbSJens Wiklander int use_ret; 157*817466cbSJens Wiklander 158*817466cbSJens Wiklander if( buflen == 0 ) 159*817466cbSJens Wiklander return; 160*817466cbSJens Wiklander 161*817466cbSJens Wiklander memset( buf, 0x00, buflen ); 162*817466cbSJens Wiklander 163*817466cbSJens Wiklander if( ret < 0 ) 164*817466cbSJens Wiklander ret = -ret; 165*817466cbSJens Wiklander 166*817466cbSJens Wiklander if( ret & 0xFF80 ) 167*817466cbSJens Wiklander { 168*817466cbSJens Wiklander use_ret = ret & 0xFF80; 169*817466cbSJens Wiklander 170*817466cbSJens Wiklander // High level error codes 171*817466cbSJens Wiklander // 172*817466cbSJens Wiklander // BEGIN generated code 173*817466cbSJens Wiklander #if defined(MBEDTLS_CIPHER_C) 174*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_FEATURE_UNAVAILABLE) ) 175*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - The selected feature is not available" ); 176*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_BAD_INPUT_DATA) ) 177*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - Bad input parameters to function" ); 178*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_ALLOC_FAILED) ) 179*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - Failed to allocate memory" ); 180*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_INVALID_PADDING) ) 181*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - Input data contains invalid padding and is rejected" ); 182*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_FULL_BLOCK_EXPECTED) ) 183*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - Decryption of block requires a full block" ); 184*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_AUTH_FAILED) ) 185*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - Authentication failed (for AEAD modes)" ); 186*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CIPHER_INVALID_CONTEXT) ) 187*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CIPHER - The context is invalid, eg because it was free()ed" ); 188*817466cbSJens Wiklander #endif /* MBEDTLS_CIPHER_C */ 189*817466cbSJens Wiklander 190*817466cbSJens Wiklander #if defined(MBEDTLS_DHM_C) 191*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_BAD_INPUT_DATA) ) 192*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Bad input parameters to function" ); 193*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_READ_PARAMS_FAILED) ) 194*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Reading of the DHM parameters failed" ); 195*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_MAKE_PARAMS_FAILED) ) 196*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Making of the DHM parameters failed" ); 197*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_READ_PUBLIC_FAILED) ) 198*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Reading of the public values failed" ); 199*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_MAKE_PUBLIC_FAILED) ) 200*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Making of the public value failed" ); 201*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_CALC_SECRET_FAILED) ) 202*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Calculation of the DHM secret failed" ); 203*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_INVALID_FORMAT) ) 204*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - The ASN.1 data is not formatted correctly" ); 205*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_ALLOC_FAILED) ) 206*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Allocation of memory failed" ); 207*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DHM_FILE_IO_ERROR) ) 208*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DHM - Read/write of file failed" ); 209*817466cbSJens Wiklander #endif /* MBEDTLS_DHM_C */ 210*817466cbSJens Wiklander 211*817466cbSJens Wiklander #if defined(MBEDTLS_ECP_C) 212*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_BAD_INPUT_DATA) ) 213*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Bad input parameters to function" ); 214*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_BUFFER_TOO_SMALL) ) 215*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - The buffer is too small to write to" ); 216*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_FEATURE_UNAVAILABLE) ) 217*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Requested curve not available" ); 218*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_VERIFY_FAILED) ) 219*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - The signature is not valid" ); 220*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_ALLOC_FAILED) ) 221*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Memory allocation failed" ); 222*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_RANDOM_FAILED) ) 223*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Generation of random value, such as (ephemeral) key, failed" ); 224*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_INVALID_KEY) ) 225*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Invalid private or public key" ); 226*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ECP_SIG_LEN_MISMATCH) ) 227*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ECP - Signature is valid but shorter than the user-supplied length" ); 228*817466cbSJens Wiklander #endif /* MBEDTLS_ECP_C */ 229*817466cbSJens Wiklander 230*817466cbSJens Wiklander #if defined(MBEDTLS_MD_C) 231*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MD_FEATURE_UNAVAILABLE) ) 232*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "MD - The selected feature is not available" ); 233*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MD_BAD_INPUT_DATA) ) 234*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "MD - Bad input parameters to function" ); 235*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MD_ALLOC_FAILED) ) 236*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "MD - Failed to allocate memory" ); 237*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MD_FILE_IO_ERROR) ) 238*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "MD - Opening or reading of file failed" ); 239*817466cbSJens Wiklander #endif /* MBEDTLS_MD_C */ 240*817466cbSJens Wiklander 241*817466cbSJens Wiklander #if defined(MBEDTLS_PEM_PARSE_C) || defined(MBEDTLS_PEM_WRITE_C) 242*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_NO_HEADER_FOOTER_PRESENT) ) 243*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - No PEM header or footer found" ); 244*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_INVALID_DATA) ) 245*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - PEM string is not as expected" ); 246*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_ALLOC_FAILED) ) 247*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Failed to allocate memory" ); 248*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_INVALID_ENC_IV) ) 249*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - RSA IV is not in hex-format" ); 250*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_UNKNOWN_ENC_ALG) ) 251*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Unsupported key encryption algorithm" ); 252*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_PASSWORD_REQUIRED) ) 253*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Private key password can't be empty" ); 254*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_PASSWORD_MISMATCH) ) 255*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Given private key password does not allow for correct decryption" ); 256*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_FEATURE_UNAVAILABLE) ) 257*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Unavailable feature, e.g. hashing/encryption combination" ); 258*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PEM_BAD_INPUT_DATA) ) 259*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PEM - Bad input parameters to function" ); 260*817466cbSJens Wiklander #endif /* MBEDTLS_PEM_PARSE_C || MBEDTLS_PEM_WRITE_C */ 261*817466cbSJens Wiklander 262*817466cbSJens Wiklander #if defined(MBEDTLS_PK_C) 263*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_ALLOC_FAILED) ) 264*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Memory allocation failed" ); 265*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_TYPE_MISMATCH) ) 266*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Type mismatch, eg attempt to encrypt with an ECDSA key" ); 267*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_BAD_INPUT_DATA) ) 268*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Bad input parameters to function" ); 269*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_FILE_IO_ERROR) ) 270*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Read/write of file failed" ); 271*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_KEY_INVALID_VERSION) ) 272*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Unsupported key version" ); 273*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_KEY_INVALID_FORMAT) ) 274*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Invalid key tag or value" ); 275*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_UNKNOWN_PK_ALG) ) 276*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Key algorithm is unsupported (only RSA and EC are supported)" ); 277*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_PASSWORD_REQUIRED) ) 278*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Private key password can't be empty" ); 279*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_PASSWORD_MISMATCH) ) 280*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Given private key password does not allow for correct decryption" ); 281*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_INVALID_PUBKEY) ) 282*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - The pubkey tag or value is invalid (only RSA and EC are supported)" ); 283*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_INVALID_ALG) ) 284*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - The algorithm tag or value is invalid" ); 285*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_UNKNOWN_NAMED_CURVE) ) 286*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Elliptic curve is unsupported (only NIST curves are supported)" ); 287*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_FEATURE_UNAVAILABLE) ) 288*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - Unavailable feature, e.g. RSA disabled for RSA key" ); 289*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PK_SIG_LEN_MISMATCH) ) 290*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PK - The signature is valid but its length is less than expected" ); 291*817466cbSJens Wiklander #endif /* MBEDTLS_PK_C */ 292*817466cbSJens Wiklander 293*817466cbSJens Wiklander #if defined(MBEDTLS_PKCS12_C) 294*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS12_BAD_INPUT_DATA) ) 295*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS12 - Bad input parameters to function" ); 296*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS12_FEATURE_UNAVAILABLE) ) 297*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS12 - Feature not available, e.g. unsupported encryption scheme" ); 298*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS12_PBE_INVALID_FORMAT) ) 299*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS12 - PBE ASN.1 data not as expected" ); 300*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS12_PASSWORD_MISMATCH) ) 301*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS12 - Given private key password does not allow for correct decryption" ); 302*817466cbSJens Wiklander #endif /* MBEDTLS_PKCS12_C */ 303*817466cbSJens Wiklander 304*817466cbSJens Wiklander #if defined(MBEDTLS_PKCS5_C) 305*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS5_BAD_INPUT_DATA) ) 306*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS5 - Bad input parameters to function" ); 307*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS5_INVALID_FORMAT) ) 308*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS5 - Unexpected ASN.1 data" ); 309*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS5_FEATURE_UNAVAILABLE) ) 310*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS5 - Requested encryption or digest alg not available" ); 311*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PKCS5_PASSWORD_MISMATCH) ) 312*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PKCS5 - Given private key password does not allow for correct decryption" ); 313*817466cbSJens Wiklander #endif /* MBEDTLS_PKCS5_C */ 314*817466cbSJens Wiklander 315*817466cbSJens Wiklander #if defined(MBEDTLS_RSA_C) 316*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_BAD_INPUT_DATA) ) 317*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - Bad input parameters to function" ); 318*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_INVALID_PADDING) ) 319*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - Input data contains invalid padding and is rejected" ); 320*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_KEY_GEN_FAILED) ) 321*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - Something failed during generation of a key" ); 322*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_KEY_CHECK_FAILED) ) 323*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - Key failed to pass the library's validity check" ); 324*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_PUBLIC_FAILED) ) 325*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - The public key operation failed" ); 326*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_PRIVATE_FAILED) ) 327*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - The private key operation failed" ); 328*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_VERIFY_FAILED) ) 329*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - The PKCS#1 verification failed" ); 330*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_OUTPUT_TOO_LARGE) ) 331*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - The output buffer for decryption is not large enough" ); 332*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_RSA_RNG_FAILED) ) 333*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "RSA - The random generator failed to generate non-zeros" ); 334*817466cbSJens Wiklander #endif /* MBEDTLS_RSA_C */ 335*817466cbSJens Wiklander 336*817466cbSJens Wiklander #if defined(MBEDTLS_SSL_TLS_C) 337*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_FEATURE_UNAVAILABLE) ) 338*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The requested feature is not available" ); 339*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_INPUT_DATA) ) 340*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Bad input parameters to function" ); 341*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_INVALID_MAC) ) 342*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Verification of the message MAC failed" ); 343*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_INVALID_RECORD) ) 344*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - An invalid SSL record was received" ); 345*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_CONN_EOF) ) 346*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The connection indicated an EOF" ); 347*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_UNKNOWN_CIPHER) ) 348*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - An unknown cipher was received" ); 349*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_NO_CIPHER_CHOSEN) ) 350*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The server has no ciphersuites in common with the client" ); 351*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_NO_RNG) ) 352*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - No RNG was provided to the SSL module" ); 353*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_NO_CLIENT_CERTIFICATE) ) 354*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - No client certification received from the client, but required by the authentication mode" ); 355*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_CERTIFICATE_TOO_LARGE) ) 356*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Our own certificate(s) is/are too large to send in an SSL message" ); 357*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_CERTIFICATE_REQUIRED) ) 358*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The own certificate is not set, but needed by the server" ); 359*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_PRIVATE_KEY_REQUIRED) ) 360*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The own private key or pre-shared key is not set, but needed" ); 361*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_CA_CHAIN_REQUIRED) ) 362*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - No CA Chain is set, but required to operate" ); 363*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_UNEXPECTED_MESSAGE) ) 364*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - An unexpected message was received from our peer" ); 365*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_FATAL_ALERT_MESSAGE) ) 366*817466cbSJens Wiklander { 367*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - A fatal alert message was received from our peer" ); 368*817466cbSJens Wiklander return; 369*817466cbSJens Wiklander } 370*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_PEER_VERIFY_FAILED) ) 371*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Verification of our peer failed" ); 372*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_PEER_CLOSE_NOTIFY) ) 373*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The peer notified us that the connection is going to be closed" ); 374*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CLIENT_HELLO) ) 375*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ClientHello handshake message failed" ); 376*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_SERVER_HELLO) ) 377*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ServerHello handshake message failed" ); 378*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CERTIFICATE) ) 379*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the Certificate handshake message failed" ); 380*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CERTIFICATE_REQUEST) ) 381*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the CertificateRequest handshake message failed" ); 382*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_SERVER_KEY_EXCHANGE) ) 383*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ServerKeyExchange handshake message failed" ); 384*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_SERVER_HELLO_DONE) ) 385*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ServerHelloDone handshake message failed" ); 386*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE) ) 387*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ClientKeyExchange handshake message failed" ); 388*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE_RP) ) 389*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ClientKeyExchange handshake message failed in DHM / ECDH Read Public" ); 390*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE_CS) ) 391*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ClientKeyExchange handshake message failed in DHM / ECDH Calculate Secret" ); 392*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CERTIFICATE_VERIFY) ) 393*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the CertificateVerify handshake message failed" ); 394*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_CHANGE_CIPHER_SPEC) ) 395*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the ChangeCipherSpec handshake message failed" ); 396*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_FINISHED) ) 397*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the Finished handshake message failed" ); 398*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_ALLOC_FAILED) ) 399*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Memory allocation failed" ); 400*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_HW_ACCEL_FAILED) ) 401*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Hardware acceleration function returned with error" ); 402*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_HW_ACCEL_FALLTHROUGH) ) 403*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Hardware acceleration function skipped / left alone data" ); 404*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_COMPRESSION_FAILED) ) 405*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the compression / decompression failed" ); 406*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_PROTOCOL_VERSION) ) 407*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Handshake protocol not within min/max boundaries" ); 408*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BAD_HS_NEW_SESSION_TICKET) ) 409*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Processing of the NewSessionTicket handshake message failed" ); 410*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_SESSION_TICKET_EXPIRED) ) 411*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Session ticket has expired" ); 412*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_PK_TYPE_MISMATCH) ) 413*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Public key type mismatch (eg, asked for RSA key exchange and presented EC key)" ); 414*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_UNKNOWN_IDENTITY) ) 415*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Unknown identity received (eg, PSK identity)" ); 416*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_INTERNAL_ERROR) ) 417*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Internal error (eg, unexpected failure in lower-level module)" ); 418*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_COUNTER_WRAPPING) ) 419*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - A counter would wrap (eg, too many messages exchanged)" ); 420*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_WAITING_SERVER_HELLO_RENEGO) ) 421*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Unexpected message at ServerHello in renegotiation" ); 422*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_HELLO_VERIFY_REQUIRED) ) 423*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - DTLS client must retry for hello verification" ); 424*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_BUFFER_TOO_SMALL) ) 425*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - A buffer is too small to receive or write a message" ); 426*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_NO_USABLE_CIPHERSUITE) ) 427*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - None of the common ciphersuites is usable (eg, no suitable certificate, see debug messages)" ); 428*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_WANT_READ) ) 429*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Connection requires a read call" ); 430*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_WANT_WRITE) ) 431*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Connection requires a write call" ); 432*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_TIMEOUT) ) 433*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The operation timed out" ); 434*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_CLIENT_RECONNECT) ) 435*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The client initiated a reconnect from the same port" ); 436*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_UNEXPECTED_RECORD) ) 437*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Record header looks valid but is not expected" ); 438*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_NON_FATAL) ) 439*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - The alert message received indicates a non-fatal error" ); 440*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_SSL_INVALID_VERIFY_HASH) ) 441*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "SSL - Couldn't set the hash for verifying CertificateVerify" ); 442*817466cbSJens Wiklander #endif /* MBEDTLS_SSL_TLS_C */ 443*817466cbSJens Wiklander 444*817466cbSJens Wiklander #if defined(MBEDTLS_X509_USE_C) || defined(MBEDTLS_X509_CREATE_C) 445*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_FEATURE_UNAVAILABLE) ) 446*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Unavailable feature, e.g. RSA hashing/encryption combination" ); 447*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_UNKNOWN_OID) ) 448*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Requested OID is unknown" ); 449*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_FORMAT) ) 450*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The CRT/CRL/CSR format is invalid, e.g. different type expected" ); 451*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_VERSION) ) 452*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The CRT/CRL/CSR version element is invalid" ); 453*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_SERIAL) ) 454*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The serial tag or value is invalid" ); 455*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_ALG) ) 456*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The algorithm tag or value is invalid" ); 457*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_NAME) ) 458*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The name tag or value is invalid" ); 459*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_DATE) ) 460*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The date tag or value is invalid" ); 461*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_SIGNATURE) ) 462*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The signature tag or value invalid" ); 463*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_INVALID_EXTENSIONS) ) 464*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - The extension tag or value is invalid" ); 465*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_UNKNOWN_VERSION) ) 466*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - CRT/CRL/CSR has an unsupported version number" ); 467*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_UNKNOWN_SIG_ALG) ) 468*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Signature algorithm (oid) is unsupported" ); 469*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_SIG_MISMATCH) ) 470*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Signature algorithms do not match. (see \\c ::mbedtls_x509_crt sig_oid)" ); 471*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_CERT_VERIFY_FAILED) ) 472*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Certificate verification failed, e.g. CRL, CA or signature check failed" ); 473*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_CERT_UNKNOWN_FORMAT) ) 474*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Format not recognized as DER or PEM" ); 475*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_BAD_INPUT_DATA) ) 476*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Input invalid" ); 477*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_ALLOC_FAILED) ) 478*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Allocation of memory failed" ); 479*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_FILE_IO_ERROR) ) 480*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Read/write of file failed" ); 481*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_BUFFER_TOO_SMALL) ) 482*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - Destination buffer is too small" ); 483*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_X509_FATAL_ERROR) ) 484*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "X509 - A fatal error occured, eg the chain is too long or the vrfy callback failed" ); 485*817466cbSJens Wiklander #endif /* MBEDTLS_X509_USE_C || MBEDTLS_X509_CREATE_C */ 486*817466cbSJens Wiklander // END generated code 487*817466cbSJens Wiklander 488*817466cbSJens Wiklander if( strlen( buf ) == 0 ) 489*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "UNKNOWN ERROR CODE (%04X)", use_ret ); 490*817466cbSJens Wiklander } 491*817466cbSJens Wiklander 492*817466cbSJens Wiklander use_ret = ret & ~0xFF80; 493*817466cbSJens Wiklander 494*817466cbSJens Wiklander if( use_ret == 0 ) 495*817466cbSJens Wiklander return; 496*817466cbSJens Wiklander 497*817466cbSJens Wiklander // If high level code is present, make a concatenation between both 498*817466cbSJens Wiklander // error strings. 499*817466cbSJens Wiklander // 500*817466cbSJens Wiklander len = strlen( buf ); 501*817466cbSJens Wiklander 502*817466cbSJens Wiklander if( len > 0 ) 503*817466cbSJens Wiklander { 504*817466cbSJens Wiklander if( buflen - len < 5 ) 505*817466cbSJens Wiklander return; 506*817466cbSJens Wiklander 507*817466cbSJens Wiklander mbedtls_snprintf( buf + len, buflen - len, " : " ); 508*817466cbSJens Wiklander 509*817466cbSJens Wiklander buf += len + 3; 510*817466cbSJens Wiklander buflen -= len + 3; 511*817466cbSJens Wiklander } 512*817466cbSJens Wiklander 513*817466cbSJens Wiklander // Low level error codes 514*817466cbSJens Wiklander // 515*817466cbSJens Wiklander // BEGIN generated code 516*817466cbSJens Wiklander #if defined(MBEDTLS_AES_C) 517*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_AES_INVALID_KEY_LENGTH) ) 518*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "AES - Invalid key length" ); 519*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_AES_INVALID_INPUT_LENGTH) ) 520*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "AES - Invalid data input length" ); 521*817466cbSJens Wiklander #endif /* MBEDTLS_AES_C */ 522*817466cbSJens Wiklander 523*817466cbSJens Wiklander #if defined(MBEDTLS_ASN1_PARSE_C) 524*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_OUT_OF_DATA) ) 525*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Out of data when parsing an ASN1 data structure" ); 526*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_UNEXPECTED_TAG) ) 527*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - ASN1 tag was of an unexpected value" ); 528*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_INVALID_LENGTH) ) 529*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Error when trying to determine the length or invalid length" ); 530*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_LENGTH_MISMATCH) ) 531*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Actual length differs from expected length" ); 532*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_INVALID_DATA) ) 533*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Data is invalid. (not used)" ); 534*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_ALLOC_FAILED) ) 535*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Memory allocation failed" ); 536*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ASN1_BUF_TOO_SMALL) ) 537*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ASN1 - Buffer too small when writing ASN.1 data structure" ); 538*817466cbSJens Wiklander #endif /* MBEDTLS_ASN1_PARSE_C */ 539*817466cbSJens Wiklander 540*817466cbSJens Wiklander #if defined(MBEDTLS_BASE64_C) 541*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_BASE64_BUFFER_TOO_SMALL) ) 542*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BASE64 - Output buffer too small" ); 543*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_BASE64_INVALID_CHARACTER) ) 544*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BASE64 - Invalid character in input" ); 545*817466cbSJens Wiklander #endif /* MBEDTLS_BASE64_C */ 546*817466cbSJens Wiklander 547*817466cbSJens Wiklander #if defined(MBEDTLS_BIGNUM_C) 548*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_FILE_IO_ERROR) ) 549*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - An error occurred while reading from or writing to a file" ); 550*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_BAD_INPUT_DATA) ) 551*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - Bad input parameters to function" ); 552*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_INVALID_CHARACTER) ) 553*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - There is an invalid character in the digit string" ); 554*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_BUFFER_TOO_SMALL) ) 555*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - The buffer is too small to write to" ); 556*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_NEGATIVE_VALUE) ) 557*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - The input arguments are negative or result in illegal output" ); 558*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_DIVISION_BY_ZERO) ) 559*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - The input argument for division is zero, which is not allowed" ); 560*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_NOT_ACCEPTABLE) ) 561*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - The input arguments are not acceptable" ); 562*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_MPI_ALLOC_FAILED) ) 563*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BIGNUM - Memory allocation failed" ); 564*817466cbSJens Wiklander #endif /* MBEDTLS_BIGNUM_C */ 565*817466cbSJens Wiklander 566*817466cbSJens Wiklander #if defined(MBEDTLS_BLOWFISH_C) 567*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_BLOWFISH_INVALID_KEY_LENGTH) ) 568*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BLOWFISH - Invalid key length" ); 569*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_BLOWFISH_INVALID_INPUT_LENGTH) ) 570*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "BLOWFISH - Invalid data input length" ); 571*817466cbSJens Wiklander #endif /* MBEDTLS_BLOWFISH_C */ 572*817466cbSJens Wiklander 573*817466cbSJens Wiklander #if defined(MBEDTLS_CAMELLIA_C) 574*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CAMELLIA_INVALID_KEY_LENGTH) ) 575*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CAMELLIA - Invalid key length" ); 576*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CAMELLIA_INVALID_INPUT_LENGTH) ) 577*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CAMELLIA - Invalid data input length" ); 578*817466cbSJens Wiklander #endif /* MBEDTLS_CAMELLIA_C */ 579*817466cbSJens Wiklander 580*817466cbSJens Wiklander #if defined(MBEDTLS_CCM_C) 581*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CCM_BAD_INPUT) ) 582*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CCM - Bad input parameters to function" ); 583*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CCM_AUTH_FAILED) ) 584*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CCM - Authenticated decryption failed" ); 585*817466cbSJens Wiklander #endif /* MBEDTLS_CCM_C */ 586*817466cbSJens Wiklander 587*817466cbSJens Wiklander #if defined(MBEDTLS_CTR_DRBG_C) 588*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CTR_DRBG_ENTROPY_SOURCE_FAILED) ) 589*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CTR_DRBG - The entropy source failed" ); 590*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CTR_DRBG_REQUEST_TOO_BIG) ) 591*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CTR_DRBG - Too many random requested in single call" ); 592*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CTR_DRBG_INPUT_TOO_BIG) ) 593*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CTR_DRBG - Input too large (Entropy + additional)" ); 594*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_CTR_DRBG_FILE_IO_ERROR) ) 595*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "CTR_DRBG - Read/write error in file" ); 596*817466cbSJens Wiklander #endif /* MBEDTLS_CTR_DRBG_C */ 597*817466cbSJens Wiklander 598*817466cbSJens Wiklander #if defined(MBEDTLS_DES_C) 599*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_DES_INVALID_INPUT_LENGTH) ) 600*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "DES - The data input has an invalid length" ); 601*817466cbSJens Wiklander #endif /* MBEDTLS_DES_C */ 602*817466cbSJens Wiklander 603*817466cbSJens Wiklander #if defined(MBEDTLS_ENTROPY_C) 604*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ENTROPY_SOURCE_FAILED) ) 605*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ENTROPY - Critical entropy source failure" ); 606*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ENTROPY_MAX_SOURCES) ) 607*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ENTROPY - No more sources can be added" ); 608*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ENTROPY_NO_SOURCES_DEFINED) ) 609*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ENTROPY - No sources have been added to poll" ); 610*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ENTROPY_NO_STRONG_SOURCE) ) 611*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ENTROPY - No strong sources have been added to poll" ); 612*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_ENTROPY_FILE_IO_ERROR) ) 613*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "ENTROPY - Read/write error in file" ); 614*817466cbSJens Wiklander #endif /* MBEDTLS_ENTROPY_C */ 615*817466cbSJens Wiklander 616*817466cbSJens Wiklander #if defined(MBEDTLS_GCM_C) 617*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_GCM_AUTH_FAILED) ) 618*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "GCM - Authenticated decryption failed" ); 619*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_GCM_BAD_INPUT) ) 620*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "GCM - Bad input parameters to function" ); 621*817466cbSJens Wiklander #endif /* MBEDTLS_GCM_C */ 622*817466cbSJens Wiklander 623*817466cbSJens Wiklander #if defined(MBEDTLS_HMAC_DRBG_C) 624*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_HMAC_DRBG_REQUEST_TOO_BIG) ) 625*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "HMAC_DRBG - Too many random requested in single call" ); 626*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_HMAC_DRBG_INPUT_TOO_BIG) ) 627*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "HMAC_DRBG - Input too large (Entropy + additional)" ); 628*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_HMAC_DRBG_FILE_IO_ERROR) ) 629*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "HMAC_DRBG - Read/write error in file" ); 630*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_HMAC_DRBG_ENTROPY_SOURCE_FAILED) ) 631*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "HMAC_DRBG - The entropy source failed" ); 632*817466cbSJens Wiklander #endif /* MBEDTLS_HMAC_DRBG_C */ 633*817466cbSJens Wiklander 634*817466cbSJens Wiklander #if defined(MBEDTLS_NET_C) 635*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_SOCKET_FAILED) ) 636*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Failed to open a socket" ); 637*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_CONNECT_FAILED) ) 638*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - The connection to the given server / port failed" ); 639*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_BIND_FAILED) ) 640*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Binding of the socket failed" ); 641*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_LISTEN_FAILED) ) 642*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Could not listen on the socket" ); 643*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_ACCEPT_FAILED) ) 644*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Could not accept the incoming connection" ); 645*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_RECV_FAILED) ) 646*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Reading information from the socket failed" ); 647*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_SEND_FAILED) ) 648*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Sending information through the socket failed" ); 649*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_CONN_RESET) ) 650*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Connection was reset by peer" ); 651*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_UNKNOWN_HOST) ) 652*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Failed to get an IP address for the given hostname" ); 653*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_BUFFER_TOO_SMALL) ) 654*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - Buffer is too small to hold the data" ); 655*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_NET_INVALID_CONTEXT) ) 656*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "NET - The context is invalid, eg because it was free()ed" ); 657*817466cbSJens Wiklander #endif /* MBEDTLS_NET_C */ 658*817466cbSJens Wiklander 659*817466cbSJens Wiklander #if defined(MBEDTLS_OID_C) 660*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_OID_NOT_FOUND) ) 661*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "OID - OID is not found" ); 662*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_OID_BUF_TOO_SMALL) ) 663*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "OID - output buffer is too small" ); 664*817466cbSJens Wiklander #endif /* MBEDTLS_OID_C */ 665*817466cbSJens Wiklander 666*817466cbSJens Wiklander #if defined(MBEDTLS_PADLOCK_C) 667*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_PADLOCK_DATA_MISALIGNED) ) 668*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "PADLOCK - Input data should be aligned" ); 669*817466cbSJens Wiklander #endif /* MBEDTLS_PADLOCK_C */ 670*817466cbSJens Wiklander 671*817466cbSJens Wiklander #if defined(MBEDTLS_THREADING_C) 672*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_THREADING_FEATURE_UNAVAILABLE) ) 673*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "THREADING - The selected feature is not available" ); 674*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_THREADING_BAD_INPUT_DATA) ) 675*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "THREADING - Bad input parameters to function" ); 676*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_THREADING_MUTEX_ERROR) ) 677*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "THREADING - Locking / unlocking / free failed with error code" ); 678*817466cbSJens Wiklander #endif /* MBEDTLS_THREADING_C */ 679*817466cbSJens Wiklander 680*817466cbSJens Wiklander #if defined(MBEDTLS_XTEA_C) 681*817466cbSJens Wiklander if( use_ret == -(MBEDTLS_ERR_XTEA_INVALID_INPUT_LENGTH) ) 682*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "XTEA - The data input has an invalid length" ); 683*817466cbSJens Wiklander #endif /* MBEDTLS_XTEA_C */ 684*817466cbSJens Wiklander // END generated code 685*817466cbSJens Wiklander 686*817466cbSJens Wiklander if( strlen( buf ) != 0 ) 687*817466cbSJens Wiklander return; 688*817466cbSJens Wiklander 689*817466cbSJens Wiklander mbedtls_snprintf( buf, buflen, "UNKNOWN ERROR CODE (%04X)", use_ret ); 690*817466cbSJens Wiklander } 691*817466cbSJens Wiklander 692*817466cbSJens Wiklander #else /* MBEDTLS_ERROR_C */ 693*817466cbSJens Wiklander 694*817466cbSJens Wiklander #if defined(MBEDTLS_ERROR_STRERROR_DUMMY) 695*817466cbSJens Wiklander 696*817466cbSJens Wiklander /* 697*817466cbSJens Wiklander * Provide an non-function in case MBEDTLS_ERROR_C is not defined 698*817466cbSJens Wiklander */ 699*817466cbSJens Wiklander void mbedtls_strerror( int ret, char *buf, size_t buflen ) 700*817466cbSJens Wiklander { 701*817466cbSJens Wiklander ((void) ret); 702*817466cbSJens Wiklander 703*817466cbSJens Wiklander if( buflen > 0 ) 704*817466cbSJens Wiklander buf[0] = '\0'; 705*817466cbSJens Wiklander } 706*817466cbSJens Wiklander 707*817466cbSJens Wiklander #endif /* MBEDTLS_ERROR_STRERROR_DUMMY */ 708*817466cbSJens Wiklander 709*817466cbSJens Wiklander #endif /* MBEDTLS_ERROR_C */ 710