esp_idf_svc::sys

Function mbedtls_mpi_safe_cond_assign

Source
pub unsafe extern "C" fn mbedtls_mpi_safe_cond_assign(
    X: *mut mbedtls_mpi,
    Y: *const mbedtls_mpi,
    assign: u8,
) -> i32
Expand description

\brief Perform a safe conditional copy of MPI which doesn’t reveal whether the condition was true or not.

\param X The MPI to conditionally assign to. This must point to an initialized MPI. \param Y The MPI to be assigned from. This must point to an initialized MPI. \param assign The condition deciding whether to perform the assignment or not. Must be either 0 or 1: * \c 1: Perform the assignment X = Y. * \c 0: Keep the original value of \p X.

\note This function is equivalent to if( assign ) mbedtls_mpi_copy( X, Y ); except that it avoids leaking any information about whether the assignment was done or not (the above code may leak information through branch prediction and/or memory access patterns analysis).

\warning If \p assign is neither 0 nor 1, the result of this function is indeterminate, and the resulting value in \p X might be neither its original value nor the value in \p Y.

\return \c 0 if successful. \return #MBEDTLS_ERR_MPI_ALLOC_FAILED if memory allocation failed. \return Another negative error code on other kinds of failure.