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

Unified Diff: src/once.cc

Issue 316133002: Move atomic ops and related files to base library (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: updates Created 6 years, 6 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/once.h ('k') | src/optimizing-compiler-thread.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/once.cc
diff --git a/src/once.cc b/src/once.cc
deleted file mode 100644
index 6a3b9cb56a5eb358e0e45cf575df016827a215d7..0000000000000000000000000000000000000000
--- a/src/once.cc
+++ /dev/null
@@ -1,53 +0,0 @@
-// Copyright 2012 the V8 project authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "src/once.h"
-
-#ifdef _WIN32
-#include <windows.h>
-#else
-#include <sched.h>
-#endif
-
-#include "src/atomicops.h"
-
-namespace v8 {
-namespace internal {
-
-void CallOnceImpl(OnceType* once, PointerArgFunction init_func, void* arg) {
- AtomicWord state = Acquire_Load(once);
- // Fast path. The provided function was already executed.
- if (state == ONCE_STATE_DONE) {
- return;
- }
-
- // The function execution did not complete yet. The once object can be in one
- // of the two following states:
- // - UNINITIALIZED: We are the first thread calling this function.
- // - EXECUTING_FUNCTION: Another thread is already executing the function.
- //
- // First, try to change the state from UNINITIALIZED to EXECUTING_FUNCTION
- // atomically.
- state = Acquire_CompareAndSwap(
- once, ONCE_STATE_UNINITIALIZED, ONCE_STATE_EXECUTING_FUNCTION);
- if (state == ONCE_STATE_UNINITIALIZED) {
- // We are the first thread to call this function, so we have to call the
- // function.
- init_func(arg);
- Release_Store(once, ONCE_STATE_DONE);
- } else {
- // Another thread has already started executing the function. We need to
- // wait until it completes the initialization.
- while (state == ONCE_STATE_EXECUTING_FUNCTION) {
-#ifdef _WIN32
- ::Sleep(0);
-#else
- sched_yield();
-#endif
- state = Acquire_Load(once);
- }
- }
-}
-
-} } // namespace v8::internal
« no previous file with comments | « src/once.h ('k') | src/optimizing-compiler-thread.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698