Add ecp_gen_keypair()
This commit is contained in:
parent
cf4365f560
commit
45a035a9ac
4 changed files with 73 additions and 0 deletions
|
@ -309,6 +309,22 @@ int ecp_sub( const ecp_group *grp, ecp_point *R,
|
||||||
int ecp_mul( const ecp_group *grp, ecp_point *R,
|
int ecp_mul( const ecp_group *grp, ecp_point *R,
|
||||||
const mpi *m, const ecp_point *P );
|
const mpi *m, const ecp_point *P );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* \brief Generate a keypair
|
||||||
|
*
|
||||||
|
* \param grp ECP group
|
||||||
|
* \param d Destination MPI (secret part)
|
||||||
|
* \param Q Destination point (public part)
|
||||||
|
* \param f_rng RNG function
|
||||||
|
* \param p_rng RNG parameter
|
||||||
|
*
|
||||||
|
* \return 0 if successful,
|
||||||
|
* or a POLARSSL_ERR_ECP_XXX or POLARSSL_MPI_XXX error code
|
||||||
|
*/
|
||||||
|
int ecp_gen_keypair( const ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
|
int (*f_rng)(void *, unsigned char *, size_t),
|
||||||
|
void *p_rng );
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* \brief Checkup routine
|
* \brief Checkup routine
|
||||||
*
|
*
|
||||||
|
|
|
@ -1127,6 +1127,33 @@ cleanup:
|
||||||
return( ret );
|
return( ret );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Generate a keypair (SEC1 3.2.1)
|
||||||
|
*/
|
||||||
|
int ecp_gen_keypair( const ecp_group *grp, mpi *d, ecp_point *Q,
|
||||||
|
int (*f_rng)(void *, unsigned char *, size_t),
|
||||||
|
void *p_rng )
|
||||||
|
{
|
||||||
|
int count = 0;
|
||||||
|
size_t n_size = (grp->nbits + 7) / 8;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Generate d such that 1 <= n < N
|
||||||
|
*/
|
||||||
|
do
|
||||||
|
{
|
||||||
|
mpi_fill_random( d, n_size, f_rng, p_rng );
|
||||||
|
|
||||||
|
while( mpi_cmp_mpi( d, &grp->N ) >= 0 )
|
||||||
|
mpi_shift_r( d, 1 );
|
||||||
|
|
||||||
|
if( count++ > 10 )
|
||||||
|
return( POLARSSL_ERR_ECP_GENERIC );
|
||||||
|
}
|
||||||
|
while( mpi_cmp_int( d, 1 ) < 0 );
|
||||||
|
|
||||||
|
return( ecp_mul( grp, Q, d, &grp->G ) );
|
||||||
|
}
|
||||||
|
|
||||||
#if defined(POLARSSL_SELF_TEST)
|
#if defined(POLARSSL_SELF_TEST)
|
||||||
|
|
||||||
|
|
|
@ -184,6 +184,9 @@ ecp_read_binary:SECP192R1:"0548d8082a3a1e3112bc03a8ef2f6d40d0a77a6f8e00cc99336ce
|
||||||
ECP read binary #6 (non-zero, OK)
|
ECP read binary #6 (non-zero, OK)
|
||||||
ecp_read_binary:SECP192R1:"0448d8082a3a1e3112bc03a8ef2f6d40d0a77a6f8e00cc99336ceed4d7cba482e288669ee1b6415626d6f34d28501e060c":UNCOMPRESSED:"48d8082a3a1e3112bc03a8ef2f6d40d0a77a6f8e00cc9933":"6ceed4d7cba482e288669ee1b6415626d6f34d28501e060c":"01":0
|
ecp_read_binary:SECP192R1:"0448d8082a3a1e3112bc03a8ef2f6d40d0a77a6f8e00cc99336ceed4d7cba482e288669ee1b6415626d6f34d28501e060c":UNCOMPRESSED:"48d8082a3a1e3112bc03a8ef2f6d40d0a77a6f8e00cc9933":"6ceed4d7cba482e288669ee1b6415626d6f34d28501e060c":"01":0
|
||||||
|
|
||||||
|
ECP gen keypair
|
||||||
|
ecp_gen_keypair:SECP192R1
|
||||||
|
|
||||||
ECP mod p192 readable
|
ECP mod p192 readable
|
||||||
ecp_fast_mod:SECP192R1:"000000000000010500000000000001040000000000000103000000000000010200000000000001010000000000000100"
|
ecp_fast_mod:SECP192R1:"000000000000010500000000000001040000000000000103000000000000010200000000000001010000000000000100"
|
||||||
|
|
||||||
|
|
|
@ -295,6 +295,33 @@ ecp_read_binary:id:input:format:x:y:z:ret
|
||||||
}
|
}
|
||||||
END_CASE
|
END_CASE
|
||||||
|
|
||||||
|
BEGIN_CASE
|
||||||
|
ecp_gen_keypair:id
|
||||||
|
{
|
||||||
|
ecp_group grp;
|
||||||
|
ecp_point Q;
|
||||||
|
mpi d;
|
||||||
|
rnd_pseudo_info rnd_info;
|
||||||
|
|
||||||
|
ecp_group_init( &grp );
|
||||||
|
ecp_point_init( &Q );
|
||||||
|
mpi_init( &d );
|
||||||
|
memset( &rnd_info, 0x00, sizeof( rnd_pseudo_info ) );
|
||||||
|
|
||||||
|
TEST_ASSERT( ecp_use_known_dp( &grp, POLARSSL_ECP_DP_{id} ) == 0 );
|
||||||
|
|
||||||
|
TEST_ASSERT( ecp_gen_keypair( &grp, &d, &Q, &rnd_pseudo_rand, &rnd_info )
|
||||||
|
== 0 );
|
||||||
|
|
||||||
|
TEST_ASSERT( mpi_cmp_mpi( &d, &grp.N ) < 0 );
|
||||||
|
TEST_ASSERT( mpi_cmp_int( &d, 1 ) >= 0 );
|
||||||
|
|
||||||
|
ecp_group_free( &grp );
|
||||||
|
ecp_point_free( &Q );
|
||||||
|
mpi_free( &d );
|
||||||
|
}
|
||||||
|
END_CASE
|
||||||
|
|
||||||
BEGIN_CASE
|
BEGIN_CASE
|
||||||
ecp_selftest:
|
ecp_selftest:
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue