annotate libsanitizer/tsan/tsan_interface_ann.cpp @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
145
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
1 //===-- tsan_interface_ann.cpp --------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
2 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
4 // See https://llvm.org/LICENSE.txt for license information.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
6 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
7 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
8 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
9 // This file is a part of ThreadSanitizer (TSan), a race detector.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
10 //
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
11 //===----------------------------------------------------------------------===//
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
12 #include "sanitizer_common/sanitizer_libc.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
13 #include "sanitizer_common/sanitizer_internal_defs.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
14 #include "sanitizer_common/sanitizer_placement_new.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
15 #include "sanitizer_common/sanitizer_stacktrace.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
16 #include "sanitizer_common/sanitizer_vector.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
17 #include "tsan_interface_ann.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
18 #include "tsan_mutex.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
19 #include "tsan_report.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
20 #include "tsan_rtl.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
21 #include "tsan_mman.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
22 #include "tsan_flags.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
23 #include "tsan_platform.h"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
24
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
25 #define CALLERPC ((uptr)__builtin_return_address(0))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
26
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
27 using namespace __tsan;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
28
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
29 namespace __tsan {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
30
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
31 class ScopedAnnotation {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
32 public:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
33 ScopedAnnotation(ThreadState *thr, const char *aname, uptr pc)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
34 : thr_(thr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
35 FuncEntry(thr_, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
36 DPrintf("#%d: annotation %s()\n", thr_->tid, aname);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
37 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
38
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
39 ~ScopedAnnotation() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
40 FuncExit(thr_);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
41 CheckNoLocks(thr_);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
42 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
43 private:
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
44 ThreadState *const thr_;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
45 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
46
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
47 #define SCOPED_ANNOTATION_RET(typ, ret) \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
48 if (!flags()->enable_annotations) \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
49 return ret; \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
50 ThreadState *thr = cur_thread(); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
51 const uptr caller_pc = (uptr)__builtin_return_address(0); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
52 StatInc(thr, StatAnnotation); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
53 StatInc(thr, Stat##typ); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
54 ScopedAnnotation sa(thr, __func__, caller_pc); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
55 const uptr pc = StackTrace::GetCurrentPc(); \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
56 (void)pc; \
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
57 /**/
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
58
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
59 #define SCOPED_ANNOTATION(typ) SCOPED_ANNOTATION_RET(typ, )
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
60
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
61 static const int kMaxDescLen = 128;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
62
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
63 struct ExpectRace {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
64 ExpectRace *next;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
65 ExpectRace *prev;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
66 atomic_uintptr_t hitcount;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
67 atomic_uintptr_t addcount;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
68 uptr addr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
69 uptr size;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
70 char *file;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
71 int line;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
72 char desc[kMaxDescLen];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
73 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
74
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
75 struct DynamicAnnContext {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
76 Mutex mtx;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
77 ExpectRace expect;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
78 ExpectRace benign;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
79
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
80 DynamicAnnContext()
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
81 : mtx(MutexTypeAnnotations, StatMtxAnnotations) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
82 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
83 };
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
84
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
85 static DynamicAnnContext *dyn_ann_ctx;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
86 static char dyn_ann_ctx_placeholder[sizeof(DynamicAnnContext)] ALIGNED(64);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
87
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
88 static void AddExpectRace(ExpectRace *list,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
89 char *f, int l, uptr addr, uptr size, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
90 ExpectRace *race = list->next;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
91 for (; race != list; race = race->next) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
92 if (race->addr == addr && race->size == size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
93 atomic_store_relaxed(&race->addcount,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
94 atomic_load_relaxed(&race->addcount) + 1);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
95 return;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
96 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
97 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
98 race = (ExpectRace*)internal_alloc(MBlockExpectRace, sizeof(ExpectRace));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
99 race->addr = addr;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
100 race->size = size;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
101 race->file = f;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
102 race->line = l;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
103 race->desc[0] = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
104 atomic_store_relaxed(&race->hitcount, 0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
105 atomic_store_relaxed(&race->addcount, 1);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
106 if (desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
107 int i = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
108 for (; i < kMaxDescLen - 1 && desc[i]; i++)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
109 race->desc[i] = desc[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
110 race->desc[i] = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
111 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
112 race->prev = list;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
113 race->next = list->next;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
114 race->next->prev = race;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
115 list->next = race;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
116 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
117
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
118 static ExpectRace *FindRace(ExpectRace *list, uptr addr, uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
119 for (ExpectRace *race = list->next; race != list; race = race->next) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
120 uptr maxbegin = max(race->addr, addr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
121 uptr minend = min(race->addr + race->size, addr + size);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
122 if (maxbegin < minend)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
123 return race;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
124 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
125 return 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
126 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
127
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
128 static bool CheckContains(ExpectRace *list, uptr addr, uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
129 ExpectRace *race = FindRace(list, addr, size);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
130 if (race == 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
131 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
132 DPrintf("Hit expected/benign race: %s addr=%zx:%d %s:%d\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
133 race->desc, race->addr, (int)race->size, race->file, race->line);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
134 atomic_fetch_add(&race->hitcount, 1, memory_order_relaxed);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
135 return true;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
136 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
137
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
138 static void InitList(ExpectRace *list) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
139 list->next = list;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
140 list->prev = list;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
141 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
142
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
143 void InitializeDynamicAnnotations() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
144 dyn_ann_ctx = new(dyn_ann_ctx_placeholder) DynamicAnnContext;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
145 InitList(&dyn_ann_ctx->expect);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
146 InitList(&dyn_ann_ctx->benign);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
147 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
148
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
149 bool IsExpectedReport(uptr addr, uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
150 ReadLock lock(&dyn_ann_ctx->mtx);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
151 if (CheckContains(&dyn_ann_ctx->expect, addr, size))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
152 return true;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
153 if (CheckContains(&dyn_ann_ctx->benign, addr, size))
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
154 return true;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
155 return false;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
156 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
157
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
158 static void CollectMatchedBenignRaces(Vector<ExpectRace> *matched,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
159 int *unique_count, int *hit_count, atomic_uintptr_t ExpectRace::*counter) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
160 ExpectRace *list = &dyn_ann_ctx->benign;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
161 for (ExpectRace *race = list->next; race != list; race = race->next) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
162 (*unique_count)++;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
163 const uptr cnt = atomic_load_relaxed(&(race->*counter));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
164 if (cnt == 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
165 continue;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
166 *hit_count += cnt;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
167 uptr i = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
168 for (; i < matched->Size(); i++) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
169 ExpectRace *race0 = &(*matched)[i];
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
170 if (race->line == race0->line
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
171 && internal_strcmp(race->file, race0->file) == 0
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
172 && internal_strcmp(race->desc, race0->desc) == 0) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
173 atomic_fetch_add(&(race0->*counter), cnt, memory_order_relaxed);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
174 break;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
175 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
176 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
177 if (i == matched->Size())
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
178 matched->PushBack(*race);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
179 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
180 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
181
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
182 void PrintMatchedBenignRaces() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
183 Lock lock(&dyn_ann_ctx->mtx);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
184 int unique_count = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
185 int hit_count = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
186 int add_count = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
187 Vector<ExpectRace> hit_matched;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
188 CollectMatchedBenignRaces(&hit_matched, &unique_count, &hit_count,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
189 &ExpectRace::hitcount);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
190 Vector<ExpectRace> add_matched;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
191 CollectMatchedBenignRaces(&add_matched, &unique_count, &add_count,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
192 &ExpectRace::addcount);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
193 if (hit_matched.Size()) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
194 Printf("ThreadSanitizer: Matched %d \"benign\" races (pid=%d):\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
195 hit_count, (int)internal_getpid());
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
196 for (uptr i = 0; i < hit_matched.Size(); i++) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
197 Printf("%d %s:%d %s\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
198 atomic_load_relaxed(&hit_matched[i].hitcount),
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
199 hit_matched[i].file, hit_matched[i].line, hit_matched[i].desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
200 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
201 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
202 if (hit_matched.Size()) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
203 Printf("ThreadSanitizer: Annotated %d \"benign\" races, %d unique"
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
204 " (pid=%d):\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
205 add_count, unique_count, (int)internal_getpid());
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
206 for (uptr i = 0; i < add_matched.Size(); i++) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
207 Printf("%d %s:%d %s\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
208 atomic_load_relaxed(&add_matched[i].addcount),
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
209 add_matched[i].file, add_matched[i].line, add_matched[i].desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
210 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
211 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
212 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
213
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
214 static void ReportMissedExpectedRace(ExpectRace *race) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
215 Printf("==================\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
216 Printf("WARNING: ThreadSanitizer: missed expected data race\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
217 Printf(" %s addr=%zx %s:%d\n",
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
218 race->desc, race->addr, race->file, race->line);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
219 Printf("==================\n");
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
220 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
221 } // namespace __tsan
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
222
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
223 using namespace __tsan;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
224
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
225 extern "C" {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
226 void INTERFACE_ATTRIBUTE AnnotateHappensBefore(char *f, int l, uptr addr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
227 SCOPED_ANNOTATION(AnnotateHappensBefore);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
228 Release(thr, pc, addr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
229 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
230
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
231 void INTERFACE_ATTRIBUTE AnnotateHappensAfter(char *f, int l, uptr addr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
232 SCOPED_ANNOTATION(AnnotateHappensAfter);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
233 Acquire(thr, pc, addr);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
234 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
235
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
236 void INTERFACE_ATTRIBUTE AnnotateCondVarSignal(char *f, int l, uptr cv) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
237 SCOPED_ANNOTATION(AnnotateCondVarSignal);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
238 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
239
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
240 void INTERFACE_ATTRIBUTE AnnotateCondVarSignalAll(char *f, int l, uptr cv) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
241 SCOPED_ANNOTATION(AnnotateCondVarSignalAll);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
242 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
243
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
244 void INTERFACE_ATTRIBUTE AnnotateMutexIsNotPHB(char *f, int l, uptr mu) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
245 SCOPED_ANNOTATION(AnnotateMutexIsNotPHB);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
246 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
247
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
248 void INTERFACE_ATTRIBUTE AnnotateCondVarWait(char *f, int l, uptr cv,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
249 uptr lock) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
250 SCOPED_ANNOTATION(AnnotateCondVarWait);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
251 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
252
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
253 void INTERFACE_ATTRIBUTE AnnotateRWLockCreate(char *f, int l, uptr m) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
254 SCOPED_ANNOTATION(AnnotateRWLockCreate);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
255 MutexCreate(thr, pc, m, MutexFlagWriteReentrant);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
256 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
257
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
258 void INTERFACE_ATTRIBUTE AnnotateRWLockCreateStatic(char *f, int l, uptr m) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
259 SCOPED_ANNOTATION(AnnotateRWLockCreateStatic);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
260 MutexCreate(thr, pc, m, MutexFlagWriteReentrant | MutexFlagLinkerInit);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
261 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
262
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
263 void INTERFACE_ATTRIBUTE AnnotateRWLockDestroy(char *f, int l, uptr m) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
264 SCOPED_ANNOTATION(AnnotateRWLockDestroy);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
265 MutexDestroy(thr, pc, m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
266 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
267
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
268 void INTERFACE_ATTRIBUTE AnnotateRWLockAcquired(char *f, int l, uptr m,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
269 uptr is_w) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
270 SCOPED_ANNOTATION(AnnotateRWLockAcquired);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
271 if (is_w)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
272 MutexPostLock(thr, pc, m, MutexFlagDoPreLockOnPostLock);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
273 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
274 MutexPostReadLock(thr, pc, m, MutexFlagDoPreLockOnPostLock);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
275 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
276
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
277 void INTERFACE_ATTRIBUTE AnnotateRWLockReleased(char *f, int l, uptr m,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
278 uptr is_w) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
279 SCOPED_ANNOTATION(AnnotateRWLockReleased);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
280 if (is_w)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
281 MutexUnlock(thr, pc, m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
282 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
283 MutexReadUnlock(thr, pc, m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
284 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
285
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
286 void INTERFACE_ATTRIBUTE AnnotateTraceMemory(char *f, int l, uptr mem) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
287 SCOPED_ANNOTATION(AnnotateTraceMemory);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
288 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
289
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
290 void INTERFACE_ATTRIBUTE AnnotateFlushState(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
291 SCOPED_ANNOTATION(AnnotateFlushState);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
292 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
293
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
294 void INTERFACE_ATTRIBUTE AnnotateNewMemory(char *f, int l, uptr mem,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
295 uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
296 SCOPED_ANNOTATION(AnnotateNewMemory);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
297 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
298
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
299 void INTERFACE_ATTRIBUTE AnnotateNoOp(char *f, int l, uptr mem) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
300 SCOPED_ANNOTATION(AnnotateNoOp);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
301 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
302
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
303 void INTERFACE_ATTRIBUTE AnnotateFlushExpectedRaces(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
304 SCOPED_ANNOTATION(AnnotateFlushExpectedRaces);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
305 Lock lock(&dyn_ann_ctx->mtx);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
306 while (dyn_ann_ctx->expect.next != &dyn_ann_ctx->expect) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
307 ExpectRace *race = dyn_ann_ctx->expect.next;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
308 if (atomic_load_relaxed(&race->hitcount) == 0) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
309 ctx->nmissed_expected++;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
310 ReportMissedExpectedRace(race);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
311 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
312 race->prev->next = race->next;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
313 race->next->prev = race->prev;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
314 internal_free(race);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
315 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
316 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
317
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
318 void INTERFACE_ATTRIBUTE AnnotateEnableRaceDetection(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
319 char *f, int l, int enable) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
320 SCOPED_ANNOTATION(AnnotateEnableRaceDetection);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
321 // FIXME: Reconsider this functionality later. It may be irrelevant.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
322 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
323
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
324 void INTERFACE_ATTRIBUTE AnnotateMutexIsUsedAsCondVar(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
325 char *f, int l, uptr mu) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
326 SCOPED_ANNOTATION(AnnotateMutexIsUsedAsCondVar);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
327 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
328
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
329 void INTERFACE_ATTRIBUTE AnnotatePCQGet(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
330 char *f, int l, uptr pcq) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
331 SCOPED_ANNOTATION(AnnotatePCQGet);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
332 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
333
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
334 void INTERFACE_ATTRIBUTE AnnotatePCQPut(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
335 char *f, int l, uptr pcq) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
336 SCOPED_ANNOTATION(AnnotatePCQPut);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
337 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
338
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
339 void INTERFACE_ATTRIBUTE AnnotatePCQDestroy(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
340 char *f, int l, uptr pcq) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
341 SCOPED_ANNOTATION(AnnotatePCQDestroy);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
342 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
343
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
344 void INTERFACE_ATTRIBUTE AnnotatePCQCreate(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
345 char *f, int l, uptr pcq) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
346 SCOPED_ANNOTATION(AnnotatePCQCreate);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
347 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
348
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
349 void INTERFACE_ATTRIBUTE AnnotateExpectRace(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
350 char *f, int l, uptr mem, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
351 SCOPED_ANNOTATION(AnnotateExpectRace);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
352 Lock lock(&dyn_ann_ctx->mtx);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
353 AddExpectRace(&dyn_ann_ctx->expect,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
354 f, l, mem, 1, desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
355 DPrintf("Add expected race: %s addr=%zx %s:%d\n", desc, mem, f, l);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
356 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
357
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
358 static void BenignRaceImpl(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
359 char *f, int l, uptr mem, uptr size, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
360 Lock lock(&dyn_ann_ctx->mtx);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
361 AddExpectRace(&dyn_ann_ctx->benign,
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
362 f, l, mem, size, desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
363 DPrintf("Add benign race: %s addr=%zx %s:%d\n", desc, mem, f, l);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
364 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
365
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
366 // FIXME: Turn it off later. WTF is benign race?1?? Go talk to Hans Boehm.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
367 void INTERFACE_ATTRIBUTE AnnotateBenignRaceSized(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
368 char *f, int l, uptr mem, uptr size, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
369 SCOPED_ANNOTATION(AnnotateBenignRaceSized);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
370 BenignRaceImpl(f, l, mem, size, desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
371 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
372
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
373 void INTERFACE_ATTRIBUTE AnnotateBenignRace(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
374 char *f, int l, uptr mem, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
375 SCOPED_ANNOTATION(AnnotateBenignRace);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
376 BenignRaceImpl(f, l, mem, 1, desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
377 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
378
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
379 void INTERFACE_ATTRIBUTE AnnotateIgnoreReadsBegin(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
380 SCOPED_ANNOTATION(AnnotateIgnoreReadsBegin);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
381 ThreadIgnoreBegin(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
382 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
383
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
384 void INTERFACE_ATTRIBUTE AnnotateIgnoreReadsEnd(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
385 SCOPED_ANNOTATION(AnnotateIgnoreReadsEnd);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
386 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
387 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
388
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
389 void INTERFACE_ATTRIBUTE AnnotateIgnoreWritesBegin(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
390 SCOPED_ANNOTATION(AnnotateIgnoreWritesBegin);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
391 ThreadIgnoreBegin(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
392 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
393
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
394 void INTERFACE_ATTRIBUTE AnnotateIgnoreWritesEnd(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
395 SCOPED_ANNOTATION(AnnotateIgnoreWritesEnd);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
396 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
397 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
398
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
399 void INTERFACE_ATTRIBUTE AnnotateIgnoreSyncBegin(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
400 SCOPED_ANNOTATION(AnnotateIgnoreSyncBegin);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
401 ThreadIgnoreSyncBegin(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
402 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
403
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
404 void INTERFACE_ATTRIBUTE AnnotateIgnoreSyncEnd(char *f, int l) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
405 SCOPED_ANNOTATION(AnnotateIgnoreSyncEnd);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
406 ThreadIgnoreSyncEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
407 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
408
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
409 void INTERFACE_ATTRIBUTE AnnotatePublishMemoryRange(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
410 char *f, int l, uptr addr, uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
411 SCOPED_ANNOTATION(AnnotatePublishMemoryRange);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
412 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
413
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
414 void INTERFACE_ATTRIBUTE AnnotateUnpublishMemoryRange(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
415 char *f, int l, uptr addr, uptr size) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
416 SCOPED_ANNOTATION(AnnotateUnpublishMemoryRange);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
417 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
418
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
419 void INTERFACE_ATTRIBUTE AnnotateThreadName(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
420 char *f, int l, char *name) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
421 SCOPED_ANNOTATION(AnnotateThreadName);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
422 ThreadSetName(thr, name);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
423 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
424
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
425 // We deliberately omit the implementation of WTFAnnotateHappensBefore() and
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
426 // WTFAnnotateHappensAfter(). Those are being used by Webkit to annotate
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
427 // atomic operations, which should be handled by ThreadSanitizer correctly.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
428 void INTERFACE_ATTRIBUTE WTFAnnotateHappensBefore(char *f, int l, uptr addr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
429 SCOPED_ANNOTATION(AnnotateHappensBefore);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
430 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
431
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
432 void INTERFACE_ATTRIBUTE WTFAnnotateHappensAfter(char *f, int l, uptr addr) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
433 SCOPED_ANNOTATION(AnnotateHappensAfter);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
434 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
435
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
436 void INTERFACE_ATTRIBUTE WTFAnnotateBenignRaceSized(
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
437 char *f, int l, uptr mem, uptr sz, char *desc) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
438 SCOPED_ANNOTATION(AnnotateBenignRaceSized);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
439 BenignRaceImpl(f, l, mem, sz, desc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
440 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
441
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
442 int INTERFACE_ATTRIBUTE RunningOnValgrind() {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
443 return flags()->running_on_valgrind;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
444 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
445
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
446 double __attribute__((weak)) INTERFACE_ATTRIBUTE ValgrindSlowdown(void) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
447 return 10.0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
448 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
449
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
450 const char INTERFACE_ATTRIBUTE* ThreadSanitizerQuery(const char *query) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
451 if (internal_strcmp(query, "pure_happens_before") == 0)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
452 return "1";
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
453 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
454 return "0";
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
455 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
456
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
457 void INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
458 AnnotateMemoryIsInitialized(char *f, int l, uptr mem, uptr sz) {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
459 void INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
460 AnnotateMemoryIsUninitialized(char *f, int l, uptr mem, uptr sz) {}
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
461
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
462 // Note: the parameter is called flagz, because flags is already taken
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
463 // by the global function that returns flags.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
464 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
465 void __tsan_mutex_create(void *m, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
466 SCOPED_ANNOTATION(__tsan_mutex_create);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
467 MutexCreate(thr, pc, (uptr)m, flagz & MutexCreationFlagMask);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
468 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
469
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
470 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
471 void __tsan_mutex_destroy(void *m, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
472 SCOPED_ANNOTATION(__tsan_mutex_destroy);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
473 MutexDestroy(thr, pc, (uptr)m, flagz);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
474 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
475
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
476 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
477 void __tsan_mutex_pre_lock(void *m, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
478 SCOPED_ANNOTATION(__tsan_mutex_pre_lock);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
479 if (!(flagz & MutexFlagTryLock)) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
480 if (flagz & MutexFlagReadLock)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
481 MutexPreReadLock(thr, pc, (uptr)m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
482 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
483 MutexPreLock(thr, pc, (uptr)m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
484 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
485 ThreadIgnoreBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
486 ThreadIgnoreSyncBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
487 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
488
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
489 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
490 void __tsan_mutex_post_lock(void *m, unsigned flagz, int rec) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
491 SCOPED_ANNOTATION(__tsan_mutex_post_lock);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
492 ThreadIgnoreSyncEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
493 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
494 if (!(flagz & MutexFlagTryLockFailed)) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
495 if (flagz & MutexFlagReadLock)
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
496 MutexPostReadLock(thr, pc, (uptr)m, flagz);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
497 else
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
498 MutexPostLock(thr, pc, (uptr)m, flagz, rec);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
499 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
500 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
501
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
502 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
503 int __tsan_mutex_pre_unlock(void *m, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
504 SCOPED_ANNOTATION_RET(__tsan_mutex_pre_unlock, 0);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
505 int ret = 0;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
506 if (flagz & MutexFlagReadLock) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
507 CHECK(!(flagz & MutexFlagRecursiveUnlock));
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
508 MutexReadUnlock(thr, pc, (uptr)m);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
509 } else {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
510 ret = MutexUnlock(thr, pc, (uptr)m, flagz);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
511 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
512 ThreadIgnoreBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
513 ThreadIgnoreSyncBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
514 return ret;
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
515 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
516
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
517 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
518 void __tsan_mutex_post_unlock(void *m, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
519 SCOPED_ANNOTATION(__tsan_mutex_post_unlock);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
520 ThreadIgnoreSyncEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
521 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
522 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
523
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
524 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
525 void __tsan_mutex_pre_signal(void *addr, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
526 SCOPED_ANNOTATION(__tsan_mutex_pre_signal);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
527 ThreadIgnoreBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
528 ThreadIgnoreSyncBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
529 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
530
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
531 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
532 void __tsan_mutex_post_signal(void *addr, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
533 SCOPED_ANNOTATION(__tsan_mutex_post_signal);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
534 ThreadIgnoreSyncEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
535 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
536 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
537
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
538 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
539 void __tsan_mutex_pre_divert(void *addr, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
540 SCOPED_ANNOTATION(__tsan_mutex_pre_divert);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
541 // Exit from ignore region started in __tsan_mutex_pre_lock/unlock/signal.
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
542 ThreadIgnoreSyncEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
543 ThreadIgnoreEnd(thr, pc);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
544 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
545
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
546 INTERFACE_ATTRIBUTE
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
547 void __tsan_mutex_post_divert(void *addr, unsigned flagz) {
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
548 SCOPED_ANNOTATION(__tsan_mutex_post_divert);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
549 ThreadIgnoreBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
550 ThreadIgnoreSyncBegin(thr, pc, /*save_stack=*/false);
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
551 }
1830386684a0 gcc-9.2.0
anatofuz
parents:
diff changeset
552 } // extern "C"