From 23a04fa2273190c4874c5263ecbaf03e743b19f6 Mon Sep 17 00:00:00 2001 From: miod <> Date: Sun, 15 Feb 2015 09:46:47 +0000 Subject: Fix various memory leaks by not exiting so abruptly from failed tests. --- src/regress/lib/libcrypto/bn/general/bntest.c | 1086 ++++++++++++------------- 1 file changed, 507 insertions(+), 579 deletions(-) (limited to 'src') diff --git a/src/regress/lib/libcrypto/bn/general/bntest.c b/src/regress/lib/libcrypto/bn/general/bntest.c index a3206aba8c..ad000fcf56 100644 --- a/src/regress/lib/libcrypto/bn/general/bntest.c +++ b/src/regress/lib/libcrypto/bn/general/bntest.c @@ -120,19 +120,21 @@ int test_mod_exp_sizes(BIO *bp, BN_CTX *ctx); int rand_neg(void); static int results=0; -static unsigned char lst[]="\xC6\x4F\x43\x04\x2A\xEA\xCA\x6E\x58\x36\x80\x5B\xE8\xC9" +static const unsigned char lst[]="\xC6\x4F\x43\x04\x2A\xEA\xCA\x6E\x58\x36\x80\x5B\xE8\xC9" "\x9B\x04\x5D\x48\x36\xC2\xFD\x16\xC9\x64\xF0"; -static void message(BIO *out, char *m) - { +static void +message(BIO *out, char *m) +{ fprintf(stderr, "test %s\n", m); BIO_puts(out, "print \"test "); BIO_puts(out, m); BIO_puts(out, "\\n\"\n"); - } +} -int main(int argc, char *argv[]) - { +int +main(int argc, char *argv[]) +{ BN_CTX *ctx; BIO *out; char *outfile=NULL; @@ -141,18 +143,16 @@ int main(int argc, char *argv[]) argc--; argv++; - while (argc >= 1) - { + while (argc >= 1) { if (strcmp(*argv,"-results") == 0) results=1; - else if (strcmp(*argv,"-out") == 0) - { + else if (strcmp(*argv,"-out") == 0) { if (--argc < 1) break; outfile= *(++argv); - } + } argc--; argv++; - } + } ctx=BN_CTX_new(); @@ -160,18 +160,14 @@ int main(int argc, char *argv[]) out=BIO_new(BIO_s_file()); if (out == NULL) exit(1); - if (outfile == NULL) - { + if (outfile == NULL) { BIO_set_fp(out,stdout,BIO_NOCLOSE); - } - else - { - if (!BIO_write_filename(out,outfile)) - { + } else { + if (!BIO_write_filename(out,outfile)) { perror(outfile); exit(1); - } } + } if (!results) BIO_puts(out,"obase=16\nibase=16\n"); @@ -311,107 +307,107 @@ err: ERR_load_crypto_strings(); ERR_print_errors_fp(stderr); exit(1); - } +} -int test_add(BIO *bp) - { +int +test_add(BIO *bp) +{ BIGNUM a,b,c; int i; + int rc = 1; BN_init(&a); BN_init(&b); BN_init(&c); BN_bntest_rand(&a,512,0,0); - for (i=0; i sizeof(unsigned long)) - { - unsigned long h=(unsigned long)(w>>32), - l=(unsigned long)(w); + if (sizeof(w) > sizeof(unsigned long)) { + unsigned long h=(unsigned long)(w>>32), l=(unsigned long)(w); - if (h) BIO_printf(bp,"%lX%08lX",h,l); - else BIO_printf(bp,"%lX",l); + if (h) + BIO_printf(bp,"%lX%08lX",h,l); + else + BIO_printf(bp,"%lX",l); return; - } + } #endif BIO_printf(bp,BN_HEX_FMT1,w); - } +} -int test_div_word(BIO *bp) - { +int +test_div_word(BIO *bp) +{ BIGNUM a,b; BN_ULONG r,s; int i; + int rc = 1; BN_init(&a); BN_init(&b); - for (i=0; iN)); BIO_puts(bp," - "); - } + } BN_print(bp,&A); BIO_puts(bp,"\n"); - } + } BN_mod_mul(&d,&a,&b,&n,ctx); BN_sub(&d,&d,&A); - if(!BN_is_zero(&d)) - { + if(!BN_is_zero(&d)) { fprintf(stderr,"Montgomery multiplication test failed!\n"); - return 0; - } + rc = 0; + break; } + } BN_MONT_CTX_free(mont); BN_free(&a); BN_free(&b); @@ -783,13 +763,15 @@ int test_mont(BIO *bp, BN_CTX *ctx) BN_free(&A); BN_free(&B); BN_free(&n); - return(1); - } + return(rc); +} -int test_mod(BIO *bp, BN_CTX *ctx) - { +int +test_mod(BIO *bp, BN_CTX *ctx) +{ BIGNUM *a,*b,*c,*d,*e; int i; + int rc = 1; a=BN_new(); b=BN_new(); @@ -798,44 +780,43 @@ int test_mod(BIO *bp, BN_CTX *ctx) e=BN_new(); BN_bntest_rand(a,1024,0,0); /**/ - for (i=0; ineg=rand_neg(); b->neg=rand_neg(); BN_mod(c,a,b,ctx);/**/ - if (bp != NULL) - { - if (!results) - { + if (bp != NULL) { + if (!results) { BN_print(bp,a); BIO_puts(bp," % "); BN_print(bp,b); BIO_puts(bp," - "); - } + } BN_print(bp,c); BIO_puts(bp,"\n"); - } + } BN_div(d,e,a,b,ctx); BN_sub(e,e,c); - if(!BN_is_zero(e)) - { + if(!BN_is_zero(e)) { fprintf(stderr,"Modulo test failed!\n"); - return 0; - } + rc = 0; + break; } + } BN_free(a); BN_free(b); BN_free(c); BN_free(d); BN_free(e); - return(1); - } + return(rc); +} -int test_mod_mul(BIO *bp, BN_CTX *ctx) - { +int +test_mod_mul(BIO *bp, BN_CTX *ctx) +{ BIGNUM *a,*b,*c,*d,*e; int i,j; + int rc = 1; a=BN_new(); b=BN_new(); @@ -844,69 +825,67 @@ int test_mod_mul(BIO *bp, BN_CTX *ctx) e=BN_new(); for (j=0; j<3; j++) { - BN_bntest_rand(c,1024,0,0); /**/ - for (i=0; ineg=rand_neg(); - b->neg=rand_neg(); - if (!BN_mod_mul(e,a,b,c,ctx)) - { - unsigned long l; - - while ((l=ERR_get_error())) - fprintf(stderr,"ERROR:%s\n", - ERR_error_string(l,NULL)); - exit(1); + BN_bntest_rand(c,1024,0,0); /**/ + for (i=0; ineg=rand_neg(); + b->neg=rand_neg(); + if (!BN_mod_mul(e,a,b,c,ctx)) { + unsigned long l; + + while ((l=ERR_get_error())) + fprintf(stderr,"ERROR:%s\n", + ERR_error_string(l,NULL)); + exit(1); } - if (bp != NULL) - { - if (!results) - { - BN_print(bp,a); - BIO_puts(bp," * "); - BN_print(bp,b); - BIO_puts(bp," % "); - BN_print(bp,c); - if ((a->neg ^ b->neg) && !BN_is_zero(e)) - { - /* If (a*b) % c is negative, c must be added - * in order to obtain the normalized remainder - * (new with OpenSSL 0.9.7, previous versions of - * BN_mod_mul could generate negative results) - */ - BIO_puts(bp," + "); + if (bp != NULL) { + if (!results) { + BN_print(bp,a); + BIO_puts(bp," * "); + BN_print(bp,b); + BIO_puts(bp," % "); BN_print(bp,c); + if ((a->neg ^ b->neg) && !BN_is_zero(e)) { + /* If (a*b) % c is negative, c must be added + * in order to obtain the normalized remainder + * (new with OpenSSL 0.9.7, previous versions of + * BN_mod_mul could generate negative results) + */ + BIO_puts(bp," + "); + BN_print(bp,c); } - BIO_puts(bp," - "); + BIO_puts(bp," - "); } - BN_print(bp,e); - BIO_puts(bp,"\n"); + BN_print(bp,e); + BIO_puts(bp,"\n"); + } + BN_mul(d,a,b,ctx); + BN_sub(d,d,e); + BN_div(a,b,d,c,ctx); + if(!BN_is_zero(b)) { + fprintf(stderr,"Modulo multiply test failed!\n"); + ERR_print_errors_fp(stderr); + rc = 0; + goto done; } - BN_mul(d,a,b,ctx); - BN_sub(d,d,e); - BN_div(a,b,d,c,ctx); - if(!BN_is_zero(b)) - { - fprintf(stderr,"Modulo multiply test failed!\n"); - ERR_print_errors_fp(stderr); - return 0; - } } } +done: BN_free(a); BN_free(b); BN_free(c); BN_free(d); BN_free(e); - return(1); - } + return(rc); +} -int test_mod_exp(BIO *bp, BN_CTX *ctx) - { +int +test_mod_exp(BIO *bp, BN_CTX *ctx) +{ BIGNUM *a,*b,*c,*d,*e; int i; + int rc = 1; a=BN_new(); b=BN_new(); @@ -915,49 +894,50 @@ int test_mod_exp(BIO *bp, BN_CTX *ctx) e=BN_new(); BN_bntest_rand(c,30,0,1); /* must be odd for montgomery */ - for (i=0; ineg = rand_neg(); putc('\n', stderr); - for (i = 0; i < num0; i++) - { + for (i = 0; i < num0; i++) { if (!BN_bntest_rand(a, 512, 0, 0)) goto err; a->neg = rand_neg(); @@ -1692,16 +1632,14 @@ int test_kron(BIO *bp, BN_CTX *ctx) legendre = 1; else if (BN_is_zero(r)) legendre = 0; - else - { + else { if (!BN_add_word(r, 1)) goto err; - if (0 != BN_ucmp(r, b)) - { + if (0 != BN_ucmp(r, b)) { fprintf(stderr, "Legendre symbol computation failed\n"); goto err; - } - legendre = -1; } + legendre = -1; + } kronecker = BN_kronecker(a, b, ctx); if (kronecker < -1) goto err; @@ -1709,33 +1647,33 @@ int test_kron(BIO *bp, BN_CTX *ctx) if (a->neg && b->neg) kronecker = -kronecker; - if (legendre != kronecker) - { + if (legendre != kronecker) { fprintf(stderr, "legendre != kronecker; a = "); BN_print_fp(stderr, a); fprintf(stderr, ", b = "); BN_print_fp(stderr, b); fprintf(stderr, "\n"); goto err; - } + } putc('.', stderr); fflush(stderr); - } + } putc('\n', stderr); fflush(stderr); ret = 1; - err: +err: if (a != NULL) BN_free(a); if (b != NULL) BN_free(b); if (r != NULL) BN_free(r); if (t != NULL) BN_free(t); return ret; - } +} -int test_sqrt(BIO *bp, BN_CTX *ctx) - { +int +test_sqrt(BIO *bp, BN_CTX *ctx) +{ BN_GENCB cb; BIGNUM *a,*p,*r; int i, j; @@ -1748,26 +1686,21 @@ int test_sqrt(BIO *bp, BN_CTX *ctx) BN_GENCB_set(&cb, genprime_cb, NULL); - for (i = 0; i < 16; i++) - { - if (i < 8) - { + for (i = 0; i < 16; i++) { + if (i < 8) { unsigned primes[8] = { 2, 3, 5, 7, 11, 13, 17, 19 }; if (!BN_set_word(p, primes[i])) goto err; - } - else - { + } else { if (!BN_set_word(a, 32)) goto err; if (!BN_set_word(r, 2*i + 1)) goto err; if (!BN_generate_prime_ex(p, 256, 0, a, r, &cb)) goto err; putc('\n', stderr); - } + } p->neg = rand_neg(); - for (j = 0; j < num2; j++) - { + for (j = 0; j < num2; j++) { /* construct 'a' such that it is a square modulo p, * but in general not a proper square and not reduced modulo p */ if (!BN_bntest_rand(r, 256, 0, 3)) goto err; @@ -1785,8 +1718,7 @@ int test_sqrt(BIO *bp, BN_CTX *ctx) if (!BN_nnmod(a, a, p, ctx)) goto err; - if (BN_cmp(a, r) != 0) - { + if (BN_cmp(a, r) != 0) { fprintf(stderr, "BN_mod_sqrt failed: a = "); BN_print_fp(stderr, a); fprintf(stderr, ", r = "); @@ -1795,27 +1727,29 @@ int test_sqrt(BIO *bp, BN_CTX *ctx) BN_print_fp(stderr, p); fprintf(stderr, "\n"); goto err; - } + } putc('.', stderr); fflush(stderr); - } + } putc('\n', stderr); fflush(stderr); - } + } ret = 1; - err: +err: if (a != NULL) BN_free(a); if (p != NULL) BN_free(p); if (r != NULL) BN_free(r); return ret; - } +} -int test_lshift(BIO *bp,BN_CTX *ctx,BIGNUM *a_) - { +int +test_lshift(BIO *bp,BN_CTX *ctx,BIGNUM *a_) +{ BIGNUM *a,*b,*c,*d; int i; + int rc = 1; b=BN_new(); c=BN_new(); @@ -1824,32 +1758,27 @@ int test_lshift(BIO *bp,BN_CTX *ctx,BIGNUM *a_) if(a_) a=a_; - else - { + else { a=BN_new(); BN_bntest_rand(a,200,0,0); /**/ a->neg=rand_neg(); - } - for (i=0; ineg=rand_neg(); - for (i=0; ineg=rand_neg(); - for (i=0; ineg=rand_neg(); - for (i=0; i