Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(79)

Side by Side Diff: runtime/vm/atomic_android.h

Issue 2344263002: Fix bad commit of stale patch set of original CL "Make NoReloadScope thread safe" (Closed)
Patch Set: Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « runtime/vm/atomic.h ('k') | runtime/vm/atomic_fuchsia.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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_ANDROID_H_ 5 #ifndef VM_ATOMIC_ANDROID_H_
6 #define VM_ATOMIC_ANDROID_H_ 6 #define VM_ATOMIC_ANDROID_H_
7 7
8 #if !defined VM_ATOMIC_H_ 8 #if !defined VM_ATOMIC_H_
9 #error Do not include atomic_android.h directly. Use atomic.h instead. 9 #error Do not include atomic_android.h directly. Use atomic.h instead.
10 #endif 10 #endif
11 11
12 #if !defined(TARGET_OS_ANDROID) 12 #if !defined(TARGET_OS_ANDROID)
13 #error This file should only be included on Android builds. 13 #error This file should only be included on Android 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 __sync_fetch_and_add(p, value); 35 __sync_fetch_and_add(p, value);
31 } 36 }
32 37
33 38
34 inline uintptr_t AtomicOperations::FetchAndDecrement(uintptr_t* p) { 39 inline uintptr_t AtomicOperations::FetchAndDecrement(uintptr_t* p) {
35 return __sync_fetch_and_sub(p, 1); 40 return __sync_fetch_and_sub(p, 1);
36 } 41 }
37 42
38 43
44 inline intptr_t AtomicOperations::FetchAndDecrement(intptr_t* p) {
45 return __sync_fetch_and_sub(p, 1);
46 }
47
48
39 inline void AtomicOperations::DecrementBy(intptr_t* p, intptr_t value) { 49 inline void AtomicOperations::DecrementBy(intptr_t* p, intptr_t value) {
40 __sync_fetch_and_sub(p, value); 50 __sync_fetch_and_sub(p, value);
41 } 51 }
42 52
43 53
44 #if !defined(USING_SIMULATOR_ATOMICS) 54 #if !defined(USING_SIMULATOR_ATOMICS)
45 inline uword AtomicOperations::CompareAndSwapWord(uword* ptr, 55 inline uword AtomicOperations::CompareAndSwapWord(uword* ptr,
46 uword old_value, 56 uword old_value,
47 uword new_value) { 57 uword new_value) {
48 return __sync_val_compare_and_swap(ptr, old_value, new_value); 58 return __sync_val_compare_and_swap(ptr, old_value, new_value);
49 } 59 }
50 60
51 61
52 inline uint32_t AtomicOperations::CompareAndSwapUint32(uint32_t* ptr, 62 inline uint32_t AtomicOperations::CompareAndSwapUint32(uint32_t* ptr,
53 uint32_t old_value, 63 uint32_t old_value,
54 uint32_t new_value) { 64 uint32_t new_value) {
55 return __sync_val_compare_and_swap(ptr, old_value, new_value); 65 return __sync_val_compare_and_swap(ptr, old_value, new_value);
56 } 66 }
57 #endif // !defined(USING_SIMULATOR_ATOMICS) 67 #endif // !defined(USING_SIMULATOR_ATOMICS)
58 68
59 } // namespace dart 69 } // namespace dart
60 70
61 #endif // VM_ATOMIC_ANDROID_H_ 71 #endif // VM_ATOMIC_ANDROID_H_
OLDNEW
« no previous file with comments | « runtime/vm/atomic.h ('k') | runtime/vm/atomic_fuchsia.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698