Index: include/ports/SkAtomics_std.h |
diff --git a/include/ports/SkAtomics_std.h b/include/ports/SkAtomics_std.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f1fb0e2053083cca8953f442ecc50ed469f52374 |
--- /dev/null |
+++ b/include/ports/SkAtomics_std.h |
@@ -0,0 +1,36 @@ |
+#ifndef SkAtomics_std_DEFINED |
+#define SkAtomics_std_DEFINED |
+ |
+// We try not to depend on the C++ standard library, |
+// but these uses of <atomic> should all inline, so we don't feel to bad here. |
+#include <atomic> |
+ |
+template <typename T> |
+T sk_atomic_load(const T* ptr, sk_memory_order mo) { |
+ const std::atomic<T>* ap = reinterpret_cast<const std::atomic<T>*>(ptr); |
+ return std::atomic_load_explicit(ap, (std::memory_order)mo); |
+} |
+ |
+template <typename T> |
+void sk_atomic_store(T* ptr, T val, sk_memory_order mo) { |
+ std::atomic<T>* ap = reinterpret_cast<std::atomic<T>*>(ptr); |
+ return std::atomic_store_explicit(ap, val, (std::memory_order)mo); |
+} |
+ |
+template <typename T> |
+T sk_atomic_fetch_add(T* ptr, T val, sk_memory_order mo) { |
+ std::atomic<T>* ap = reinterpret_cast<std::atomic<T>*>(ptr); |
+ return std::atomic_fetch_add_explicit(ap, val, (std::memory_order)mo); |
+} |
+ |
+template <typename T> |
+bool sk_atomic_compare_exchange(T* ptr, T* expected, T desired, |
+ sk_memory_order success, |
+ sk_memory_order failure) { |
+ std::atomic<T>* ap = reinterpret_cast<std::atomic<T>*>(ptr); |
+ return std::atomic_compare_exchange_strong_explicit(ap, expected, desired, |
+ (std::memory_order)success, |
+ (std::memory_order)failure); |
+} |
+ |
+#endif//SkAtomics_std_DEFINED |