mirror of
https://github.com/Mbed-TLS/mbedtls.git
synced 2025-04-23 10:25:35 +03:00
So far we needed it only locally here, but we will need calculating RR for safe unblinding in RSA as well. Signed-off-by: Janos Follath <janos.follath@arm.com>
32 lines
1.1 KiB
C
32 lines
1.1 KiB
C
/**
|
|
* Low level bignum functions
|
|
*
|
|
* Copyright The Mbed TLS Contributors
|
|
* SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
|
|
*/
|
|
|
|
#ifndef MBEDTLS_BIGNUM_INTERNAL_H
|
|
#define MBEDTLS_BIGNUM_INTERNAL_H
|
|
|
|
#include "mbedtls/bignum.h"
|
|
|
|
/**
|
|
* \brief Calculate the square of the Montgomery constant. (Needed
|
|
* for conversion and operations in Montgomery form.)
|
|
*
|
|
* \param[out] X A pointer to the result of the calculation of
|
|
* the square of the Montgomery constant:
|
|
* 2^{2*n*biL} mod N.
|
|
* \param[in] N Little-endian presentation of the modulus, which must be odd.
|
|
*
|
|
* \return 0 if successful.
|
|
* \return #MBEDTLS_ERR_MPI_ALLOC_FAILED if there is not enough space
|
|
* to store the value of Montgomery constant squared.
|
|
* \return #MBEDTLS_ERR_MPI_DIVISION_BY_ZERO if \p N modulus is zero.
|
|
* \return #MBEDTLS_ERR_MPI_NEGATIVE_VALUE if \p N modulus is negative.
|
|
*/
|
|
int mbedtls_mpi_get_mont_r2_unsafe(mbedtls_mpi *X,
|
|
const mbedtls_mpi *N);
|
|
|
|
#endif /* MBEDTLS_BIGNUM_INTERNAL_H */
|