OLD | NEW |
| (Empty) |
1 /* | |
2 * Copyright 2014 Google Inc. | |
3 * | |
4 * Use of this source code is governed by a BSD-style license that can be | |
5 * found in the LICENSE file. | |
6 */ | |
7 | |
8 #ifndef SkBarriers_x86_DEFINED | |
9 #define SkBarriers_x86_DEFINED | |
10 | |
11 #ifdef SK_BUILD_FOR_WIN | |
12 # include <intrin.h> | |
13 static inline void sk_compiler_barrier() { _ReadWriteBarrier(); } | |
14 #else | |
15 static inline void sk_compiler_barrier() { asm volatile("" : : : "memory"); } | |
16 #endif | |
17 | |
18 template <typename T> | |
19 T sk_acquire_load(T* ptr) { | |
20 T val = *ptr; | |
21 // On x86, all loads are acquire loads, so we only need a compiler barrier. | |
22 sk_compiler_barrier(); | |
23 return val; | |
24 } | |
25 | |
26 template <typename T> | |
27 T sk_consume_load(T* ptr) { | |
28 // On x86, consume is the same as acquire, i.e. a normal load. | |
29 return sk_acquire_load(ptr); | |
30 } | |
31 | |
32 template <typename T> | |
33 void sk_release_store(T* ptr, T val) { | |
34 // On x86, all stores are release stores, so we only need a compiler barrier
. | |
35 sk_compiler_barrier(); | |
36 *ptr = val; | |
37 } | |
38 | |
39 #endif//SkBarriers_x86_DEFINED | |
OLD | NEW |