6402c3cf92ed43afb40d6769d15943d2d2d93a8c
[WebKit-https.git] / Source / WebCore / platform / ThreadGlobalData.cpp
1 /*
2  * Copyright (C) 2008, 2014 Apple Inc. All Rights Reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
24  *
25  */
26
27 #include "config.h"
28 #include "ThreadGlobalData.h"
29
30 #include "CachedResourceRequestInitiators.h"
31 #include "EventNames.h"
32 #include "QualifiedNameCache.h"
33 #include "TextCodecICU.h"
34 #include "ThreadTimers.h"
35 #include <wtf/MainThread.h>
36 #include <wtf/ThreadSpecific.h>
37 #include <wtf/Threading.h>
38 #include <wtf/text/StringImpl.h>
39
40 #if PLATFORM(MAC)
41 #include "TextCodecMac.h"
42 #endif
43
44 namespace WebCore {
45
46 ThreadGlobalData::ThreadGlobalData()
47     : m_cachedResourceRequestInitiators(std::make_unique<CachedResourceRequestInitiators>())
48     , m_eventNames(EventNames::create())
49     , m_threadTimers(std::make_unique<ThreadTimers>())
50     , m_qualifiedNameCache(std::make_unique<QualifiedNameCache>())
51 #ifndef NDEBUG
52     , m_isMainThread(isMainThread())
53 #endif
54     , m_cachedConverterICU(std::make_unique<ICUConverterWrapper>())
55 #if PLATFORM(MAC)
56     , m_cachedConverterTEC(std::make_unique<TECConverterWrapper>())
57 #endif
58 {
59     // This constructor will have been called on the main thread before being called on
60     // any other thread, and is only called once per thread - this makes this a convenient
61     // point to call methods that internally perform a one-time initialization that is not
62     // threadsafe.
63     Thread::current();
64 }
65
66 ThreadGlobalData::~ThreadGlobalData() = default;
67
68 void ThreadGlobalData::destroy()
69 {
70 #if PLATFORM(MAC)
71     m_cachedConverterTEC = nullptr;
72 #endif
73
74     m_cachedConverterICU = nullptr;
75
76     m_eventNames = nullptr;
77     m_threadTimers = nullptr;
78     m_qualifiedNameCache = nullptr;
79 }
80
81 #if USE(WEB_THREAD)
82 static ThreadSpecific<RefPtr<ThreadGlobalData>>* staticData { nullptr };
83 static ThreadGlobalData* sharedMainThreadStaticData { nullptr };
84
85 void ThreadGlobalData::setWebCoreThreadData()
86 {
87     ASSERT(isWebThread());
88     ASSERT(&threadGlobalData() != sharedMainThreadStaticData);
89
90     // Set WebThread's ThreadGlobalData object to be the same as the main UI thread.
91     **staticData = adoptRef(sharedMainThreadStaticData);
92
93     ASSERT(&threadGlobalData() == sharedMainThreadStaticData);
94 }
95
96 ThreadGlobalData& threadGlobalData()
97 {
98     if (UNLIKELY(!staticData)) {
99         staticData = new ThreadSpecific<RefPtr<ThreadGlobalData>>;
100         auto& result = **staticData;
101         ASSERT(!result);
102         result = adoptRef(new ThreadGlobalData);
103         // WebThread and main UI thread need to share the same object. Save it in a static
104         // here, the WebThread will pick it up in setWebCoreThreadData().
105         if (pthread_main_np()) {
106             sharedMainThreadStaticData = result.get();
107             result->ref();
108         }
109         return *result;
110     }
111
112     auto& result = **staticData;
113     if (!result)
114         result = adoptRef(new ThreadGlobalData);
115     return *result;
116 }
117
118 #else
119
120 static ThreadSpecific<ThreadGlobalData>* staticData { nullptr };
121
122 ThreadGlobalData& threadGlobalData()
123 {
124     if (UNLIKELY(!staticData))
125         staticData = new ThreadSpecific<ThreadGlobalData>;
126     return **staticData;
127 }
128
129 #endif
130
131 } // namespace WebCore