| Index: runtime/vm/thread.h
|
| ===================================================================
|
| --- runtime/vm/thread.h (revision 45815)
|
| +++ runtime/vm/thread.h (working copy)
|
| @@ -16,13 +16,9 @@
|
|
|
| // A VM thread; may be executing Dart code or performing helper tasks like
|
| // garbage collection or compilation. The Thread structure associated with
|
| -// a thread is allocated when the thread enters an isolate, and destroyed
|
| -// upon an explicit call to CleanUp.
|
| -//
|
| -// NOTE: When the underlying OS thread is started by the embedder, i.e., not
|
| -// part of a ThreadPool managed by the VM, we currently leak the Thread
|
| -// structure after its last isolate exit. We could add an explicit cleanup API,
|
| -// or, on platforms that support it, register a cleanup callback.
|
| +// a thread is allocated by EnsureInit before entering an isolate, and destroyed
|
| +// automatically when the underlying OS thread exits. NOTE: On Windows, CleanUp
|
| +// must currently be called manually (issue 23474).
|
| class Thread {
|
| public:
|
| // The currently executing thread, or NULL if not yet initialized.
|
| @@ -30,7 +26,10 @@
|
| return reinterpret_cast<Thread*>(OSThread::GetThreadLocal(thread_key_));
|
| }
|
|
|
| - // Makes the current thread enter 'isolate'. Also calls EnsureInit.
|
| + // Initializes the current thread as a VM thread, if not already done.
|
| + static void EnsureInit();
|
| +
|
| + // Makes the current thread enter 'isolate'.
|
| static void EnterIsolate(Isolate* isolate);
|
| // Makes the current thread exit its isolate.
|
| static void ExitIsolate();
|
| @@ -42,10 +41,10 @@
|
| static void EnterIsolateAsHelper(Isolate* isolate);
|
| static void ExitIsolateAsHelper();
|
|
|
| - // Initializes the current thread as a VM thread, if not already done.
|
| - static void EnsureInit();
|
| - // Clears the state of the current thread.
|
| +#if defined(TARGET_OS_WINDOWS)
|
| + // Clears the state of the current thread and frees the allocation.
|
| static void CleanUp();
|
| +#endif
|
|
|
| // Called at VM startup.
|
| static void InitOnce();
|
|
|