blob: 926287da48617665eb947d25711841cfbb06cf02 [file] [log] [blame]
Kurt Roeckxe1859d82016-06-18 15:56:49 +02001/*
2 * Copyright 2016 The OpenSSL Project Authors. All Rights Reserved.
3 *
4 * Licensed under the OpenSSL licenses, (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 * https://www.openssl.org/source/license.html
8 * or in the file LICENSE in the source distribution.
9 */
10
11#include <openssl/x509.h>
12#include <openssl/bio.h>
Kurt Roeckxd69d8f92016-12-02 19:34:54 +010013#include <openssl/err.h>
Kurt Roeckxb534df92017-02-19 17:04:11 +010014#include <openssl/rand.h>
Kurt Roeckxe1859d82016-06-18 15:56:49 +020015#include "fuzzer.h"
16
Rich Salz710769f2017-08-11 08:22:22 -040017#include "rand.inc"
18
Kurt Roeckxf3e911d2016-11-19 17:10:35 +010019int FuzzerInitialize(int *argc, char ***argv)
20{
Kurt Roeckxd69d8f92016-12-02 19:34:54 +010021 OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
22 ERR_get_state();
23 CRYPTO_free_ex_index(0, -1);
Rich Salz9f08a1c2017-07-26 14:27:30 -040024 FuzzerSetRand();
Kurt Roeckxa05b0bc2016-07-01 16:42:15 +020025 return 1;
26}
27
Kurt Roeckxf3e911d2016-11-19 17:10:35 +010028int FuzzerTestOneInput(const uint8_t *buf, size_t len)
29{
Kurt Roeckxe1859d82016-06-18 15:56:49 +020030 const unsigned char *p = buf;
31 unsigned char *der = NULL;
32
33 X509 *x509 = d2i_X509(NULL, &p, len);
34 if (x509 != NULL) {
35 BIO *bio = BIO_new(BIO_s_null());
Alex Gaynor03cb37a2016-06-26 10:37:03 -040036 /* This will load and print the public key as well as extensions */
Kurt Roeckxe1859d82016-06-18 15:56:49 +020037 X509_print(bio, x509);
38 BIO_free(bio);
39
40 i2d_X509(x509, &der);
41 OPENSSL_free(der);
42
43 X509_free(x509);
44 }
Kurt Roeckxd69d8f92016-12-02 19:34:54 +010045 ERR_clear_error();
Kurt Roeckxe1859d82016-06-18 15:56:49 +020046 return 0;
47}
Kurt Roeckxad4da7f2016-11-19 17:13:10 +010048
49void FuzzerCleanup(void)
50{
51}