From 57501ef056585bd52988db296ceb17d09f6a4989 Mon Sep 17 00:00:00 2001 From: Ron Eldor Date: Thu, 12 Jan 2017 14:50:50 +0200 Subject: [PATCH] Backport 1.3: Check rc of mbedtls_mpi_fill_random Add MPI_CHK to check for error value of mpi_fill_random. Backport from Report and fix suggestion by guidovranken in #740 --- ChangeLog | 2 ++ library/dhm.c | 6 +++--- library/ecp.c | 4 ++-- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 43ad0c3ce..081bcf1b6 100644 --- a/ChangeLog +++ b/ChangeLog @@ -11,6 +11,8 @@ Bugfix * Fix resource leak on windows platform, in mbedtls_x509_crt_parse_path. In case of failure, when an error occures, goto cleanup. Found by redplait #590 + * Add MPI_CHK to check for error value of mpi_fill_random. + Backported from a report and fix suggestion by guidovranken in #740 = mbed TLS 1.3.20 branch released 2017-06-21 diff --git a/library/dhm.c b/library/dhm.c index 0a4f82028..48fba2a73 100644 --- a/library/dhm.c +++ b/library/dhm.c @@ -163,7 +163,7 @@ int dhm_make_params( dhm_context *ctx, int x_size, */ do { - mpi_fill_random( &ctx->X, x_size, f_rng, p_rng ); + MPI_CHK( mpi_fill_random( &ctx->X, x_size, f_rng, p_rng ) ); while( mpi_cmp_mpi( &ctx->X, &ctx->P ) >= 0 ) MPI_CHK( mpi_shift_r( &ctx->X, 1 ) ); @@ -249,7 +249,7 @@ int dhm_make_public( dhm_context *ctx, int x_size, */ do { - mpi_fill_random( &ctx->X, x_size, f_rng, p_rng ); + MPI_CHK( mpi_fill_random( &ctx->X, x_size, f_rng, p_rng ) ); while( mpi_cmp_mpi( &ctx->X, &ctx->P ) >= 0 ) MPI_CHK( mpi_shift_r( &ctx->X, 1 ) ); @@ -322,7 +322,7 @@ static int dhm_update_blinding( dhm_context *ctx, count = 0; do { - mpi_fill_random( &ctx->Vi, mpi_size( &ctx->P ), f_rng, p_rng ); + MPI_CHK( mpi_fill_random( &ctx->Vi, mpi_size( &ctx->P ), f_rng, p_rng ) ); while( mpi_cmp_mpi( &ctx->Vi, &ctx->P ) >= 0 ) MPI_CHK( mpi_shift_r( &ctx->Vi, 1 ) ); diff --git a/library/ecp.c b/library/ecp.c index 796452baf..79066dc91 100644 --- a/library/ecp.c +++ b/library/ecp.c @@ -1151,7 +1151,7 @@ static int ecp_randomize_jac( const ecp_group *grp, ecp_point *pt, /* Generate l such that 1 < l < p */ do { - mpi_fill_random( &l, p_size, f_rng, p_rng ); + MPI_CHK( mpi_fill_random( &l, p_size, f_rng, p_rng ) ); while( mpi_cmp_mpi( &l, &grp->P ) >= 0 ) MPI_CHK( mpi_shift_r( &l, 1 ) ); @@ -1536,7 +1536,7 @@ static int ecp_randomize_mxz( const ecp_group *grp, ecp_point *P, /* Generate l such that 1 < l < p */ do { - mpi_fill_random( &l, p_size, f_rng, p_rng ); + MPI_CHK( mpi_fill_random( &l, p_size, f_rng, p_rng ) ); while( mpi_cmp_mpi( &l, &grp->P ) >= 0 ) MPI_CHK( mpi_shift_r( &l, 1 ) );