| 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
|
|
|
| //===----------------------------------------------------------------------===//
|
|
|