| Index: include/llvm/IR/Intrinsics.td
|
| diff --git a/include/llvm/IR/Intrinsics.td b/include/llvm/IR/Intrinsics.td
|
| index 3e496204350e8fc932d2070af8be7a8ea7fff48a..2dfcc8e6b6e467763d20e1da79eb0c5116e6da91 100644
|
| --- a/include/llvm/IR/Intrinsics.td
|
| +++ b/include/llvm/IR/Intrinsics.td
|
| @@ -498,6 +498,46 @@ 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.
|
| +//
|
| +// The general signature is:
|
| +// template<typename T>
|
| +// T nacl.atomic.<size>(int32_t operation, T *location, T value,
|
| +// T old_value, int32_t memory_order);
|
| +//
|
| +// Where `T` is a 8, 16, 32 or 64-bit integer (`size` bits), and
|
| +// location is naturally aligned to `T`. Valid `operation` and
|
| +// `memory_order` values are in llvm/IR/NaCl.h.
|
| +//
|
| +// Note that not all arguments are meaningful for all operations:
|
| +// - result = load {atomic|volatile} T* location, align sizeof(T)
|
| +// - store {atomic|volatile} T value, T* location memory_order
|
| +// - result = atomicrmw OP T* location, T value memory_order
|
| +// Where OP is one of: {add, sub, or, and, xor, xchg}
|
| +// - result = cmpxchg T* location, T old_value, T value memory_order
|
| +// - fence memory_order
|
| +def int_nacl_atomic_8 : Intrinsic<[llvm_i8_ty],
|
| + [llvm_i32_ty, LLVMPointerType<llvm_i8_ty>,
|
| + llvm_i8_ty, llvm_i8_ty, llvm_i32_ty],
|
| + [IntrReadWriteArgMem]>;
|
| +def int_nacl_atomic_16 : Intrinsic<[llvm_i16_ty],
|
| + [llvm_i32_ty, LLVMPointerType<llvm_i16_ty>,
|
| + llvm_i16_ty, llvm_i16_ty, llvm_i32_ty],
|
| + [IntrReadWriteArgMem]>;
|
| +def int_nacl_atomic_32 : Intrinsic<[llvm_i32_ty],
|
| + [llvm_i32_ty, LLVMPointerType<llvm_i32_ty>,
|
| + llvm_i32_ty, llvm_i32_ty, llvm_i32_ty],
|
| + [IntrReadWriteArgMem]>;
|
| +def int_nacl_atomic_64 : Intrinsic<[llvm_i64_ty],
|
| + [llvm_i32_ty, LLVMPointerType<llvm_i64_ty>,
|
| + llvm_i64_ty, llvm_i64_ty, llvm_i32_ty],
|
| + [IntrReadWriteArgMem]>;
|
| // @LOCALMOD-END
|
|
|
| //===----------------------------------------------------------------------===//
|
|
|