aboutsummaryrefslogtreecommitdiffhomepage
path: root/include/core
diff options
context:
space:
mode:
authorGravatar herb <herb@google.com>2015-09-04 10:38:58 -0700
committerGravatar Commit bot <commit-bot@chromium.org>2015-09-04 10:38:58 -0700
commit6f2a486040cb25465990196c229feb47e668e87f (patch)
treefc63ba7119fad3229790ce920f5580fd75b7b7c8 /include/core
parent714a710c428c3166b729b7756199927ab85eb69e (diff)
Parallel cache.
TBR=reed@google.com BUG=skia:1330 Review URL: https://codereview.chromium.org/1264103003
Diffstat (limited to 'include/core')
-rw-r--r--include/core/SkAtomics.h7
1 files changed, 7 insertions, 0 deletions
diff --git a/include/core/SkAtomics.h b/include/core/SkAtomics.h
index d31d9c64fb..7c5294b76d 100644
--- a/include/core/SkAtomics.h
+++ b/include/core/SkAtomics.h
@@ -30,6 +30,9 @@ template <typename T>
T sk_atomic_fetch_add(T*, T, sk_memory_order = sk_memory_order_seq_cst);
template <typename T>
+T sk_atomic_fetch_sub(T*, T, sk_memory_order = sk_memory_order_seq_cst);
+
+template <typename T>
bool sk_atomic_compare_exchange(T*, T* expected, T desired,
sk_memory_order success = sk_memory_order_seq_cst,
sk_memory_order failure = sk_memory_order_seq_cst);
@@ -58,6 +61,10 @@ public:
return sk_atomic_fetch_add(&fVal, val, mo);
}
+ T fetch_sub(const T& val, sk_memory_order mo = sk_memory_order_seq_cst) {
+ return sk_atomic_fetch_sub(&fVal, val, mo);
+ }
+
bool compare_exchange(T* expected, const T& desired,
sk_memory_order success = sk_memory_order_seq_cst,
sk_memory_order failure = sk_memory_order_seq_cst) {