Index: include/llvm/IR/Intrinsics.td |
diff --git a/include/llvm/IR/Intrinsics.td b/include/llvm/IR/Intrinsics.td |
index 3e496204350e8fc932d2070af8be7a8ea7fff48a..ef15ceb1588a8a385f3a24050708637450ccc010 100644 |
--- a/include/llvm/IR/Intrinsics.td |
+++ b/include/llvm/IR/Intrinsics.td |
@@ -498,6 +498,34 @@ def int_nacl_tp_tdb_offset : Intrinsic<[llvm_i32_ty], [llvm_i32_ty]>, |
// pnaclintrin.h. |
def int_nacl_target_arch : Intrinsic<[llvm_i32_ty], []>, |
GCCBuiltin<"__builtin_nacl_target_arch">; |
+ |
+// Atomic intrinsics. |
+// |
+// Volatiles and atomics are encoded through these intrinsics to make |
+// them platform-independent, remove some of LLVM's legacy, and isolate |
+// PNaCl from future changes to IR. The intrinsics allow user code to |
+// use `__sync_*` builtins as well as C11/C++11 atomics. |
+// |
+// These are further documented in docs/PNaClLangRef.rst. |
+// |
+// Note that IntrReadWriteArgMem is used in all cases to prevent |
+// reordering. |
+def int_nacl_atomic_load : Intrinsic<[llvm_anyint_ty], |
+ [LLVMPointerType<LLVMMatchType<0>>, llvm_i32_ty], |
+ [IntrReadWriteArgMem]>; |
+def int_nacl_atomic_store : Intrinsic<[], |
+ [llvm_anyint_ty, LLVMPointerType<LLVMMatchType<0>>, llvm_i32_ty], |
+ [IntrReadWriteArgMem]>; |
+def int_nacl_atomic_rmw : Intrinsic<[llvm_anyint_ty], |
+ [llvm_i32_ty, LLVMPointerType<LLVMMatchType<0>>, LLVMMatchType<0>, |
+ llvm_i32_ty], |
+ [IntrReadWriteArgMem]>; |
+def int_nacl_atomic_cmpxchg : Intrinsic<[llvm_anyint_ty], |
+ [LLVMPointerType<LLVMMatchType<0>>, LLVMMatchType<0>, LLVMMatchType<0>, |
+ llvm_i32_ty, llvm_i32_ty], |
+ [IntrReadWriteArgMem]>; |
+def int_nacl_atomic_fence : Intrinsic<[], [llvm_i32_ty], |
+ [IntrReadWriteArgMem]>; |
// @LOCALMOD-END |
//===----------------------------------------------------------------------===// |