blob: a8ddeee21d6c4dbde516661147bd89c35d6c77b7 [file] [log] [blame] [edit]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef TESTING_FUZZERS_PDFIUM_FUZZER_UTIL_H_
#define TESTING_FUZZERS_PDFIUM_FUZZER_UTIL_H_
#include <stdint.h>
#include "public/fpdfview.h"
// Returns an integer from the first 4 bytes of |data|.
int GetInteger(const uint8_t* data);
// Plumb access to any context created by fuzzer initialization into
// the LLVMFuzzerTestOneInput() function, as that function does not
// allow for additional parameters, nor can it reach back up to the
// top-level fuzzer shim during a component build (see the comment
// in BUILD.gn about splitting fuzzers into _impl and _src targets).
extern "C" {
FPDF_EXPORT void FPDF_CALLCONV FPDF_SetFuzzerPerProcessState(void* state);
FPDF_EXPORT void* FPDF_CALLCONV FPDF_GetFuzzerPerProcessState();
} // extern "C"
#endif // TESTING_FUZZERS_PDFIUM_FUZZER_UTIL_H_