Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(87)

Side by Side Diff: third_party/WebKit/Source/wtf/StdLibExtras.h

Issue 1850413002: Improve DEFINE_STATIC_LOCAL()'s handling of Blink GCed objects. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: msvc compile fix.. Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « third_party/WebKit/Source/web/WebPagePopupImpl.cpp ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. 2 * Copyright (C) 2008 Apple Inc. All Rights Reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
52 // AtomicallyInitializedStatic (i.e. with a lock held). 52 // AtomicallyInitializedStatic (i.e. with a lock held).
53 return m_safelyInitialized || m_thread == WTF::currentThread() || WTF::i sAtomicallyInitializedStaticMutexLockHeld(); 53 return m_safelyInitialized || m_thread == WTF::currentThread() || WTF::i sAtomicallyInitializedStaticMutexLockHeld();
54 } 54 }
55 55
56 private: 56 private:
57 bool m_safelyInitialized; 57 bool m_safelyInitialized;
58 ThreadIdentifier m_thread; 58 ThreadIdentifier m_thread;
59 }; 59 };
60 #endif 60 #endif
61 61
62 // A direct static local to a Blink garbage collected objects isn't allowed; 62 namespace blink {
63 // must be wrapped up with a persistent reference. 63 template<typename T>class Persistent;
64 #define STATIC_ASSERT_FOR_LOCAL_WITH_GARBAGE_COLLECTED_TYPE(Name, Type) \ 64 };
65 using Name##NoConstType = std::remove_const<Type>::type; \
66 using Name##NoPointerType = std::remove_pointer<Name##NoConstType>::type; \
67 using Name##NoReferenceType = std::remove_reference<Name##NoPointerType>::ty pe; \
68 static_assert(!WTF::IsGarbageCollectedType<Name##NoReferenceType>::value || WTF::IsPersistentReferenceType<Name##NoReferenceType>::value, "Garbage collected static local needs to be wrapped up with a persistent reference")
69 65
70 // Use DEFINE_STATIC_LOCAL() to declare and define a static local variable (stat ic T;) 66 template<typename T, bool = WTF::IsGarbageCollectedType<T>::value && !WTF::IsPer sistentReferenceType<T>::value>
71 // so that it is leaked and its destructors are not called at exit. 67 class StaticLocalWrapper {
68 public:
69 using WrapType = T;
70
71 static T& unwrap(T* singleton)
72 {
73 return *singleton;
74 }
75 };
76
77 template<typename T>
78 class StaticLocalWrapper<T, true> {
79 public:
80 using WrapType = blink::Persistent<T>;
81
82 static T& unwrap(blink::Persistent<T>* singleton)
83 {
84 return **singleton;
85 }
86 };
87
88 #if ENABLE(ASSERT)
89 #define DEFINE_STATIC_LOCAL_CHECK_THREADSAFE_ACCESS(Name) \
90 static StaticLocalVerifier Name##StaticLocalVerifier; \
91 ASSERT(Name##StaticLocalVerifier.isNotRacy())
92 #else
93 #define DEFINE_STATIC_LOCAL_CHECK_THREADSAFE_ACCESS(Name)
94 #endif
95
96 // Use DEFINE_STATIC_LOCAL() to declare and define a static local variable
97 // (static T;) so that it is leaked and its destructors are not called at exit.
98 // T may also be a Blink garbage collected object, in which case it is
99 // wrapped up by a strong off-heap Persistent<T> reference.
haraken 2016/04/03 23:46:52 Nit: "strong off-heap" might be misleading. "a str
sof 2016/04/04 07:09:00 Reworded.
72 // 100 //
73 // To cooperate with leak detection, the objects held onto by these local static s 101 // To cooperate with leak detection(LSan) for Blink garbage collected objects,
74 // will in some cases have to be finalized prior to leak checking. This only app lies 102 // the objects owned by persistent local statics will in some cases have to be
75 // to static references to Oilpan heap objects and what they transitively hold o n to. 103 // finalized prior to leak checking. This only applies to static references to
76 // LEAK_SANITIZER_REGISTER_STATIC_LOCAL() takes care of the details. 104 // Blink heap objects and what they transitively hold on to. Hence the
105 // LEAK_SANITIZER_REGISTER_STATIC_LOCAL() use, it taking care of the grungy
106 // details.
77 // 107 //
78 #if ENABLE(ASSERT) 108 #define DEFINE_STATIC_LOCAL(Type, Name, Arguments) \
79 #define DEFINE_STATIC_LOCAL(Type, Name, Arguments) \ 109 DEFINE_STATIC_LOCAL_CHECK_THREADSAFE_ACCESS(Name); \
80 STATIC_ASSERT_FOR_LOCAL_WITH_GARBAGE_COLLECTED_TYPE(Name, Type); \ 110 using WrappedTypeFor##Name = StaticLocalWrapper<Type>::WrapType; \
81 static StaticLocalVerifier Name##StaticLocalVerifier; \ 111 static Type& Name = StaticLocalWrapper<Type>::unwrap(LEAK_SANITIZER_REGISTER _STATIC_LOCAL(WrappedTypeFor##Name, new WrappedTypeFor##Name Arguments))
82 ASSERT(Name##StaticLocalVerifier.isNotRacy()); \
83 static Type& Name = *LEAK_SANITIZER_REGISTER_STATIC_LOCAL(Type, new Type Arg uments)
84 #else
85 #define DEFINE_STATIC_LOCAL(Type, Name, Arguments) \
86 STATIC_ASSERT_FOR_LOCAL_WITH_GARBAGE_COLLECTED_TYPE(Name, Type); \
87 static Type& Name = *LEAK_SANITIZER_REGISTER_STATIC_LOCAL(Type, new Type Arg uments)
88 #endif
89 112
90 // Use this to declare and define a static local pointer to a ref-counted object so that 113 // Use this to declare and define a static local pointer to a ref-counted object so that
91 // it is leaked so that the object's destructors are not called at exit. 114 // it is leaked so that the object's destructors are not called at exit.
92 // This macro should be used with ref-counted objects rather than DEFINE_STATIC_ LOCAL macro, 115 // This macro should be used with ref-counted objects rather than DEFINE_STATIC_ LOCAL macro,
93 // as this macro does not lead to an extra memory allocation. 116 // as this macro does not lead to an extra memory allocation.
94 #define DEFINE_STATIC_REF(type, name, arguments) \ 117 #define DEFINE_STATIC_REF(type, name, arguments) \
95 static type* name = PassRefPtr<type>(arguments).leakRef(); 118 static type* name = PassRefPtr<type>(arguments).leakRef();
96 119
97 /* 120 /*
98 * The reinterpret_cast<Type1*>([pointer to Type2]) expressions - where 121 * The reinterpret_cast<Type1*>([pointer to Type2]) expressions - where
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after
201 inline void* operator new(size_t, NotNullTag, void* location) 224 inline void* operator new(size_t, NotNullTag, void* location)
202 { 225 {
203 ASSERT(location); 226 ASSERT(location);
204 return location; 227 return location;
205 } 228 }
206 229
207 using WTF::bitwise_cast; 230 using WTF::bitwise_cast;
208 using WTF::safeCast; 231 using WTF::safeCast;
209 232
210 #endif // WTF_StdLibExtras_h 233 #endif // WTF_StdLibExtras_h
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/web/WebPagePopupImpl.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698