Fix unchecked error codes in ecp_gen_keypair()
This commit is contained in:
parent
fae079e4c5
commit
c9573998ca
1 changed files with 14 additions and 9 deletions
|
@ -1742,6 +1742,7 @@ int ecp_gen_keypair( ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
int (*f_rng)(void *, unsigned char *, size_t),
|
int (*f_rng)(void *, unsigned char *, size_t),
|
||||||
void *p_rng )
|
void *p_rng )
|
||||||
{
|
{
|
||||||
|
int ret;
|
||||||
size_t n_size = (grp->nbits + 7) / 8;
|
size_t n_size = (grp->nbits + 7) / 8;
|
||||||
|
|
||||||
#if defined(POLARSSL_ECP_MONTGOMERY)
|
#if defined(POLARSSL_ECP_MONTGOMERY)
|
||||||
|
@ -1750,19 +1751,19 @@ int ecp_gen_keypair( ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
/* [M225] page 5 */
|
/* [M225] page 5 */
|
||||||
size_t b;
|
size_t b;
|
||||||
|
|
||||||
mpi_fill_random( d, n_size, f_rng, p_rng );
|
MPI_CHK( mpi_fill_random( d, n_size, f_rng, p_rng ) );
|
||||||
|
|
||||||
/* Make sure the most significant bit is nbits */
|
/* Make sure the most significant bit is nbits */
|
||||||
b = mpi_msb( d ) - 1; /* mpi_msb is one-based */
|
b = mpi_msb( d ) - 1; /* mpi_msb is one-based */
|
||||||
if( b > grp->nbits )
|
if( b > grp->nbits )
|
||||||
mpi_shift_r( d, b - grp->nbits );
|
MPI_CHK( mpi_shift_r( d, b - grp->nbits ) );
|
||||||
else
|
else
|
||||||
mpi_set_bit( d, grp->nbits, 1 );
|
MPI_CHK( mpi_set_bit( d, grp->nbits, 1 ) );
|
||||||
|
|
||||||
/* Make sure the last three bits are unset */
|
/* Make sure the last three bits are unset */
|
||||||
mpi_set_bit( d, 0, 0 );
|
MPI_CHK( mpi_set_bit( d, 0, 0 ) );
|
||||||
mpi_set_bit( d, 1, 0 );
|
MPI_CHK( mpi_set_bit( d, 1, 0 ) );
|
||||||
mpi_set_bit( d, 2, 0 );
|
MPI_CHK( mpi_set_bit( d, 2, 0 ) );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
|
@ -1782,9 +1783,9 @@ int ecp_gen_keypair( ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
*/
|
*/
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
f_rng( p_rng, rnd, n_size );
|
MPI_CHK( f_rng( p_rng, rnd, n_size ) );
|
||||||
mpi_read_binary( d, rnd, n_size );
|
MPI_CHK( mpi_read_binary( d, rnd, n_size ) );
|
||||||
mpi_shift_r( d, 8 * n_size - grp->nbits );
|
MPI_CHK( mpi_shift_r( d, 8 * n_size - grp->nbits ) );
|
||||||
|
|
||||||
if( count++ > 10 )
|
if( count++ > 10 )
|
||||||
return( POLARSSL_ERR_ECP_RANDOM_FAILED );
|
return( POLARSSL_ERR_ECP_RANDOM_FAILED );
|
||||||
|
@ -1796,6 +1797,10 @@ int ecp_gen_keypair( ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
#endif
|
#endif
|
||||||
return( POLARSSL_ERR_ECP_BAD_INPUT_DATA );
|
return( POLARSSL_ERR_ECP_BAD_INPUT_DATA );
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
if( ret != 0 )
|
||||||
|
return( ret );
|
||||||
|
|
||||||
return( ecp_mul( grp, Q, d, &grp->G, f_rng, p_rng ) );
|
return( ecp_mul( grp, Q, d, &grp->G, f_rng, p_rng ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue