]> git.saurik.com Git - apple/javascriptcore.git/blobdiff - runtime/InitializeThreading.cpp
JavaScriptCore-7601.1.46.3.tar.gz
[apple/javascriptcore.git] / runtime / InitializeThreading.cpp
index 4c0e123a493bf68bcda2d8904a76e0bddde5a9da..2d7adbd0da5262c84608b243eba0a0912f71680a 100644 (file)
@@ -10,7 +10,7 @@
  * 2.  Redistributions in binary form must reproduce the above copyright
  *     notice, this list of conditions and the following disclaimer in the
  *     documentation and/or other materials provided with the distribution. 
- * 3.  Neither the name of Apple Computer, Inc. ("Apple") nor the names of
+ * 3.  Neither the name of Apple Inc. ("Apple") nor the names of
  *     its contributors may be used to endorse or promote products derived
  *     from this software without specific prior written permission. 
  *
 
 #include "ExecutableAllocator.h"
 #include "Heap.h"
+#include "HeapStatistics.h"
 #include "Options.h"
 #include "Identifier.h"
 #include "JSDateMath.h"
 #include "JSGlobalObject.h"
-#include "UString.h"
+#include "JSLock.h"
+#include "LLIntData.h"
+#include "StructureIDTable.h"
 #include "WriteBarrier.h"
+#include <mutex>
 #include <wtf/dtoa.h>
 #include <wtf/Threading.h>
 #include <wtf/dtoa/cached-powers.h>
@@ -45,35 +49,31 @@ using namespace WTF;
 
 namespace JSC {
 
-#if OS(DARWIN)
-static pthread_once_t initializeThreadingKeyOnce = PTHREAD_ONCE_INIT;
-#endif
-
-static void initializeThreadingOnce()
+void initializeThreading()
 {
-    WTF::double_conversion::initialize();
-    WTF::initializeThreading();
-    Options::initializeOptions();
+    static std::once_flag initializeThreadingOnceFlag;
+
+    std::call_once(initializeThreadingOnceFlag, []{
+        WTF::double_conversion::initialize();
+        WTF::initializeThreading();
+        GlobalJSLock::initialize();
+        Options::initialize();
+        if (Options::recordGCPauseTimes())
+            HeapStatistics::initialize();
 #if ENABLE(WRITE_BARRIER_PROFILING)
-    WriteBarrierCounters::initialize();
+        WriteBarrierCounters::initialize();
 #endif
 #if ENABLE(ASSEMBLER)
-    ExecutableAllocator::initializeAllocator();
+        ExecutableAllocator::initializeAllocator();
 #endif
-    RegisterFile::initializeThreading();
-}
-
-void initializeThreading()
-{
-#if OS(DARWIN)
-    pthread_once(&initializeThreadingKeyOnce, initializeThreadingOnce);
-#else
-    static bool initializedThreading = false;
-    if (!initializedThreading) {
-        initializeThreadingOnce();
-        initializedThreading = true;
-    }
+        JSStack::initializeThreading();
+        LLInt::initialize();
+#ifndef NDEBUG
+        DisallowGC::initialize();
 #endif
+        WTFThreadData& threadData = wtfThreadData();
+        threadData.setSavedLastStackTop(threadData.stack().origin());
+    });
 }
 
 } // namespace JSC