summaryrefslogtreecommitdiff
path: root/fuzz/shared.h
blob: 24ca51f85d2ff9a22925685fdc2269cfd1c8e368 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
 * You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef shared_h__
#define shared_h__

#include <assert.h>
#include <random>
#include "cert.h"
#include "nss.h"

extern "C" size_t LLVMFuzzerMutate(uint8_t *Data, size_t Size, size_t MaxSize);
extern "C" size_t LLVMFuzzerCustomMutator(uint8_t *Data, size_t Size,
                                          size_t MaxSize, unsigned int Seed);

class NSSDatabase {
 public:
  NSSDatabase() { assert(NSS_NoDB_Init(nullptr) == SECSuccess); }
  ~NSSDatabase() { assert(NSS_Shutdown() == SECSuccess); }
};

typedef std::vector<decltype(LLVMFuzzerCustomMutator) *> Mutators;

size_t CustomMutate(Mutators &mutators, uint8_t *Data, size_t Size,
                    size_t MaxSize, unsigned int Seed) {
  std::mt19937 rng(Seed);
  static std::bernoulli_distribution bdist;

  if (bdist(rng)) {
    std::uniform_int_distribution<size_t> idist(0, mutators.size() - 1);
    return mutators.at(idist(rng))(Data, Size, MaxSize, Seed);
  }

  return LLVMFuzzerMutate(Data, Size, MaxSize);
}

#endif  // shared_h__