OLD | NEW |
---|---|
1 //===-- llvm/IR/NaClAtomicIntrinsics.h - NaCl Atomic Intrinsics -*- C++ -*-===// | 1 //===-- llvm/IR/NaClAtomicIntrinsics.h - NaCl Atomic Intrinsics -*- C++ -*-===// |
2 // | 2 // |
3 // The LLVM Compiler Infrastructure | 3 // The LLVM Compiler Infrastructure |
4 // | 4 // |
5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
7 // | 7 // |
8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
9 // | 9 // |
10 // This file describes atomic intrinsic functions that are specific to NaCl. | 10 // This file describes atomic intrinsic functions that are specific to NaCl. |
(...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
93 /// Do not reorder these values: their order offers forward | 93 /// Do not reorder these values: their order offers forward |
94 /// compatibility of bitcode targeted to NaCl. | 94 /// compatibility of bitcode targeted to NaCl. |
95 enum MemoryOrder { | 95 enum MemoryOrder { |
96 MemoryOrderInvalid = 0, // Invalid, keep first. | 96 MemoryOrderInvalid = 0, // Invalid, keep first. |
97 MemoryOrderRelaxed, | 97 MemoryOrderRelaxed, |
98 MemoryOrderConsume, | 98 MemoryOrderConsume, |
99 MemoryOrderAcquire, | 99 MemoryOrderAcquire, |
100 MemoryOrderRelease, | 100 MemoryOrderRelease, |
101 MemoryOrderAcquireRelease, | 101 MemoryOrderAcquireRelease, |
102 MemoryOrderSequentiallyConsistent, | 102 MemoryOrderSequentiallyConsistent, |
103 // The following memory order is specific to PNaCl and is used to | |
104 // support non-C11/C++11 legacy code which uses the __sync_synchronize | |
105 // GCC-style builtin and the asm("":::"memory") compiler fence | |
106 // idiom. It's equivalent to MemoryOrderSequentiallyConsistent | |
107 // surrounded by compiler barriers, which means that in practice is | |
108 // should prevent reordering of memory accesses to objects which may | |
109 // escape. | |
110 MemoryOrderSequentiallyConsistentAll, | |
jvoung (off chromium)
2013/08/05 23:21:22
I guess the thing with having this in the general
JF
2013/08/05 23:25:50
Good point, I could make a separate @llvm.nacl.ato
| |
103 MemoryOrderNum // Invalid, keep last. | 111 MemoryOrderNum // Invalid, keep last. |
104 }; | 112 }; |
105 | 113 |
106 } // End NaCl namespace | 114 } // End NaCl namespace |
107 | 115 |
108 } // End llvm namespace | 116 } // End llvm namespace |
109 | 117 |
110 #endif | 118 #endif |
OLD | NEW |