OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #ifndef VM_ATOMIC_LINUX_H_ | 5 #ifndef VM_ATOMIC_LINUX_H_ |
6 #define VM_ATOMIC_LINUX_H_ | 6 #define VM_ATOMIC_LINUX_H_ |
7 | 7 |
8 #if !defined VM_ATOMIC_H_ | 8 #if !defined VM_ATOMIC_H_ |
9 #error Do not include atomic_linux.h directly. Use atomic.h instead. | 9 #error Do not include atomic_linux.h directly. Use atomic.h instead. |
10 #endif | 10 #endif |
11 | 11 |
12 #if !defined(TARGET_OS_LINUX) | 12 #if !defined(TARGET_OS_LINUX) |
13 #error This file should only be included on Linux builds. | 13 #error This file should only be included on Linux builds. |
14 #endif | 14 #endif |
15 | 15 |
16 namespace dart { | 16 namespace dart { |
17 | 17 |
18 | 18 |
19 inline uintptr_t AtomicOperations::FetchAndIncrement(uintptr_t* p) { | 19 inline uintptr_t AtomicOperations::FetchAndIncrement(uintptr_t* p) { |
20 return __sync_fetch_and_add(p, 1); | 20 return __sync_fetch_and_add(p, 1); |
21 } | 21 } |
22 | 22 |
23 | 23 |
| 24 inline intptr_t AtomicOperations::FetchAndIncrement(intptr_t* p) { |
| 25 return __sync_fetch_and_add(p, 1); |
| 26 } |
| 27 |
| 28 |
24 inline void AtomicOperations::IncrementBy(intptr_t* p, intptr_t value) { | 29 inline void AtomicOperations::IncrementBy(intptr_t* p, intptr_t value) { |
25 __sync_fetch_and_add(p, value); | 30 __sync_fetch_and_add(p, value); |
26 } | 31 } |
27 | 32 |
28 | 33 |
29 inline void AtomicOperations::IncrementInt64By(int64_t* p, int64_t value) { | 34 inline void AtomicOperations::IncrementInt64By(int64_t* p, int64_t value) { |
30 #if defined(TARGET_ARCH_MIPS) | 35 #if defined(TARGET_ARCH_MIPS) |
31 // No double-word atomics on MIPS32. | 36 // No double-word atomics on MIPS32. |
32 *p += value; | 37 *p += value; |
33 #else | 38 #else |
34 __sync_fetch_and_add(p, value); | 39 __sync_fetch_and_add(p, value); |
35 #endif | 40 #endif |
36 } | 41 } |
37 | 42 |
38 | 43 |
39 inline uintptr_t AtomicOperations::FetchAndDecrement(uintptr_t* p) { | 44 inline uintptr_t AtomicOperations::FetchAndDecrement(uintptr_t* p) { |
40 return __sync_fetch_and_sub(p, 1); | 45 return __sync_fetch_and_sub(p, 1); |
41 } | 46 } |
42 | 47 |
43 | 48 |
| 49 inline intptr_t AtomicOperations::FetchAndDecrement(intptr_t* p) { |
| 50 return __sync_fetch_and_sub(p, 1); |
| 51 } |
| 52 |
| 53 |
44 inline void AtomicOperations::DecrementBy(intptr_t* p, intptr_t value) { | 54 inline void AtomicOperations::DecrementBy(intptr_t* p, intptr_t value) { |
45 __sync_fetch_and_sub(p, value); | 55 __sync_fetch_and_sub(p, value); |
46 } | 56 } |
47 | 57 |
48 | 58 |
49 #if !defined(USING_SIMULATOR_ATOMICS) | 59 #if !defined(USING_SIMULATOR_ATOMICS) |
50 inline uword AtomicOperations::CompareAndSwapWord(uword* ptr, | 60 inline uword AtomicOperations::CompareAndSwapWord(uword* ptr, |
51 uword old_value, | 61 uword old_value, |
52 uword new_value) { | 62 uword new_value) { |
53 return __sync_val_compare_and_swap(ptr, old_value, new_value); | 63 return __sync_val_compare_and_swap(ptr, old_value, new_value); |
54 } | 64 } |
55 | 65 |
56 | 66 |
57 inline uint32_t AtomicOperations::CompareAndSwapUint32(uint32_t* ptr, | 67 inline uint32_t AtomicOperations::CompareAndSwapUint32(uint32_t* ptr, |
58 uint32_t old_value, | 68 uint32_t old_value, |
59 uint32_t new_value) { | 69 uint32_t new_value) { |
60 return __sync_val_compare_and_swap(ptr, old_value, new_value); | 70 return __sync_val_compare_and_swap(ptr, old_value, new_value); |
61 } | 71 } |
62 #endif // !defined(USING_SIMULATOR_ATOMICS) | 72 #endif // !defined(USING_SIMULATOR_ATOMICS) |
63 | 73 |
64 } // namespace dart | 74 } // namespace dart |
65 | 75 |
66 #endif // VM_ATOMIC_LINUX_H_ | 76 #endif // VM_ATOMIC_LINUX_H_ |
OLD | NEW |