aboutsummaryrefslogtreecommitdiffhomepage
path: root/include/ports/SkAtomics_atomic.h
diff options
context:
space:
mode:
authorGravatar mtklein <mtklein@chromium.org>2015-11-12 11:07:53 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2015-11-12 11:07:53 -0800
commit23267db67824a92f045649f571ae1ceaf2cc2b28 (patch)
tree6058957cf726013eaf2c8bdb919d9b98f6a0a194 /include/ports/SkAtomics_atomic.h
parent64593525debc63339e1bf9ddb8a0e998f7d976a3 (diff)
SkAtomic: always use std::atomic
We were doing it on Windows, now do it everywhere. This just changes the backend. We could think about another step to actually replacing all our sk_atomic_... with std atomic stuff. CQ_EXTRA_TRYBOTS=client.skia:Test-Ubuntu-GCC-GCE-CPU-AVX2-x86_64-Release-TSAN-Trybot TBR=reed@google.com Only deleting from include/... Review URL: https://codereview.chromium.org/1441773002
Diffstat (limited to 'include/ports/SkAtomics_atomic.h')
-rw-r--r--include/ports/SkAtomics_atomic.h59
1 files changed, 0 insertions, 59 deletions
diff --git a/include/ports/SkAtomics_atomic.h b/include/ports/SkAtomics_atomic.h
deleted file mode 100644
index 64ee823f90..0000000000
--- a/include/ports/SkAtomics_atomic.h
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright 2015 Google Inc.
- *
- * Use of this source code is governed by a BSD-style license that can be
- * found in the LICENSE file.
- */
-
-#ifndef SkAtomics_atomic_DEFINED
-#define SkAtomics_atomic_DEFINED
-
-template <typename T>
-T sk_atomic_load(const T* ptr, sk_memory_order mo) {
- SkASSERT(mo == sk_memory_order_relaxed ||
- mo == sk_memory_order_seq_cst ||
- mo == sk_memory_order_acquire ||
- mo == sk_memory_order_consume);
- return __atomic_load_n(ptr, mo);
-}
-
-template <typename T>
-void sk_atomic_store(T* ptr, T val, sk_memory_order mo) {
- SkASSERT(mo == sk_memory_order_relaxed ||
- mo == sk_memory_order_seq_cst ||
- mo == sk_memory_order_release);
- __atomic_store_n(ptr, val, mo);
-}
-
-template <typename T>
-T sk_atomic_fetch_add(T* ptr, T val, sk_memory_order mo) {
- // All values of mo are valid.
- return __atomic_fetch_add(ptr, val, mo);
-}
-
-template <typename T>
-T sk_atomic_fetch_sub(T* ptr, T val, sk_memory_order mo) {
- // All values of mo are valid.
- return __atomic_fetch_sub(ptr, val, mo);
-}
-
-template <typename T>
-bool sk_atomic_compare_exchange(T* ptr, T* expected, T desired,
- sk_memory_order success,
- sk_memory_order failure) {
- // All values of success are valid.
- SkASSERT(failure == sk_memory_order_relaxed ||
- failure == sk_memory_order_seq_cst ||
- failure == sk_memory_order_acquire ||
- failure == sk_memory_order_consume);
- SkASSERT(failure <= success);
- return __atomic_compare_exchange_n(ptr, expected, desired, false/*weak?*/, success, failure);
-}
-
-template <typename T>
-T sk_atomic_exchange(T* ptr, T val, sk_memory_order mo) {
- // All values of mo are valid.
- return __atomic_exchange_n(ptr, val, mo);
-}
-
-#endif//SkAtomics_atomic_DEFINED