error.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. /**
  2. * \file error.h
  3. *
  4. * \brief Error to string translation
  5. *
  6. * Copyright (C) 2006-2015, ARM Limited, All Rights Reserved
  7. * SPDX-License-Identifier: GPL-2.0
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License along
  20. * with this program; if not, write to the Free Software Foundation, Inc.,
  21. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
  22. *
  23. * This file is part of mbed TLS (https://tls.mbed.org)
  24. */
  25. #ifndef MBEDTLS_ERROR_H
  26. #define MBEDTLS_ERROR_H
  27. #include <stddef.h>
  28. /**
  29. * Error code layout.
  30. *
  31. * Currently we try to keep all error codes within the negative space of 16
  32. * bits signed integers to support all platforms (-0x0001 - -0x7FFF). In
  33. * addition we'd like to give two layers of information on the error if
  34. * possible.
  35. *
  36. * For that purpose the error codes are segmented in the following manner:
  37. *
  38. * 16 bit error code bit-segmentation
  39. *
  40. * 1 bit - Unused (sign bit)
  41. * 3 bits - High level module ID
  42. * 5 bits - Module-dependent error code
  43. * 7 bits - Low level module errors
  44. *
  45. * For historical reasons, low-level error codes are divided in even and odd,
  46. * even codes were assigned first, and -1 is reserved for other errors.
  47. *
  48. * Low-level module errors (0x0002-0x007E, 0x0003-0x007F)
  49. *
  50. * Module Nr Codes assigned
  51. * MPI 7 0x0002-0x0010
  52. * GCM 2 0x0012-0x0014
  53. * BLOWFISH 2 0x0016-0x0018
  54. * THREADING 3 0x001A-0x001E
  55. * AES 2 0x0020-0x0022
  56. * CAMELLIA 2 0x0024-0x0026
  57. * XTEA 1 0x0028-0x0028
  58. * BASE64 2 0x002A-0x002C
  59. * OID 1 0x002E-0x002E 0x000B-0x000B
  60. * PADLOCK 1 0x0030-0x0030
  61. * DES 1 0x0032-0x0032
  62. * CTR_DBRG 4 0x0034-0x003A
  63. * ENTROPY 3 0x003C-0x0040 0x003D-0x003F
  64. * NET 11 0x0042-0x0052 0x0043-0x0045
  65. * ASN1 7 0x0060-0x006C
  66. * PBKDF2 1 0x007C-0x007C
  67. * HMAC_DRBG 4 0x0003-0x0009
  68. * CCM 2 0x000D-0x000F
  69. *
  70. * High-level module nr (3 bits - 0x0...-0x7...)
  71. * Name ID Nr of Errors
  72. * PEM 1 9
  73. * PKCS#12 1 4 (Started from top)
  74. * X509 2 19
  75. * PKCS5 2 4 (Started from top)
  76. * DHM 3 9
  77. * PK 3 14 (Started from top)
  78. * RSA 4 9
  79. * ECP 4 8 (Started from top)
  80. * MD 5 4
  81. * CIPHER 6 6
  82. * SSL 6 17 (Started from top)
  83. * SSL 7 31
  84. *
  85. * Module dependent error code (5 bits 0x.00.-0x.F8.)
  86. */
  87. #ifdef __cplusplus
  88. extern "C" {
  89. #endif
  90. /**
  91. * \brief Translate a mbed TLS error code into a string representation,
  92. * Result is truncated if necessary and always includes a terminating
  93. * null byte.
  94. *
  95. * \param errnum error code
  96. * \param buffer buffer to place representation in
  97. * \param buflen length of the buffer
  98. */
  99. void mbedtls_strerror( int errnum, char *buffer, size_t buflen );
  100. #ifdef __cplusplus
  101. }
  102. #endif
  103. #endif /* error.h */