rsa_alt_helpers.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. /**
  2. * \file rsa_alt_helpers.h
  3. *
  4. * \brief Context-independent RSA helper functions
  5. *
  6. * This module declares some RSA-related helper functions useful when
  7. * implementing the RSA interface. These functions are provided in a separate
  8. * compilation unit in order to make it easy for designers of alternative RSA
  9. * implementations to use them in their own code, as it is conceived that the
  10. * functionality they provide will be necessary for most complete
  11. * implementations.
  12. *
  13. * End-users of Mbed TLS who are not providing their own alternative RSA
  14. * implementations should not use these functions directly, and should instead
  15. * use only the functions declared in rsa.h.
  16. *
  17. * The interface provided by this module will be maintained through LTS (Long
  18. * Term Support) branches of Mbed TLS, but may otherwise be subject to change,
  19. * and must be considered an internal interface of the library.
  20. *
  21. * There are two classes of helper functions:
  22. *
  23. * (1) Parameter-generating helpers. These are:
  24. * - mbedtls_rsa_deduce_primes
  25. * - mbedtls_rsa_deduce_private_exponent
  26. * - mbedtls_rsa_deduce_crt
  27. * Each of these functions takes a set of core RSA parameters and
  28. * generates some other, or CRT related parameters.
  29. *
  30. * (2) Parameter-checking helpers. These are:
  31. * - mbedtls_rsa_validate_params
  32. * - mbedtls_rsa_validate_crt
  33. * They take a set of core or CRT related RSA parameters and check their
  34. * validity.
  35. *
  36. */
  37. /*
  38. * Copyright The Mbed TLS Contributors
  39. * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
  40. */
  41. #ifndef MBEDTLS_RSA_ALT_HELPERS_H
  42. #define MBEDTLS_RSA_ALT_HELPERS_H
  43. #include "mbedtls/build_info.h"
  44. #include "mbedtls/bignum.h"
  45. #ifdef __cplusplus
  46. extern "C" {
  47. #endif
  48. /**
  49. * \brief Compute RSA prime moduli P, Q from public modulus N=PQ
  50. * and a pair of private and public key.
  51. *
  52. * \note This is a 'static' helper function not operating on
  53. * an RSA context. Alternative implementations need not
  54. * overwrite it.
  55. *
  56. * \param N RSA modulus N = PQ, with P, Q to be found
  57. * \param E RSA public exponent
  58. * \param D RSA private exponent
  59. * \param P Pointer to MPI holding first prime factor of N on success
  60. * \param Q Pointer to MPI holding second prime factor of N on success
  61. *
  62. * \return
  63. * - 0 if successful. In this case, P and Q constitute a
  64. * factorization of N.
  65. * - A non-zero error code otherwise.
  66. *
  67. * \note It is neither checked that P, Q are prime nor that
  68. * D, E are modular inverses wrt. P-1 and Q-1. For that,
  69. * use the helper function \c mbedtls_rsa_validate_params.
  70. *
  71. */
  72. int mbedtls_rsa_deduce_primes(mbedtls_mpi const *N, mbedtls_mpi const *E,
  73. mbedtls_mpi const *D,
  74. mbedtls_mpi *P, mbedtls_mpi *Q);
  75. /**
  76. * \brief Compute RSA private exponent from
  77. * prime moduli and public key.
  78. *
  79. * \note This is a 'static' helper function not operating on
  80. * an RSA context. Alternative implementations need not
  81. * overwrite it.
  82. *
  83. * \param P First prime factor of RSA modulus
  84. * \param Q Second prime factor of RSA modulus
  85. * \param E RSA public exponent
  86. * \param D Pointer to MPI holding the private exponent on success.
  87. *
  88. * \return
  89. * - 0 if successful. In this case, D is set to a simultaneous
  90. * modular inverse of E modulo both P-1 and Q-1.
  91. * - A non-zero error code otherwise.
  92. *
  93. * \note This function does not check whether P and Q are primes.
  94. *
  95. */
  96. int mbedtls_rsa_deduce_private_exponent(mbedtls_mpi const *P,
  97. mbedtls_mpi const *Q,
  98. mbedtls_mpi const *E,
  99. mbedtls_mpi *D);
  100. /**
  101. * \brief Generate RSA-CRT parameters
  102. *
  103. * \note This is a 'static' helper function not operating on
  104. * an RSA context. Alternative implementations need not
  105. * overwrite it.
  106. *
  107. * \param P First prime factor of N
  108. * \param Q Second prime factor of N
  109. * \param D RSA private exponent
  110. * \param DP Output variable for D modulo P-1
  111. * \param DQ Output variable for D modulo Q-1
  112. * \param QP Output variable for the modular inverse of Q modulo P.
  113. *
  114. * \return 0 on success, non-zero error code otherwise.
  115. *
  116. * \note This function does not check whether P, Q are
  117. * prime and whether D is a valid private exponent.
  118. *
  119. */
  120. int mbedtls_rsa_deduce_crt(const mbedtls_mpi *P, const mbedtls_mpi *Q,
  121. const mbedtls_mpi *D, mbedtls_mpi *DP,
  122. mbedtls_mpi *DQ, mbedtls_mpi *QP);
  123. /**
  124. * \brief Check validity of core RSA parameters
  125. *
  126. * \note This is a 'static' helper function not operating on
  127. * an RSA context. Alternative implementations need not
  128. * overwrite it.
  129. *
  130. * \param N RSA modulus N = PQ
  131. * \param P First prime factor of N
  132. * \param Q Second prime factor of N
  133. * \param D RSA private exponent
  134. * \param E RSA public exponent
  135. * \param f_rng PRNG to be used for primality check, or NULL
  136. * \param p_rng PRNG context for f_rng, or NULL
  137. *
  138. * \return
  139. * - 0 if the following conditions are satisfied
  140. * if all relevant parameters are provided:
  141. * - P prime if f_rng != NULL (%)
  142. * - Q prime if f_rng != NULL (%)
  143. * - 1 < N = P * Q
  144. * - 1 < D, E < N
  145. * - D and E are modular inverses modulo P-1 and Q-1
  146. * (%) This is only done if MBEDTLS_GENPRIME is defined.
  147. * - A non-zero error code otherwise.
  148. *
  149. * \note The function can be used with a restricted set of arguments
  150. * to perform specific checks only. E.g., calling it with
  151. * (-,P,-,-,-) and a PRNG amounts to a primality check for P.
  152. */
  153. int mbedtls_rsa_validate_params(const mbedtls_mpi *N, const mbedtls_mpi *P,
  154. const mbedtls_mpi *Q, const mbedtls_mpi *D,
  155. const mbedtls_mpi *E,
  156. int (*f_rng)(void *, unsigned char *, size_t),
  157. void *p_rng);
  158. /**
  159. * \brief Check validity of RSA CRT parameters
  160. *
  161. * \note This is a 'static' helper function not operating on
  162. * an RSA context. Alternative implementations need not
  163. * overwrite it.
  164. *
  165. * \param P First prime factor of RSA modulus
  166. * \param Q Second prime factor of RSA modulus
  167. * \param D RSA private exponent
  168. * \param DP MPI to check for D modulo P-1
  169. * \param DQ MPI to check for D modulo P-1
  170. * \param QP MPI to check for the modular inverse of Q modulo P.
  171. *
  172. * \return
  173. * - 0 if the following conditions are satisfied:
  174. * - D = DP mod P-1 if P, D, DP != NULL
  175. * - Q = DQ mod P-1 if P, D, DQ != NULL
  176. * - QP = Q^-1 mod P if P, Q, QP != NULL
  177. * - \c MBEDTLS_ERR_RSA_KEY_CHECK_FAILED if check failed,
  178. * potentially including \c MBEDTLS_ERR_MPI_XXX if some
  179. * MPI calculations failed.
  180. * - \c MBEDTLS_ERR_RSA_BAD_INPUT_DATA if insufficient
  181. * data was provided to check DP, DQ or QP.
  182. *
  183. * \note The function can be used with a restricted set of arguments
  184. * to perform specific checks only. E.g., calling it with the
  185. * parameters (P, -, D, DP, -, -) will check DP = D mod P-1.
  186. */
  187. int mbedtls_rsa_validate_crt(const mbedtls_mpi *P, const mbedtls_mpi *Q,
  188. const mbedtls_mpi *D, const mbedtls_mpi *DP,
  189. const mbedtls_mpi *DQ, const mbedtls_mpi *QP);
  190. #ifdef __cplusplus
  191. }
  192. #endif
  193. #endif /* rsa_alt_helpers.h */