forked from llvm/llvm-project
- Notifications
You must be signed in to change notification settings - Fork 339
/
Copy pathllvm-dis-fuzzer.cpp
28 lines (25 loc) · 1019 Bytes
/
llvm-dis-fuzzer.cpp
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
//===-- llvm-dis-fuzzer.cpp - Fuzzer for llvm-dis using lib/Fuzzer --------===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// Fuzzer for LLVM bitcode reading.
//
//===----------------------------------------------------------------------===//
#include"llvm/Bitcode/BitcodeReader.h"
#include"llvm/IR/LLVMContext.h"
#include"llvm/IR/Module.h"
#include"llvm/Support/MemoryBuffer.h"
usingnamespacellvm;
extern"C"intLLVMFuzzerTestOneInput(constuint8_t *Data, size_tSize) {
LLVMContext Context;
auto Buffer = MemoryBuffer::getMemBuffer(
StringRef(reinterpret_cast<constchar *>(Data), Size), "Fuzzer input",
/*RequiresNullTerminator=*/false);
consumeError(
parseBitcodeFile(Buffer->getMemBufferRef(), Context).takeError());
return0;
}