annotate libsanitizer/tsan/tsan_interceptors.h @ 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
111
kono
parents:
diff changeset
1 #ifndef TSAN_INTERCEPTORS_H
kono
parents:
diff changeset
2 #define TSAN_INTERCEPTORS_H
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include "sanitizer_common/sanitizer_stacktrace.h"
kono
parents:
diff changeset
5 #include "tsan_rtl.h"
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 namespace __tsan {
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 class ScopedInterceptor {
kono
parents:
diff changeset
10 public:
kono
parents:
diff changeset
11 ScopedInterceptor(ThreadState *thr, const char *fname, uptr pc);
kono
parents:
diff changeset
12 ~ScopedInterceptor();
kono
parents:
diff changeset
13 void DisableIgnores();
kono
parents:
diff changeset
14 void EnableIgnores();
kono
parents:
diff changeset
15 private:
kono
parents:
diff changeset
16 ThreadState *const thr_;
kono
parents:
diff changeset
17 const uptr pc_;
kono
parents:
diff changeset
18 bool in_ignored_lib_;
kono
parents:
diff changeset
19 bool ignoring_;
kono
parents:
diff changeset
20 };
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 LibIgnore *libignore();
kono
parents:
diff changeset
23
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
24 #if !SANITIZER_GO
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
25 INLINE bool in_symbolizer() {
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
26 cur_thread_init();
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
27 return UNLIKELY(cur_thread()->in_symbolizer);
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
28 }
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
29 #endif
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
30
111
kono
parents:
diff changeset
31 } // namespace __tsan
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 #define SCOPED_INTERCEPTOR_RAW(func, ...) \
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
34 cur_thread_init(); \
111
kono
parents:
diff changeset
35 ThreadState *thr = cur_thread(); \
kono
parents:
diff changeset
36 const uptr caller_pc = GET_CALLER_PC(); \
kono
parents:
diff changeset
37 ScopedInterceptor si(thr, #func, caller_pc); \
kono
parents:
diff changeset
38 const uptr pc = StackTrace::GetCurrentPc(); \
kono
parents:
diff changeset
39 (void)pc; \
kono
parents:
diff changeset
40 /**/
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 #define SCOPED_TSAN_INTERCEPTOR(func, ...) \
kono
parents:
diff changeset
43 SCOPED_INTERCEPTOR_RAW(func, __VA_ARGS__); \
kono
parents:
diff changeset
44 if (REAL(func) == 0) { \
kono
parents:
diff changeset
45 Report("FATAL: ThreadSanitizer: failed to intercept %s\n", #func); \
kono
parents:
diff changeset
46 Die(); \
kono
parents:
diff changeset
47 } \
kono
parents:
diff changeset
48 if (!thr->is_inited || thr->ignore_interceptors || thr->in_ignored_lib) \
kono
parents:
diff changeset
49 return REAL(func)(__VA_ARGS__); \
kono
parents:
diff changeset
50 /**/
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 #define SCOPED_TSAN_INTERCEPTOR_USER_CALLBACK_START() \
kono
parents:
diff changeset
53 si.DisableIgnores();
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 #define SCOPED_TSAN_INTERCEPTOR_USER_CALLBACK_END() \
kono
parents:
diff changeset
56 si.EnableIgnores();
kono
parents:
diff changeset
57
kono
parents:
diff changeset
58 #define TSAN_INTERCEPTOR(ret, func, ...) INTERCEPTOR(ret, func, __VA_ARGS__)
kono
parents:
diff changeset
59
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
60 #if SANITIZER_NETBSD
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
61 # define TSAN_INTERCEPTOR_NETBSD_ALIAS(ret, func, ...) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
62 TSAN_INTERCEPTOR(ret, __libc_##func, __VA_ARGS__) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
63 ALIAS(WRAPPER_NAME(pthread_##func));
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
64 # define TSAN_INTERCEPTOR_NETBSD_ALIAS_THR(ret, func, ...) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
65 TSAN_INTERCEPTOR(ret, __libc_thr_##func, __VA_ARGS__) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
66 ALIAS(WRAPPER_NAME(pthread_##func));
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
67 # define TSAN_INTERCEPTOR_NETBSD_ALIAS_THR2(ret, func, func2, ...) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
68 TSAN_INTERCEPTOR(ret, __libc_thr_##func, __VA_ARGS__) \
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
69 ALIAS(WRAPPER_NAME(pthread_##func2));
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
70 #else
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
71 # define TSAN_INTERCEPTOR_NETBSD_ALIAS(ret, func, ...)
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
72 # define TSAN_INTERCEPTOR_NETBSD_ALIAS_THR(ret, func, ...)
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
73 # define TSAN_INTERCEPTOR_NETBSD_ALIAS_THR2(ret, func, func2, ...)
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
74 #endif
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
75
111
kono
parents:
diff changeset
76 #endif // TSAN_INTERCEPTORS_H