OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #ifndef SkAtomics_atomic_DEFINED | 8 #ifndef SkAtomics_atomic_DEFINED |
9 #define SkAtomics_atomic_DEFINED | 9 #define SkAtomics_atomic_DEFINED |
10 | 10 |
(...skipping 14 matching lines...) Expand all Loading... |
25 __atomic_store_n(ptr, val, mo); | 25 __atomic_store_n(ptr, val, mo); |
26 } | 26 } |
27 | 27 |
28 template <typename T> | 28 template <typename T> |
29 T sk_atomic_fetch_add(T* ptr, T val, sk_memory_order mo) { | 29 T sk_atomic_fetch_add(T* ptr, T val, sk_memory_order mo) { |
30 // All values of mo are valid. | 30 // All values of mo are valid. |
31 return __atomic_fetch_add(ptr, val, mo); | 31 return __atomic_fetch_add(ptr, val, mo); |
32 } | 32 } |
33 | 33 |
34 template <typename T> | 34 template <typename T> |
35 T sk_atomic_fetch_sub(T* ptr, T val, sk_memory_order mo) { | |
36 // All values of mo are valid. | |
37 return __atomic_fetch_sub(ptr, val, mo); | |
38 } | |
39 | |
40 template <typename T> | |
41 bool sk_atomic_compare_exchange(T* ptr, T* expected, T desired, | 35 bool sk_atomic_compare_exchange(T* ptr, T* expected, T desired, |
42 sk_memory_order success, | 36 sk_memory_order success, |
43 sk_memory_order failure) { | 37 sk_memory_order failure) { |
44 // All values of success are valid. | 38 // All values of success are valid. |
45 SkASSERT(failure == sk_memory_order_relaxed || | 39 SkASSERT(failure == sk_memory_order_relaxed || |
46 failure == sk_memory_order_seq_cst || | 40 failure == sk_memory_order_seq_cst || |
47 failure == sk_memory_order_acquire || | 41 failure == sk_memory_order_acquire || |
48 failure == sk_memory_order_consume); | 42 failure == sk_memory_order_consume); |
49 SkASSERT(failure <= success); | 43 SkASSERT(failure <= success); |
50 return __atomic_compare_exchange_n(ptr, expected, desired, false/*weak?*/, s
uccess, failure); | 44 return __atomic_compare_exchange_n(ptr, expected, desired, false/*weak?*/, s
uccess, failure); |
51 } | 45 } |
52 | 46 |
53 template <typename T> | 47 template <typename T> |
54 T sk_atomic_exchange(T* ptr, T val, sk_memory_order mo) { | 48 T sk_atomic_exchange(T* ptr, T val, sk_memory_order mo) { |
55 // All values of mo are valid. | 49 // All values of mo are valid. |
56 return __atomic_exchange_n(ptr, val, mo); | 50 return __atomic_exchange_n(ptr, val, mo); |
57 } | 51 } |
58 | 52 |
59 #endif//SkAtomics_atomic_DEFINED | 53 #endif//SkAtomics_atomic_DEFINED |
OLD | NEW |