blob: bd182750800257e33a308d08cb2a44223dc277f5 [file] [log] [blame]
Kostya Serebryany6f5a8042016-09-21 01:50:50 +00001//===- FuzzerDefs.h - Internal header for the Fuzzer ------------*- C++ -* ===//
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// Basic definitions.
10//===----------------------------------------------------------------------===//
Marcos Pividori178fe582016-12-13 17:46:11 +000011
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000012#ifndef LLVM_FUZZER_DEFS_H
13#define LLVM_FUZZER_DEFS_H
14
Kostya Serebryany556894f2016-09-21 02:05:39 +000015#include <cassert>
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000016#include <cstddef>
17#include <cstdint>
Kostya Serebryany86586182016-09-21 21:17:23 +000018#include <cstring>
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000019#include <string>
20#include <vector>
21
22// Platform detection.
23#ifdef __linux__
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000024#define LIBFUZZER_APPLE 0
Zachary Turnerc6d8b4c2016-11-30 16:32:54 +000025#define LIBFUZZER_LINUX 1
26#define LIBFUZZER_WINDOWS 0
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000027#elif __APPLE__
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000028#define LIBFUZZER_APPLE 1
Zachary Turnerc6d8b4c2016-11-30 16:32:54 +000029#define LIBFUZZER_LINUX 0
30#define LIBFUZZER_WINDOWS 0
31#elif _WIN32
32#define LIBFUZZER_APPLE 0
33#define LIBFUZZER_LINUX 0
34#define LIBFUZZER_WINDOWS 1
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000035#else
36#error "Support for your platform has not been implemented"
37#endif
38
Zachary Turnerc6d8b4c2016-11-30 16:32:54 +000039#define LIBFUZZER_POSIX LIBFUZZER_APPLE || LIBFUZZER_LINUX
40
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000041#ifdef __x86_64
42#define ATTRIBUTE_TARGET_POPCNT __attribute__((target("popcnt")))
43#else
44#define ATTRIBUTE_TARGET_POPCNT
45#endif
46
Kostya Serebryany3a4e2dd2016-12-16 22:45:25 +000047
48#ifdef __clang__ // avoid gcc warning.
49# define ATTRIBUTE_NO_SANITIZE_MEMORY __attribute__((no_sanitize("memory")))
Mike Aizatsky0e37f8e2017-01-17 23:11:32 +000050# define ALWAYS_INLINE __attribute__((always_inline))
Kostya Serebryany3a4e2dd2016-12-16 22:45:25 +000051#else
52# define ATTRIBUTE_NO_SANITIZE_MEMORY
Mike Aizatsky0e37f8e2017-01-17 23:11:32 +000053# define ALWAYS_INLINE
54#endif // __clang__
Kostya Serebryany3a4e2dd2016-12-16 22:45:25 +000055
Kostya Serebryanyd0ecb4c2017-01-26 01:04:54 +000056#define ATTRIBUTE_NO_SANITIZE_ADDRESS __attribute__((no_sanitize_address))
57
Kostya Serebryany6ca44f92017-03-23 22:43:12 +000058#if defined(__has_feature)
59# if __has_feature(address_sanitizer)
60# define ATTRIBUTE_NO_SANITIZE_ALL ATTRIBUTE_NO_SANITIZE_ADDRESS
61# elif __has_feature(memory_sanitizer)
62# define ATTRIBUTE_NO_SANITIZE_ALL ATTRIBUTE_NO_SANITIZE_MEMORY
63# else
64# define ATTRIBUTE_NO_SANITIZE_ALL
65# endif
66#else
67# define ATTRIBUTE_NO_SANITIZE_ALL
68#endif
Kostya Serebryanyd0ecb4c2017-01-26 01:04:54 +000069
Marcos Pividori6137f982017-01-22 01:27:38 +000070#if LIBFUZZER_WINDOWS
71#define ATTRIBUTE_INTERFACE __declspec(dllexport)
72#else
73#define ATTRIBUTE_INTERFACE __attribute__((visibility("default")))
74#endif
75
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000076namespace fuzzer {
77
Kostya Serebryanyd28099d2016-09-23 00:22:46 +000078template <class T> T Min(T a, T b) { return a < b ? a : b; }
79template <class T> T Max(T a, T b) { return a > b ? a : b; }
80
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000081class Random;
82class Dictionary;
83class DictionaryEntry;
84class MutationDispatcher;
Kostya Serebryany556894f2016-09-21 02:05:39 +000085struct FuzzingOptions;
86class InputCorpus;
Kostya Serebryany29bb6642016-09-21 22:42:17 +000087struct InputInfo;
Kostya Serebryany556894f2016-09-21 02:05:39 +000088struct ExternalFunctions;
89
90// Global interface to functions that may or may not be available.
91extern ExternalFunctions *EF;
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000092
93typedef std::vector<uint8_t> Unit;
94typedef std::vector<Unit> UnitVector;
95typedef int (*UserCallback)(const uint8_t *Data, size_t Size);
Zachary Turner24a148b2016-11-30 19:06:14 +000096
Kostya Serebryany6f5a8042016-09-21 01:50:50 +000097int FuzzerDriver(int *argc, char ***argv, UserCallback Callback);
98
Kostya Serebryanyaf2dfce2017-03-31 02:21:28 +000099struct ScopedDoingMyOwnMemOrStr {
100 ScopedDoingMyOwnMemOrStr() { DoingMyOwnMemOrStr++; }
101 ~ScopedDoingMyOwnMemOrStr() { DoingMyOwnMemOrStr--; }
102 static int DoingMyOwnMemOrStr;
Kostya Serebryanya5f94fb2016-10-14 20:20:33 +0000103};
104
Kostya Serebryany9a4b10a2016-10-15 04:00:07 +0000105inline uint8_t Bswap(uint8_t x) { return x; }
106inline uint16_t Bswap(uint16_t x) { return __builtin_bswap16(x); }
107inline uint32_t Bswap(uint32_t x) { return __builtin_bswap32(x); }
108inline uint64_t Bswap(uint64_t x) { return __builtin_bswap64(x); }
109
Kostya Serebryany6ca44f92017-03-23 22:43:12 +0000110uint8_t *ExtraCountersBegin();
111uint8_t *ExtraCountersEnd();
112void ClearExtraCounters();
113
Kostya Serebryany6f5a8042016-09-21 01:50:50 +0000114} // namespace fuzzer
Marcos Pividori178fe582016-12-13 17:46:11 +0000115
Kostya Serebryany6f5a8042016-09-21 01:50:50 +0000116#endif // LLVM_FUZZER_DEFS_H