xref: /aosp_15_r20/external/skia/include/private/base/SkThreadAnnotations.h (revision c8dee2aa9b3f27cf6c858bd81872bdeb2c07ed17)
1*c8dee2aaSAndroid Build Coastguard Worker /*
2*c8dee2aaSAndroid Build Coastguard Worker  * Copyright 2019 Google LLC
3*c8dee2aaSAndroid Build Coastguard Worker  *
4*c8dee2aaSAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
5*c8dee2aaSAndroid Build Coastguard Worker  * found in the LICENSE file.
6*c8dee2aaSAndroid Build Coastguard Worker  */
7*c8dee2aaSAndroid Build Coastguard Worker 
8*c8dee2aaSAndroid Build Coastguard Worker #ifndef SkThreadAnnotations_DEFINED
9*c8dee2aaSAndroid Build Coastguard Worker #define SkThreadAnnotations_DEFINED
10*c8dee2aaSAndroid Build Coastguard Worker 
11*c8dee2aaSAndroid Build Coastguard Worker #include "include/private/base/SkFeatures.h"  // IWYU pragma: keep
12*c8dee2aaSAndroid Build Coastguard Worker 
13*c8dee2aaSAndroid Build Coastguard Worker // The bulk of this code is cribbed from:
14*c8dee2aaSAndroid Build Coastguard Worker // http://clang.llvm.org/docs/ThreadSafetyAnalysis.html
15*c8dee2aaSAndroid Build Coastguard Worker 
16*c8dee2aaSAndroid Build Coastguard Worker #if defined(__clang__) && (!defined(SWIG))
17*c8dee2aaSAndroid Build Coastguard Worker #define SK_THREAD_ANNOTATION_ATTRIBUTE(x)   __attribute__((x))
18*c8dee2aaSAndroid Build Coastguard Worker #else
19*c8dee2aaSAndroid Build Coastguard Worker #define SK_THREAD_ANNOTATION_ATTRIBUTE(x)   // no-op
20*c8dee2aaSAndroid Build Coastguard Worker #endif
21*c8dee2aaSAndroid Build Coastguard Worker 
22*c8dee2aaSAndroid Build Coastguard Worker #define SK_CAPABILITY(x) \
23*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(capability(x))
24*c8dee2aaSAndroid Build Coastguard Worker 
25*c8dee2aaSAndroid Build Coastguard Worker #define SK_SCOPED_CAPABILITY \
26*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(scoped_lockable)
27*c8dee2aaSAndroid Build Coastguard Worker 
28*c8dee2aaSAndroid Build Coastguard Worker #define SK_GUARDED_BY(x) \
29*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(guarded_by(x))
30*c8dee2aaSAndroid Build Coastguard Worker 
31*c8dee2aaSAndroid Build Coastguard Worker #define SK_PT_GUARDED_BY(x) \
32*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(pt_guarded_by(x))
33*c8dee2aaSAndroid Build Coastguard Worker 
34*c8dee2aaSAndroid Build Coastguard Worker #define SK_ACQUIRED_BEFORE(...) \
35*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(acquired_before(__VA_ARGS__))
36*c8dee2aaSAndroid Build Coastguard Worker 
37*c8dee2aaSAndroid Build Coastguard Worker #define SK_ACQUIRED_AFTER(...) \
38*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(acquired_after(__VA_ARGS__))
39*c8dee2aaSAndroid Build Coastguard Worker 
40*c8dee2aaSAndroid Build Coastguard Worker #define SK_REQUIRES(...) \
41*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(requires_capability(__VA_ARGS__))
42*c8dee2aaSAndroid Build Coastguard Worker 
43*c8dee2aaSAndroid Build Coastguard Worker #define SK_REQUIRES_SHARED(...) \
44*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(requires_shared_capability(__VA_ARGS__))
45*c8dee2aaSAndroid Build Coastguard Worker 
46*c8dee2aaSAndroid Build Coastguard Worker #define SK_ACQUIRE(...) \
47*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(acquire_capability(__VA_ARGS__))
48*c8dee2aaSAndroid Build Coastguard Worker 
49*c8dee2aaSAndroid Build Coastguard Worker #define SK_ACQUIRE_SHARED(...) \
50*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(acquire_shared_capability(__VA_ARGS__))
51*c8dee2aaSAndroid Build Coastguard Worker 
52*c8dee2aaSAndroid Build Coastguard Worker // Would be SK_RELEASE, but that is already in use as SK_DEBUG vs. SK_RELEASE.
53*c8dee2aaSAndroid Build Coastguard Worker #define SK_RELEASE_CAPABILITY(...) \
54*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(release_capability(__VA_ARGS__))
55*c8dee2aaSAndroid Build Coastguard Worker 
56*c8dee2aaSAndroid Build Coastguard Worker // For symmetry with SK_RELEASE_CAPABILITY.
57*c8dee2aaSAndroid Build Coastguard Worker #define SK_RELEASE_SHARED_CAPABILITY(...) \
58*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(release_shared_capability(__VA_ARGS__))
59*c8dee2aaSAndroid Build Coastguard Worker 
60*c8dee2aaSAndroid Build Coastguard Worker #define SK_TRY_ACQUIRE(...) \
61*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(try_acquire_capability(__VA_ARGS__))
62*c8dee2aaSAndroid Build Coastguard Worker 
63*c8dee2aaSAndroid Build Coastguard Worker #define SK_TRY_ACQUIRE_SHARED(...) \
64*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(try_acquire_shared_capability(__VA_ARGS__))
65*c8dee2aaSAndroid Build Coastguard Worker 
66*c8dee2aaSAndroid Build Coastguard Worker #define SK_EXCLUDES(...) \
67*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(locks_excluded(__VA_ARGS__))
68*c8dee2aaSAndroid Build Coastguard Worker 
69*c8dee2aaSAndroid Build Coastguard Worker #define SK_ASSERT_CAPABILITY(x) \
70*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(assert_capability(x))
71*c8dee2aaSAndroid Build Coastguard Worker 
72*c8dee2aaSAndroid Build Coastguard Worker #define SK_ASSERT_SHARED_CAPABILITY(x) \
73*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(assert_shared_capability(x))
74*c8dee2aaSAndroid Build Coastguard Worker 
75*c8dee2aaSAndroid Build Coastguard Worker #define SK_RETURN_CAPABILITY(x) \
76*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(lock_returned(x))
77*c8dee2aaSAndroid Build Coastguard Worker 
78*c8dee2aaSAndroid Build Coastguard Worker #define SK_NO_THREAD_SAFETY_ANALYSIS \
79*c8dee2aaSAndroid Build Coastguard Worker   SK_THREAD_ANNOTATION_ATTRIBUTE(no_thread_safety_analysis)
80*c8dee2aaSAndroid Build Coastguard Worker 
81*c8dee2aaSAndroid Build Coastguard Worker #if defined(SK_BUILD_FOR_GOOGLE3) && !defined(SK_BUILD_FOR_WASM_IN_GOOGLE3) \
82*c8dee2aaSAndroid Build Coastguard Worker     && !defined(SK_BUILD_FOR_WIN)
83*c8dee2aaSAndroid Build Coastguard Worker     extern "C" {
84*c8dee2aaSAndroid Build Coastguard Worker         void __google_cxa_guard_acquire_begin(void) __attribute__((weak));
85*c8dee2aaSAndroid Build Coastguard Worker         void __google_cxa_guard_acquire_end  (void) __attribute__((weak));
86*c8dee2aaSAndroid Build Coastguard Worker     }
sk_potentially_blocking_region_begin()87*c8dee2aaSAndroid Build Coastguard Worker     static inline void sk_potentially_blocking_region_begin() {
88*c8dee2aaSAndroid Build Coastguard Worker         if (&__google_cxa_guard_acquire_begin) {
89*c8dee2aaSAndroid Build Coastguard Worker             __google_cxa_guard_acquire_begin();
90*c8dee2aaSAndroid Build Coastguard Worker         }
91*c8dee2aaSAndroid Build Coastguard Worker     }
sk_potentially_blocking_region_end()92*c8dee2aaSAndroid Build Coastguard Worker     static inline void sk_potentially_blocking_region_end() {
93*c8dee2aaSAndroid Build Coastguard Worker         if (&__google_cxa_guard_acquire_end) {
94*c8dee2aaSAndroid Build Coastguard Worker             __google_cxa_guard_acquire_end();
95*c8dee2aaSAndroid Build Coastguard Worker         }
96*c8dee2aaSAndroid Build Coastguard Worker     }
97*c8dee2aaSAndroid Build Coastguard Worker     #define SK_POTENTIALLY_BLOCKING_REGION_BEGIN sk_potentially_blocking_region_begin()
98*c8dee2aaSAndroid Build Coastguard Worker     #define SK_POTENTIALLY_BLOCKING_REGION_END   sk_potentially_blocking_region_end()
99*c8dee2aaSAndroid Build Coastguard Worker #else
100*c8dee2aaSAndroid Build Coastguard Worker     #define SK_POTENTIALLY_BLOCKING_REGION_BEGIN
101*c8dee2aaSAndroid Build Coastguard Worker     #define SK_POTENTIALLY_BLOCKING_REGION_END
102*c8dee2aaSAndroid Build Coastguard Worker #endif
103*c8dee2aaSAndroid Build Coastguard Worker 
104*c8dee2aaSAndroid Build Coastguard Worker #endif  // SkThreadAnnotations_DEFINED
105