blob: 32e173f9d1fce57c974126e0d3b5d90ccd430f50 [file] [log] [blame]
Alexey Samsonovd804a1e2015-05-28 18:35:18 +00001//===-- llvm-dwarfdump-fuzzer.cpp - Fuzz the llvm-dwarfdump tool ----------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9///
10/// \file
11/// \brief This file implements a function that runs llvm-dwarfdump
12/// on a single input. This function is then linked into the Fuzzer library.
13///
14//===----------------------------------------------------------------------===//
15#include "llvm/DebugInfo/DIContext.h"
16#include "llvm/DebugInfo/DWARF/DWARFContext.h"
17#include "llvm/Object/ObjectFile.h"
18#include "llvm/Support/MemoryBuffer.h"
19
20using namespace llvm;
21using namespace object;
22
23extern "C" void LLVMFuzzerTestOneInput(uint8_t *data, size_t size) {
24 std::unique_ptr<MemoryBuffer> Buff = MemoryBuffer::getMemBuffer(
25 StringRef((const char *)data, size), "", false);
26
David Majnemer2da76642016-05-31 01:24:33 +000027 Expected<std::unique_ptr<ObjectFile>> ObjOrErr =
Alexey Samsonovd804a1e2015-05-28 18:35:18 +000028 ObjectFile::createObjectFile(Buff->getMemBufferRef());
David Majnemer2da76642016-05-31 01:24:33 +000029 if (auto E = ObjOrErr.takeError()) {
30 consumeError(std::move(E));
Alexey Samsonovd804a1e2015-05-28 18:35:18 +000031 return;
David Majnemer2da76642016-05-31 01:24:33 +000032 }
Alexey Samsonovd804a1e2015-05-28 18:35:18 +000033 ObjectFile &Obj = *ObjOrErr.get();
34 std::unique_ptr<DIContext> DICtx(new DWARFContextInMemory(Obj));
35 DICtx->dump(nulls(), DIDT_All);
36}