X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=fuzz%2Fbignum.c;h=e53dd3d1717a0ca6a4996a1d629f15d03c19be26;hp=43e134bc141081db6fc0d7848fa828ada33a7263;hb=3a9b9b2deb8e19fa10e7c3c99ad0baa2f90f13fa;hpb=352dbbaf4ca361c076f1437690607caf02965d7f;ds=sidebyside diff --git a/fuzz/bignum.c b/fuzz/bignum.c index 43e134bc14..e53dd3d171 100644 --- a/fuzz/bignum.c +++ b/fuzz/bignum.c @@ -17,29 +17,31 @@ #include #include "fuzzer.h" -int FuzzerInitialize(int *argc, char ***argv) { +static BN_CTX *ctx; +static BIGNUM *b1; +static BIGNUM *b2; +static BIGNUM *b3; +static BIGNUM *b4; +static BIGNUM *b5; + +int FuzzerInitialize(int *argc, char ***argv) +{ + b1 = BN_new(); + b2 = BN_new(); + b3 = BN_new(); + b4 = BN_new(); + b5 = BN_new(); + ctx = BN_CTX_new(); + return 1; } -int FuzzerTestOneInput(const uint8_t *buf, size_t len) { - static BN_CTX *ctx; - static BIGNUM *b1; - static BIGNUM *b2; - static BIGNUM *b3; - static BIGNUM *b4; - static BIGNUM *b5; +int FuzzerTestOneInput(const uint8_t *buf, size_t len) +{ int success = 0; size_t l1 = 0, l2 = 0, l3 = 0; int s1 = 0, s2 = 0, s3 = 0; - if (ctx == NULL) { - b1 = BN_new(); - b2 = BN_new(); - b3 = BN_new(); - b4 = BN_new(); - b5 = BN_new(); - ctx = BN_CTX_new(); - } /* Divide the input into three parts, using the values of the first two * bytes to choose lengths, which generate b1, b2 and b3. Use three bits * of the third byte to choose signs for the three numbers. @@ -92,3 +94,13 @@ int FuzzerTestOneInput(const uint8_t *buf, size_t len) { return 0; } + +void FuzzerCleanup(void) +{ + BN_free(b1); + BN_free(b2); + BN_free(b3); + BN_free(b4); + BN_free(b5); + BN_CTX_free(ctx); +}