2 * Copyright (C) 2008 Apple Inc. All Rights Reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
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.
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, 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 COMPUTER, 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.
27 #ifndef WorkerThread_h
28 #define WorkerThread_h
30 #include "core/dom/ExecutionContextTask.h"
31 #include "core/frame/csp/ContentSecurityPolicy.h"
32 #include "core/workers/WorkerGlobalScope.h"
33 #include "platform/SharedTimer.h"
34 #include "platform/WebThreadSupportingGC.h"
35 #include "platform/weborigin/SecurityOrigin.h"
36 #include "wtf/Forward.h"
37 #include "wtf/MessageQueue.h"
38 #include "wtf/OwnPtr.h"
39 #include "wtf/PassRefPtr.h"
40 #include "wtf/RefCounted.h"
45 class WebWaitableEvent;
46 class WorkerGlobalScope;
47 class WorkerInspectorController;
48 class WorkerLoaderProxy;
49 class WorkerReportingProxy;
50 class WorkerSharedTimer;
51 class WorkerThreadShutdownFinishTask;
52 class WorkerThreadStartupData;
53 class WorkerThreadTask;
55 enum WorkerThreadStartMode {
56 DontPauseWorkerGlobalScopeOnStart,
57 PauseWorkerGlobalScopeOnStart
60 class WorkerThread : public RefCounted<WorkerThread> {
62 virtual ~WorkerThread();
67 // Can be used to wait for this worker thread to shut down.
68 // (This is signalled on the main thread, so it's assumed to be waited on the worker context thread)
69 WebWaitableEvent* shutdownEvent() { return m_shutdownEvent.get(); }
71 WebWaitableEvent* terminationEvent() { return m_terminationEvent.get(); }
72 void terminateAndWait();
73 static void terminateAndWaitForAllWorkers();
75 bool isCurrentThread() const;
76 WorkerLoaderProxy& workerLoaderProxy() const { return m_workerLoaderProxy; }
77 WorkerReportingProxy& workerReportingProxy() const { return m_workerReportingProxy; }
79 void postTask(PassOwnPtr<ExecutionContextTask>);
80 void postDebuggerTask(PassOwnPtr<ExecutionContextTask>);
82 enum WaitMode { WaitForMessage, DontWaitForMessage };
83 MessageQueueWaitResult runDebuggerTask(WaitMode = WaitForMessage);
85 // These methods should be called if the holder of the thread is
86 // going to call runDebuggerTask in a loop.
87 void willEnterNestedLoop();
88 void didLeaveNestedLoop();
90 WorkerGlobalScope* workerGlobalScope() const { return m_workerGlobalScope.get(); }
93 // Number of active worker threads.
94 static unsigned workerThreadCount();
96 PlatformThreadId platformThreadId() const;
98 void interruptAndDispatchInspectorCommands();
99 void setWorkerInspectorController(WorkerInspectorController*);
102 WorkerThread(WorkerLoaderProxy&, WorkerReportingProxy&, PassOwnPtrWillBeRawPtr<WorkerThreadStartupData>);
104 // Factory method for creating a new worker context for the thread.
105 virtual PassRefPtrWillBeRawPtr<WorkerGlobalScope> createWorkerGlobalScope(PassOwnPtrWillBeRawPtr<WorkerThreadStartupData>) = 0;
107 virtual void postInitialize() { }
110 friend class WorkerSharedTimer;
111 friend class WorkerThreadShutdownFinishTask;
113 void stopInShutdownSequence();
119 void postDelayedTask(PassOwnPtr<ExecutionContextTask>, long long delayMs);
122 OwnPtr<WorkerSharedTimer> m_sharedTimer;
123 MessageQueue<WorkerThreadTask> m_debuggerMessageQueue;
124 OwnPtr<WebThread::TaskObserver> m_microtaskRunner;
126 WorkerLoaderProxy& m_workerLoaderProxy;
127 WorkerReportingProxy& m_workerReportingProxy;
129 RefPtrWillBePersistent<WorkerInspectorController> m_workerInspectorController;
130 Mutex m_workerInspectorControllerMutex;
132 Mutex m_threadCreationMutex;
133 RefPtrWillBePersistent<WorkerGlobalScope> m_workerGlobalScope;
134 OwnPtrWillBePersistent<WorkerThreadStartupData> m_startupData;
136 // Used to signal thread shutdown.
137 OwnPtr<WebWaitableEvent> m_shutdownEvent;
139 // Used to signal thread termination.
140 OwnPtr<WebWaitableEvent> m_terminationEvent;
142 // FIXME: This has to be last because of crbug.com/401397 - the
143 // WorkerThread might get deleted before it had a chance to properly
144 // shut down. By deleting the WebThread first, we can guarantee that
145 // no pending tasks on the thread might want to access any of the other
146 // members during the WorkerThread's destruction.
147 OwnPtr<WebThreadSupportingGC> m_thread;
152 #endif // WorkerThread_h