• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1//===--- Sanitizers.def - Runtime sanitizer options -------------*- 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//
10// This file defines the options for specifying which runtime sanitizers to
11// enable. Users of this file must define the SANITIZER macro to make use of
12// this information. Users of this file can also define the SANITIZER_GROUP
13// macro to get information on options which refer to sets of sanitizers.
14//
15//===----------------------------------------------------------------------===//
16
17#ifndef SANITIZER
18#error "Define SANITIZER prior to including this file!"
19#endif
20
21// SANITIZER(NAME, ID)
22
23// The first value is the name of the sanitizer as a string. The sanitizer can
24// be enabled by specifying -fsanitize=NAME.
25
26// The second value is an identifier which can be used to refer to the
27// sanitizer.
28
29
30// SANITIZER_GROUP(NAME, ID, ALIAS)
31
32// The first two values have the same semantics as the corresponding SANITIZER
33// values. The third value is an expression ORing together the IDs of individual
34// sanitizers in this group.
35
36#ifndef SANITIZER_GROUP
37#define SANITIZER_GROUP(NAME, ID, ALIAS)
38#endif
39
40
41// AddressSanitizer
42SANITIZER("address", Address)
43// More features of AddressSanitizer that should be turned on explicitly.
44SANITIZER("init-order", InitOrder)
45SANITIZER("use-after-return", UseAfterReturn)
46SANITIZER("use-after-scope", UseAfterScope)
47
48SANITIZER_GROUP("address-full", AddressFull,
49                Address | InitOrder | UseAfterReturn | UseAfterScope)
50
51// MemorySanitizer
52SANITIZER("memory", Memory)
53
54// ThreadSanitizer
55SANITIZER("thread", Thread)
56
57// UndefinedBehaviorSanitizer
58SANITIZER("alignment", Alignment)
59SANITIZER("bool", Bool)
60SANITIZER("bounds", Bounds)
61SANITIZER("enum", Enum)
62SANITIZER("float-cast-overflow", FloatCastOverflow)
63SANITIZER("float-divide-by-zero", FloatDivideByZero)
64SANITIZER("integer-divide-by-zero", IntegerDivideByZero)
65SANITIZER("null", Null)
66SANITIZER("object-size", ObjectSize)
67SANITIZER("return", Return)
68SANITIZER("shift", Shift)
69SANITIZER("signed-integer-overflow", SignedIntegerOverflow)
70SANITIZER("unreachable", Unreachable)
71SANITIZER("vla-bound", VLABound)
72SANITIZER("vptr", Vptr)
73
74// IntegerSanitizer
75SANITIZER("unsigned-integer-overflow", UnsignedIntegerOverflow)
76
77// -fsanitize=undefined includes all the sanitizers which have low overhead, no
78// ABI or address space layout implications, and only catch undefined behavior.
79SANITIZER_GROUP("undefined", Undefined,
80                Alignment | Bool | Bounds | Enum | FloatCastOverflow |
81                FloatDivideByZero | IntegerDivideByZero | Null | ObjectSize |
82                Return | Shift | SignedIntegerOverflow | Unreachable |
83                VLABound | Vptr)
84
85// -fsanitize=undefined-trap (and its alias -fcatch-undefined-behavior) includes
86// all sanitizers included by -fsanitize=undefined, except those that require
87// runtime support.  This group is generally used in conjunction with the
88// -fsanitize-undefined-trap-on-error flag.
89SANITIZER_GROUP("undefined-trap", UndefinedTrap,
90                Alignment | Bool | Bounds | Enum | FloatCastOverflow |
91                FloatDivideByZero | IntegerDivideByZero | Null | ObjectSize |
92                Return | Shift | SignedIntegerOverflow | Unreachable |
93                VLABound)
94
95SANITIZER_GROUP("integer", Integer,
96                SignedIntegerOverflow | UnsignedIntegerOverflow | Shift |
97                IntegerDivideByZero)
98
99#undef SANITIZER
100#undef SANITIZER_GROUP
101