1 //===-- tsan_defs.h ---------------------------------------------*- C++ -*-===//
3 // This file is distributed under the University of Illinois Open Source
4 // License. See LICENSE.TXT for details.
6 //===----------------------------------------------------------------------===//
8 // This file is a part of ThreadSanitizer (TSan), a race detector.
10 //===----------------------------------------------------------------------===//
15 #include "sanitizer_common/sanitizer_internal_defs.h"
16 #include "sanitizer_common/sanitizer_libc.h"
17 #include "tsan_stat.h"
26 const bool kGoMode
= true;
27 const bool kCppMode
= false;
28 const char *const kTsanOptionsEnv
= "GORACE";
29 // Go linker does not support weak symbols.
32 const bool kGoMode
= false;
33 const bool kCppMode
= true;
34 const char *const kTsanOptionsEnv
= "TSAN_OPTIONS";
38 const int kTidBits
= 13;
39 const unsigned kMaxTid
= 1 << kTidBits
;
40 const unsigned kMaxTidInClock
= kMaxTid
* 2; // This includes msb 'freed' bit.
41 const int kClkBits
= 42;
42 const unsigned kMaxTidReuse
= (1 << (64 - kClkBits
)) - 1;
43 const uptr kShadowStackSize
= 64 * 1024;
44 const uptr kTraceStackSize
= 256;
46 #ifdef TSAN_SHADOW_COUNT
47 # if TSAN_SHADOW_COUNT == 2 \
48 || TSAN_SHADOW_COUNT == 4 || TSAN_SHADOW_COUNT == 8
49 const uptr kShadowCnt
= TSAN_SHADOW_COUNT
;
51 # error "TSAN_SHADOW_COUNT must be one of 2,4,8"
54 // Count of shadow values in a shadow cell.
55 const uptr kShadowCnt
= 4;
58 // That many user bytes are mapped onto a single shadow cell.
59 const uptr kShadowCell
= 8;
61 // Size of a single shadow value (u64).
62 const uptr kShadowSize
= 8;
64 // Shadow memory is kShadowMultiplier times larger than user memory.
65 const uptr kShadowMultiplier
= kShadowSize
* kShadowCnt
/ kShadowCell
;
67 #if defined(TSAN_NO_HISTORY) && TSAN_NO_HISTORY
68 const bool kCollectHistory
= false;
70 const bool kCollectHistory
= true;
73 #if defined(TSAN_COLLECT_STATS) && TSAN_COLLECT_STATS
74 const bool kCollectStats
= true;
76 const bool kCollectStats
= false;
79 // The following "build consistency" machinery ensures that all source files
80 // are built in the same configuration. Inconsistent builds lead to
81 // hard to debug crashes.
83 void build_consistency_debug();
85 void build_consistency_release();
88 #if TSAN_COLLECT_STATS
89 void build_consistency_stats();
91 void build_consistency_nostats();
94 #if TSAN_SHADOW_COUNT == 1
95 void build_consistency_shadow1();
96 #elif TSAN_SHADOW_COUNT == 2
97 void build_consistency_shadow2();
98 #elif TSAN_SHADOW_COUNT == 4
99 void build_consistency_shadow4();
101 void build_consistency_shadow8();
104 static inline void USED
build_consistency() {
106 build_consistency_debug();
108 build_consistency_release();
110 #if TSAN_COLLECT_STATS
111 build_consistency_stats();
113 build_consistency_nostats();
115 #if TSAN_SHADOW_COUNT == 1
116 build_consistency_shadow1();
117 #elif TSAN_SHADOW_COUNT == 2
118 build_consistency_shadow2();
119 #elif TSAN_SHADOW_COUNT == 4
120 build_consistency_shadow4();
122 build_consistency_shadow8();
128 return a
< b
? a
: b
;
133 return a
> b
? a
: b
;
137 T
RoundUp(T p
, u64 align
) {
138 DCHECK_EQ(align
& (align
- 1), 0);
139 return (T
)(((u64
)p
+ align
- 1) & ~(align
- 1));
143 T
RoundDown(T p
, u64 align
) {
144 DCHECK_EQ(align
& (align
- 1), 0);
145 return (T
)((u64
)p
& ~(align
- 1));
148 // Zeroizes high part, returns 'bits' lsb bits.
150 T
GetLsb(T v
, int bits
) {
151 return (T
)((u64
)v
& ((1ull << bits
) - 1));
156 bool operator==(const MD5Hash
&other
) const;
159 MD5Hash
md5_hash(const void *data
, uptr size
);
170 } // namespace __tsan
172 #endif // TSAN_DEFS_H