X-Git-Url: https://git.openssl.org/gitweb/?p=openssl.git;a=blobdiff_plain;f=fuzz%2Fcms.c;h=959ef9365ad1f60c1d0405bf78dfa4bfaa0274d5;hp=c4477efa8fd00f1e92d717ddf3b8fcaa1652084c;hb=6b97cc6ec17586ff9c1d96ab5c3e0b6d829074a8;hpb=ad4da7fbc0779fb1730c9862221e19583de69f4f diff --git a/fuzz/cms.c b/fuzz/cms.c index c4477efa8f..959ef9365a 100644 --- a/fuzz/cms.c +++ b/fuzz/cms.c @@ -14,26 +14,39 @@ #include #include +#include #include "fuzzer.h" int FuzzerInitialize(int *argc, char ***argv) { + OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL); + ERR_get_state(); + CRYPTO_free_ex_index(0, -1); return 1; } int FuzzerTestOneInput(const uint8_t *buf, size_t len) { - CMS_ContentInfo *i; + CMS_ContentInfo *cms; BIO *in; - if (!len) { + + if (len == 0) return 0; - } in = BIO_new(BIO_s_mem()); OPENSSL_assert((size_t)BIO_write(in, buf, len) == len); - i = d2i_CMS_bio(in, NULL); - CMS_ContentInfo_free(i); + cms = d2i_CMS_bio(in, NULL); + if (cms != NULL) { + BIO *out = BIO_new(BIO_s_null()); + + i2d_CMS_bio(out, cms); + BIO_free(out); + CMS_ContentInfo_free(cms); + } + BIO_free(in); + ERR_clear_error(); + return 0; }