Update dh_genprime program

- no warning
- configurable size
- default to 2048 bits
This commit is contained in:
Manuel Pégourié-Gonnard 2015-07-03 17:18:10 +02:00
parent 78a428dbd0
commit f333174fa1

View file

@ -25,6 +25,7 @@
#endif #endif
#include <stdio.h> #include <stdio.h>
#include <stdlib.h>
#include "polarssl/config.h" #include "polarssl/config.h"
@ -32,11 +33,17 @@
#include "polarssl/entropy.h" #include "polarssl/entropy.h"
#include "polarssl/ctr_drbg.h" #include "polarssl/ctr_drbg.h"
#define USAGE \
"\n usage: dh_genprime param=<>...\n" \
"\n acceprable parameters:\n" \
" bits=%%d default: 2048\n"
#define DFL_BITS 2048
/* /*
* Note: G = 4 is always a quadratic residue mod P, * Note: G = 4 is always a quadratic residue mod P,
* so it is a generator of order Q (with P = 2*Q+1). * so it is a generator of order Q (with P = 2*Q+1).
*/ */
#define DH_P_SIZE 1024
#define GENERATOR "4" #define GENERATOR "4"
#if !defined(POLARSSL_BIGNUM_C) || !defined(POLARSSL_ENTROPY_C) || \ #if !defined(POLARSSL_BIGNUM_C) || !defined(POLARSSL_ENTROPY_C) || \
@ -61,26 +68,43 @@ int main( int argc, char *argv[] )
ctr_drbg_context ctr_drbg; ctr_drbg_context ctr_drbg;
const char *pers = "dh_genprime"; const char *pers = "dh_genprime";
FILE *fout; FILE *fout;
int nbits = DFL_BITS;
((void) argc); int i;
((void) argv); char *p, *q;
mpi_init( &G ); mpi_init( &P ); mpi_init( &Q ); mpi_init( &G ); mpi_init( &P ); mpi_init( &Q );
entropy_init( &entropy ); entropy_init( &entropy );
if( argc == 0 )
{
usage:
printf( USAGE );
return( 1 );
}
for( i = 1; i < argc; i++ )
{
p = argv[i];
if( ( q = strchr( p, '=' ) ) == NULL )
goto usage;
*q++ = '\0';
if( strcmp( p, "bits" ) == 0 )
{
nbits = atoi( q );
if( nbits < 0 || nbits > POLARSSL_MPI_MAX_BITS )
goto usage;
}
else
goto usage;
}
if( ( ret = mpi_read_string( &G, 10, GENERATOR ) ) != 0 ) if( ( ret = mpi_read_string( &G, 10, GENERATOR ) ) != 0 )
{ {
printf( " failed\n ! mpi_read_string returned %d\n", ret ); printf( " failed\n ! mpi_read_string returned %d\n", ret );
goto exit; goto exit;
} }
printf( "\nWARNING: You should not generate and use your own DHM primes\n" );
printf( " unless you are very certain of what you are doing!\n" );
printf( " Failing to follow this instruction may result in\n" );
printf( " weak security for your connections! Use the\n" );
printf( " predefined DHM parameters from dhm.h instead!\n\n" );
printf( "============================================================\n\n" );
printf( "\n . Seeding the random number generator..." ); printf( "\n . Seeding the random number generator..." );
fflush( stdout ); fflush( stdout );
@ -98,7 +122,7 @@ int main( int argc, char *argv[] )
/* /*
* This can take a long time... * This can take a long time...
*/ */
if( ( ret = mpi_gen_prime( &P, DH_P_SIZE, 1, if( ( ret = mpi_gen_prime( &P, nbits, 1,
ctr_drbg_random, &ctr_drbg ) ) != 0 ) ctr_drbg_random, &ctr_drbg ) ) != 0 )
{ {
printf( " failed\n ! mpi_gen_prime returned %d\n\n", ret ); printf( " failed\n ! mpi_gen_prime returned %d\n\n", ret );