diff options
Diffstat (limited to 'include/llvm/IntrinsicsPTX.td')
-rw-r--r-- | include/llvm/IntrinsicsPTX.td | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/include/llvm/IntrinsicsPTX.td b/include/llvm/IntrinsicsPTX.td new file mode 100644 index 0000000000..ec291e467e --- /dev/null +++ b/include/llvm/IntrinsicsPTX.td @@ -0,0 +1,32 @@ +//===- IntrinsicsPTX.td - Defines PTX intrinsics -----------*- tablegen -*-===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// +// +// This file defines all of the PTX-specific intrinsics. +// +//===----------------------------------------------------------------------===// + +let TargetPrefix = "ptx" in { + multiclass PTXReadSpecialRegisterIntrinsic { + def _r64 : Intrinsic<[llvm_i64_ty], [], [IntrNoMem]>; + def _v4i16 : Intrinsic<[llvm_v4i16_ty], [], [IntrNoMem]>; + } + + multiclass PTXReadSpecialSubRegisterIntrinsic { + def _x : Intrinsic<[llvm_i16_ty], [], [IntrNoMem]>; + def _y : Intrinsic<[llvm_i16_ty], [], [IntrNoMem]>; + def _z : Intrinsic<[llvm_i16_ty], [], [IntrNoMem]>; + def _w : Intrinsic<[llvm_i16_ty], [], [IntrNoMem]>; + } +} + +defm int_ptx_read_tid : PTXReadSpecialRegisterIntrinsic; +defm int_ptx_read_tid : PTXReadSpecialSubRegisterIntrinsic; + +let TargetPrefix = "ptx" in + def int_ptx_bar_sync : Intrinsic<[], [llvm_i32_ty], []>; |