summaryrefslogtreecommitdiffstats
path: root/skia
diff options
context:
space:
mode:
authorbungeman@chromium.org <bungeman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-16 17:02:38 +0000
committerbungeman@chromium.org <bungeman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-05-16 17:02:38 +0000
commit83968247ce6ac742097c9cc897c37bdbf9d2c102 (patch)
tree02692587581a8ecaf846456c445252cb29ab58f5 /skia
parentec0d07e46cc6c193f6c5d98b8dd2c87a9d90122a (diff)
downloadchromium_src-83968247ce6ac742097c9cc897c37bdbf9d2c102.zip
chromium_src-83968247ce6ac742097c9cc897c37bdbf9d2c102.tar.gz
chromium_src-83968247ce6ac742097c9cc897c37bdbf9d2c102.tar.bz2
Add atomics for Skia in preperation for landing http://codereview.appspot.com/5649046/
Review URL: https://chromiumcodereview.appspot.com/10310169 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@137443 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia')
-rw-r--r--skia/ext/SkThread_chrome.cc55
1 files changed, 49 insertions, 6 deletions
diff --git a/skia/ext/SkThread_chrome.cc b/skia/ext/SkThread_chrome.cc
index 8ea584a..4904f2d 100644
--- a/skia/ext/SkThread_chrome.cc
+++ b/skia/ext/SkThread_chrome.cc
@@ -1,4 +1,4 @@
-// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
@@ -11,17 +11,60 @@
#include "base/logging.h"
#include "base/synchronization/lock.h"
+/** Adds one to the int specified by the address (in a thread-safe manner), and
+ returns the previous value.
+ No additional memory barrier is required.
+ This must act as a compiler barrier.
+*/
int32_t sk_atomic_inc(int32_t* addr) {
- // sk_atomic_inc is expected to return the old value, Barrier_AtomicIncrement
- // returns the new value.
- return base::subtle::Barrier_AtomicIncrement(addr, 1) - 1;
+ // sk_atomic_inc is expected to return the old value,
+ // Barrier_AtomicIncrement returns the new value.
+ return base::subtle::NoBarrier_AtomicIncrement(addr, 1) - 1;
}
+/* Subtracts one from the int specified by the address (in a thread-safe
+ manner), and returns the previous value.
+ Expected to act as a release (SL/S) memory barrier and a compiler barrier.
+*/
int32_t sk_atomic_dec(int32_t* addr) {
- // sk_atomic_dec is expected to return the old value, Barrier_AtomicIncrement
- // returns the new value.
+ // sk_atomic_dec is expected to return the old value,
+ // Barrier_AtomicIncrement returns the new value.
return base::subtle::Barrier_AtomicIncrement(addr, -1) + 1;
}
+/** If sk_atomic_dec does not act as an aquire (L/SL) barrier, this is expected
+ to act as an aquire (L/SL) memory barrier and as a compiler barrier.
+*/
+void sk_membar_aquire__after_atomic_dec() { }
+
+/** Adds one to the int specified by the address iff the int specified by the
+ address is not zero (in a thread-safe manner), and returns the previous
+ value.
+ No additional memory barrier is required.
+ This must act as a compiler barrier.
+*/
+int32_t sk_atomic_conditional_inc(int32_t* addr) {
+ int32_t value = *addr;
+
+ while (true) {
+ if (value == 0) {
+ return 0;
+ }
+
+ int32_t before;
+ before = base::subtle::Aquire_CompareAndSwap(addr, value, value + 1);
+
+ if (before == value) {
+ return value;
+ } else {
+ value = before;
+ }
+ }
+}
+/** If sk_atomic_conditional_inc does not act as an aquire (L/SL) barrier, this
+ is expected to act as an aquire (L/SL) memory barrier and as a compiler
+ barrier.
+*/
+void sk_membar_aquire__after_atomic_conditional_inc() { }
SkMutex::SkMutex() {
COMPILE_ASSERT(sizeof(base::Lock) <= sizeof(fStorage), Lock_is_too_big_for_SkMutex);