2006-03-03 02:33:15 +00:00
|
|
|
//===- Intrinsics.td - Defines all LLVM intrinsics ---------*- tablegen -*-===//
|
2009-08-14 20:27:12 +00:00
|
|
|
//
|
2006-03-03 02:33:15 +00:00
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
2007-12-29 22:59:10 +00:00
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
2009-08-14 20:27:12 +00:00
|
|
|
//
|
2006-03-03 02:33:15 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file defines properties of all LLVM intrinsics.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2006-03-24 18:51:56 +00:00
|
|
|
include "llvm/CodeGen/ValueTypes.td"
|
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Properties we keep track of for intrinsics.
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
class IntrinsicProperty;
|
|
|
|
|
2010-08-05 23:36:21 +00:00
|
|
|
// Intr*Mem - Memory properties. An intrinsic is allowed to have at most one of
|
2006-03-03 02:33:15 +00:00
|
|
|
// these properties set. They are listed from the most aggressive (best to use
|
2009-08-14 20:27:12 +00:00
|
|
|
// if correct) to the least aggressive. If no property is set, the worst case
|
2010-08-05 23:36:21 +00:00
|
|
|
// is assumed (it may read and write any memory it can get access to and it may
|
|
|
|
// have other side effects).
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2006-04-10 22:02:59 +00:00
|
|
|
// IntrNoMem - The intrinsic does not access memory or have any other side
|
2006-03-03 02:33:15 +00:00
|
|
|
// effects. It may be CSE'd deleted if dead, etc.
|
2006-04-10 22:02:59 +00:00
|
|
|
def IntrNoMem : IntrinsicProperty;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2006-04-10 22:02:59 +00:00
|
|
|
// IntrReadArgMem - This intrinsic reads only from memory that one of its
|
2011-04-27 18:39:03 +00:00
|
|
|
// pointer-typed arguments points to, but may read an unspecified amount.
|
2006-04-10 22:02:59 +00:00
|
|
|
def IntrReadArgMem : IntrinsicProperty;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
|
|
|
// IntrReadMem - This intrinsic reads from unspecified memory, so it cannot be
|
|
|
|
// moved across stores. However, it can be reordered otherwise and can be
|
|
|
|
// deleted if dead.
|
|
|
|
def IntrReadMem : IntrinsicProperty;
|
|
|
|
|
2010-08-05 23:36:21 +00:00
|
|
|
// IntrReadWriteArgMem - This intrinsic reads and writes only from memory that
|
|
|
|
// one of its arguments points to, but may access an unspecified amount. The
|
|
|
|
// reads and writes may be volatile, but except for this it has no other side
|
|
|
|
// effects.
|
|
|
|
def IntrReadWriteArgMem : IntrinsicProperty;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2008-06-16 20:29:38 +00:00
|
|
|
// Commutative - This intrinsic is commutative: X op Y == Y op X.
|
|
|
|
def Commutative : IntrinsicProperty;
|
|
|
|
|
2011-05-28 06:31:34 +00:00
|
|
|
// Throws - This intrinsic can throw.
|
|
|
|
def Throws : IntrinsicProperty;
|
|
|
|
|
2009-01-12 01:12:03 +00:00
|
|
|
// NoCapture - The specified argument pointer is not captured by the intrinsic.
|
|
|
|
class NoCapture<int argNo> : IntrinsicProperty {
|
|
|
|
int ArgNo = argNo;
|
|
|
|
}
|
|
|
|
|
2013-07-06 00:29:58 +00:00
|
|
|
// ReadOnly - The specified argument pointer is not written to through the
|
|
|
|
// pointer by the intrinsic.
|
|
|
|
class ReadOnly<int argNo> : IntrinsicProperty {
|
|
|
|
int ArgNo = argNo;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ReadNone - The specified argument pointer is not dereferenced by the
|
|
|
|
// intrinsic.
|
|
|
|
class ReadNone<int argNo> : IntrinsicProperty {
|
|
|
|
int ArgNo = argNo;
|
|
|
|
}
|
|
|
|
|
2012-05-27 23:20:41 +00:00
|
|
|
def IntrNoReturn : IntrinsicProperty;
|
|
|
|
|
2014-03-18 23:51:07 +00:00
|
|
|
// IntrNoduplicate - Calls to this intrinsic cannot be duplicated.
|
|
|
|
// Parallels the noduplicate attribute on LLVM IR functions.
|
|
|
|
def IntrNoDuplicate : IntrinsicProperty;
|
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Types used by intrinsics.
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2007-08-04 01:51:18 +00:00
|
|
|
class LLVMType<ValueType vt> {
|
2006-03-24 19:41:10 +00:00
|
|
|
ValueType VT = vt;
|
2006-03-03 02:33:15 +00:00
|
|
|
}
|
|
|
|
|
2012-05-21 23:21:28 +00:00
|
|
|
class LLVMQualPointerType<LLVMType elty, int addrspace>
|
2007-08-04 01:51:18 +00:00
|
|
|
: LLVMType<iPTR>{
|
2007-02-07 20:38:26 +00:00
|
|
|
LLVMType ElTy = elty;
|
2012-05-21 23:21:28 +00:00
|
|
|
int AddrSpace = addrspace;
|
2009-08-14 20:27:12 +00:00
|
|
|
}
|
2007-02-07 20:38:26 +00:00
|
|
|
|
2012-05-21 23:21:28 +00:00
|
|
|
class LLVMPointerType<LLVMType elty>
|
|
|
|
: LLVMQualPointerType<elty, 0>;
|
|
|
|
|
2008-07-30 04:36:53 +00:00
|
|
|
class LLVMAnyPointerType<LLVMType elty>
|
|
|
|
: LLVMType<iPTRAny>{
|
|
|
|
LLVMType ElTy = elty;
|
2009-08-14 20:27:12 +00:00
|
|
|
}
|
2008-07-30 04:36:53 +00:00
|
|
|
|
2009-04-16 21:46:42 +00:00
|
|
|
// Match the type of another intrinsic parameter. Number is an index into the
|
|
|
|
// list of overloaded types for the intrinsic, excluding all the fixed types.
|
|
|
|
// The Number value must refer to a previously listed type. For example:
|
|
|
|
// Intrinsic<[llvm_i32_ty], [llvm_i32_ty, llvm_anyfloat_ty, LLVMMatchType<0>]>
|
|
|
|
// has two overloaded types, the 2nd and 3rd arguments. LLVMMatchType<0>
|
|
|
|
// refers to the first overloaded type, which is the 2nd argument.
|
2007-08-04 01:51:18 +00:00
|
|
|
class LLVMMatchType<int num>
|
|
|
|
: LLVMType<OtherVT>{
|
|
|
|
int Number = num;
|
2008-02-21 06:45:13 +00:00
|
|
|
}
|
2007-02-07 20:38:26 +00:00
|
|
|
|
2014-03-28 12:31:39 +00:00
|
|
|
// Match the type of another intrinsic parameter that is expected to be based on
|
|
|
|
// an integral type (i.e. either iN or <N x iM>), but change the scalar size to
|
|
|
|
// be twice as wide or half as wide as the other type. This is only useful when
|
|
|
|
// the intrinsic is overloaded, so the matched type should be declared as iAny.
|
|
|
|
class LLVMExtendedType<int num> : LLVMMatchType<num>;
|
|
|
|
class LLVMTruncatedType<int num> : LLVMMatchType<num>;
|
2009-01-07 00:09:01 +00:00
|
|
|
|
2014-03-29 07:04:54 +00:00
|
|
|
// Match the type of another intrinsic parameter that is expected to be a
|
|
|
|
// vector type, but change the element count to be half as many
|
|
|
|
class LLVMHalfElementsVectorType<int num> : LLVMMatchType<num>;
|
|
|
|
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_void_ty : LLVMType<isVoid>;
|
|
|
|
def llvm_anyint_ty : LLVMType<iAny>;
|
2007-08-16 21:57:19 +00:00
|
|
|
def llvm_anyfloat_ty : LLVMType<fAny>;
|
2009-08-11 01:14:02 +00:00
|
|
|
def llvm_anyvector_ty : LLVMType<vAny>;
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_i1_ty : LLVMType<i1>;
|
|
|
|
def llvm_i8_ty : LLVMType<i8>;
|
|
|
|
def llvm_i16_ty : LLVMType<i16>;
|
|
|
|
def llvm_i32_ty : LLVMType<i32>;
|
|
|
|
def llvm_i64_ty : LLVMType<i64>;
|
2013-01-11 01:45:05 +00:00
|
|
|
def llvm_half_ty : LLVMType<f16>;
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_float_ty : LLVMType<f32>;
|
|
|
|
def llvm_double_ty : LLVMType<f64>;
|
2007-09-28 01:08:20 +00:00
|
|
|
def llvm_f80_ty : LLVMType<f80>;
|
|
|
|
def llvm_f128_ty : LLVMType<f128>;
|
|
|
|
def llvm_ppcf128_ty : LLVMType<ppcf128>;
|
2007-02-07 20:38:26 +00:00
|
|
|
def llvm_ptr_ty : LLVMPointerType<llvm_i8_ty>; // i8*
|
|
|
|
def llvm_ptrptr_ty : LLVMPointerType<llvm_ptr_ty>; // i8**
|
2008-10-10 01:41:18 +00:00
|
|
|
def llvm_anyptr_ty : LLVMAnyPointerType<llvm_i8_ty>; // (space)i8*
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_empty_ty : LLVMType<OtherVT>; // { }
|
2007-02-07 20:38:26 +00:00
|
|
|
def llvm_descriptor_ty : LLVMPointerType<llvm_empty_ty>; // { }*
|
2009-08-28 23:24:31 +00:00
|
|
|
def llvm_metadata_ty : LLVMType<MetadataVT>; // !{...}
|
2006-03-24 19:41:10 +00:00
|
|
|
|
2010-09-07 20:03:56 +00:00
|
|
|
def llvm_x86mmx_ty : LLVMType<x86mmx>;
|
2010-09-17 00:33:03 +00:00
|
|
|
def llvm_ptrx86mmx_ty : LLVMPointerType<llvm_x86mmx_ty>; // <1 x i64>*
|
2010-09-07 20:03:56 +00:00
|
|
|
|
2012-09-19 22:47:07 +00:00
|
|
|
def llvm_v2i1_ty : LLVMType<v2i1>; // 2 x i1
|
|
|
|
def llvm_v4i1_ty : LLVMType<v4i1>; // 4 x i1
|
|
|
|
def llvm_v8i1_ty : LLVMType<v8i1>; // 8 x i1
|
|
|
|
def llvm_v16i1_ty : LLVMType<v16i1>; // 16 x i1
|
2012-12-24 10:03:57 +00:00
|
|
|
def llvm_v32i1_ty : LLVMType<v32i1>; // 32 x i1
|
|
|
|
def llvm_v64i1_ty : LLVMType<v64i1>; // 64 x i1
|
2013-09-24 02:47:27 +00:00
|
|
|
def llvm_v1i8_ty : LLVMType<v1i8>; // 1 x i8
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v2i8_ty : LLVMType<v2i8>; // 2 x i8
|
|
|
|
def llvm_v4i8_ty : LLVMType<v4i8>; // 4 x i8
|
|
|
|
def llvm_v8i8_ty : LLVMType<v8i8>; // 8 x i8
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_v16i8_ty : LLVMType<v16i8>; // 16 x i8
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v32i8_ty : LLVMType<v32i8>; // 32 x i8
|
2012-12-24 10:03:57 +00:00
|
|
|
def llvm_v64i8_ty : LLVMType<v64i8>; // 64 x i8
|
|
|
|
|
2012-09-19 22:47:07 +00:00
|
|
|
def llvm_v1i16_ty : LLVMType<v1i16>; // 1 x i16
|
2010-08-31 21:53:15 +00:00
|
|
|
def llvm_v2i16_ty : LLVMType<v2i16>; // 2 x i16
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v4i16_ty : LLVMType<v4i16>; // 4 x i16
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_v8i16_ty : LLVMType<v8i16>; // 8 x i16
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v16i16_ty : LLVMType<v16i16>; // 16 x i16
|
2012-12-24 10:03:57 +00:00
|
|
|
def llvm_v32i16_ty : LLVMType<v32i16>; // 32 x i16
|
|
|
|
|
2012-09-19 22:47:07 +00:00
|
|
|
def llvm_v1i32_ty : LLVMType<v1i32>; // 1 x i32
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_v2i32_ty : LLVMType<v2i32>; // 2 x i32
|
|
|
|
def llvm_v4i32_ty : LLVMType<v4i32>; // 4 x i32
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v8i32_ty : LLVMType<v8i32>; // 8 x i32
|
2012-07-26 21:22:00 +00:00
|
|
|
def llvm_v16i32_ty : LLVMType<v16i32>; // 16 x i32
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v1i64_ty : LLVMType<v1i64>; // 1 x i64
|
|
|
|
def llvm_v2i64_ty : LLVMType<v2i64>; // 2 x i64
|
|
|
|
def llvm_v4i64_ty : LLVMType<v4i64>; // 4 x i64
|
2012-07-26 21:22:00 +00:00
|
|
|
def llvm_v8i64_ty : LLVMType<v8i64>; // 8 x i64
|
|
|
|
def llvm_v16i64_ty : LLVMType<v16i64>; // 16 x i64
|
2009-06-29 16:47:10 +00:00
|
|
|
|
2013-10-03 03:29:21 +00:00
|
|
|
def llvm_v2f16_ty : LLVMType<v2f16>; // 2 x half (__fp16)
|
|
|
|
def llvm_v4f16_ty : LLVMType<v4f16>; // 4 x half (__fp16)
|
[Mips][msa] Added the simple builtins (fadd to ftq)
Includes:
fadd, fceq, fcg[et], fclass, fcl[et], fcne, fcun, fdiv, fexdo, fexp2,
fexup[lr], ffint_[su], ffql, ffqr, fill, flog2, fmadd, fmax, fmax_a, fmin,
fmin_a, fmsub, fmul, frint, frcp, frsqrt, fseq, fsge, fsgt, fsle, fslt,
fsne, fsqr, fsub, ftint_s, ftq
Patch by Daniel Sanders
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188458 91177308-0d34-0410-b5e6-96231b3b80d8
2013-08-15 13:45:36 +00:00
|
|
|
def llvm_v8f16_ty : LLVMType<v8f16>; // 8 x half (__fp16)
|
2013-09-24 02:47:27 +00:00
|
|
|
def llvm_v1f32_ty : LLVMType<v1f32>; // 1 x float
|
2009-06-22 23:27:02 +00:00
|
|
|
def llvm_v2f32_ty : LLVMType<v2f32>; // 2 x float
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_v4f32_ty : LLVMType<v4f32>; // 4 x float
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v8f32_ty : LLVMType<v8f32>; // 8 x float
|
2012-12-24 10:03:57 +00:00
|
|
|
def llvm_v16f32_ty : LLVMType<v16f32>; // 16 x float
|
2013-09-24 02:47:27 +00:00
|
|
|
def llvm_v1f64_ty : LLVMType<v1f64>; // 1 x double
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_v2f64_ty : LLVMType<v2f64>; // 2 x double
|
2009-06-29 16:47:10 +00:00
|
|
|
def llvm_v4f64_ty : LLVMType<v4f64>; // 4 x double
|
2012-12-24 10:03:57 +00:00
|
|
|
def llvm_v8f64_ty : LLVMType<v8f64>; // 8 x double
|
2007-03-08 22:09:11 +00:00
|
|
|
|
2007-08-04 01:51:18 +00:00
|
|
|
def llvm_vararg_ty : LLVMType<isVoid>; // this means vararg here
|
2007-02-06 18:02:54 +00:00
|
|
|
|
2009-06-29 16:47:10 +00:00
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Intrinsic Definitions.
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
// Intrinsic class - This is used to define one LLVM intrinsic. The name of the
|
|
|
|
// intrinsic definition should start with "int_", then match the LLVM intrinsic
|
|
|
|
// name with the "llvm." prefix removed, and all "."s turned into "_"s. For
|
|
|
|
// example, llvm.bswap.i16 -> int_bswap_i16.
|
|
|
|
//
|
2008-11-13 09:08:33 +00:00
|
|
|
// * RetTypes is a list containing the return types expected for the
|
|
|
|
// intrinsic.
|
|
|
|
// * ParamTypes is a list containing the parameter types expected for the
|
|
|
|
// intrinsic.
|
2006-03-03 02:33:15 +00:00
|
|
|
// * Properties can be set to describe the behavior of the intrinsic.
|
|
|
|
//
|
2012-07-10 00:51:11 +00:00
|
|
|
class SDPatternOperator;
|
2008-11-13 09:08:33 +00:00
|
|
|
class Intrinsic<list<LLVMType> ret_types,
|
|
|
|
list<LLVMType> param_types = [],
|
2006-03-03 02:33:15 +00:00
|
|
|
list<IntrinsicProperty> properties = [],
|
2012-07-10 00:51:11 +00:00
|
|
|
string name = ""> : SDPatternOperator {
|
2006-03-03 02:33:15 +00:00
|
|
|
string LLVMName = name;
|
2006-03-15 01:32:36 +00:00
|
|
|
string TargetPrefix = ""; // Set to a prefix for target-specific intrinsics.
|
2008-11-13 09:08:33 +00:00
|
|
|
list<LLVMType> RetTypes = ret_types;
|
|
|
|
list<LLVMType> ParamTypes = param_types;
|
2006-03-03 02:33:15 +00:00
|
|
|
list<IntrinsicProperty> Properties = properties;
|
2009-02-05 01:49:45 +00:00
|
|
|
|
|
|
|
bit isTarget = 0;
|
2006-03-03 02:33:15 +00:00
|
|
|
}
|
|
|
|
|
2006-03-13 22:38:32 +00:00
|
|
|
/// GCCBuiltin - If this intrinsic exactly corresponds to a GCC builtin, this
|
|
|
|
/// specifies the name of the builtin. This provides automatic CBE and CFE
|
|
|
|
/// support.
|
|
|
|
class GCCBuiltin<string name> {
|
|
|
|
string GCCBuiltinName = name;
|
|
|
|
}
|
|
|
|
|
2014-07-04 18:42:25 +00:00
|
|
|
class MSBuiltin<string name> {
|
|
|
|
string MSBuiltinName = name;
|
|
|
|
}
|
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
|
|
|
|
//===--------------- Variable Argument Handling Intrinsics ----------------===//
|
2009-08-14 20:27:12 +00:00
|
|
|
//
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_vastart : Intrinsic<[], [llvm_ptr_ty], [], "llvm.va_start">;
|
|
|
|
def int_vacopy : Intrinsic<[], [llvm_ptr_ty, llvm_ptr_ty], [],
|
2006-03-03 02:33:15 +00:00
|
|
|
"llvm.va_copy">;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_vaend : Intrinsic<[], [llvm_ptr_ty], [], "llvm.va_end">;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
|
|
|
//===------------------- Garbage Collection Intrinsics --------------------===//
|
2009-08-14 20:27:12 +00:00
|
|
|
//
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_gcroot : Intrinsic<[],
|
2008-11-20 07:23:34 +00:00
|
|
|
[llvm_ptrptr_ty, llvm_ptr_ty]>;
|
|
|
|
def int_gcread : Intrinsic<[llvm_ptr_ty],
|
|
|
|
[llvm_ptr_ty, llvm_ptrptr_ty],
|
2006-04-10 22:02:59 +00:00
|
|
|
[IntrReadArgMem]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_gcwrite : Intrinsic<[],
|
2008-11-20 07:23:34 +00:00
|
|
|
[llvm_ptr_ty, llvm_ptr_ty, llvm_ptrptr_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<1>, NoCapture<2>]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
|
|
|
//===--------------------- Code Generator Intrinsics ----------------------===//
|
2009-08-14 20:27:12 +00:00
|
|
|
//
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_returnaddress : Intrinsic<[llvm_ptr_ty], [llvm_i32_ty], [IntrNoMem]>;
|
|
|
|
def int_frameaddress : Intrinsic<[llvm_ptr_ty], [llvm_i32_ty], [IntrNoMem]>;
|
2014-05-06 16:51:25 +00:00
|
|
|
def int_read_register : Intrinsic<[llvm_anyint_ty], [llvm_metadata_ty],
|
|
|
|
[IntrNoMem], "llvm.read_register">;
|
|
|
|
def int_write_register : Intrinsic<[], [llvm_metadata_ty, llvm_anyint_ty],
|
2014-05-20 17:40:03 +00:00
|
|
|
[], "llvm.write_register">;
|
2007-10-29 05:47:52 +00:00
|
|
|
|
2010-05-27 23:11:57 +00:00
|
|
|
// Note: we treat stacksave/stackrestore as writemem because we don't otherwise
|
|
|
|
// model their dependencies on allocas.
|
2007-10-29 05:47:52 +00:00
|
|
|
def int_stacksave : Intrinsic<[llvm_ptr_ty]>,
|
2007-01-17 23:33:20 +00:00
|
|
|
GCCBuiltin<"__builtin_stack_save">;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_stackrestore : Intrinsic<[], [llvm_ptr_ty]>,
|
2007-01-17 23:33:20 +00:00
|
|
|
GCCBuiltin<"__builtin_stack_restore">;
|
2008-11-06 02:29:10 +00:00
|
|
|
|
2010-08-05 23:36:21 +00:00
|
|
|
// IntrReadWriteArgMem is more pessimistic than strictly necessary for prefetch,
|
2007-10-08 21:15:07 +00:00
|
|
|
// however it does conveniently prevent the prefetch from being reordered
|
|
|
|
// with respect to nearby accesses to the same memory.
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_prefetch : Intrinsic<[],
|
2011-06-14 04:58:37 +00:00
|
|
|
[llvm_ptr_ty, llvm_i32_ty, llvm_i32_ty,
|
|
|
|
llvm_i32_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<0>]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_pcmarker : Intrinsic<[], [llvm_i32_ty]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2006-12-31 22:24:55 +00:00
|
|
|
def int_readcyclecounter : Intrinsic<[llvm_i64_ty]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2014-07-25 21:13:35 +00:00
|
|
|
// The assume intrinsic is marked as arbitrarily writing so that proper
|
|
|
|
// control dependencies will be maintained.
|
|
|
|
def int_assume : Intrinsic<[], [llvm_i1_ty], []>;
|
|
|
|
|
2008-11-18 11:01:33 +00:00
|
|
|
// Stack Protector Intrinsic - The stackprotector intrinsic writes the stack
|
|
|
|
// guard to the correct place on the stack frame.
|
2010-08-05 23:36:21 +00:00
|
|
|
def int_stackprotector : Intrinsic<[], [llvm_ptr_ty, llvm_ptrptr_ty], []>;
|
2013-08-12 18:35:32 +00:00
|
|
|
def int_stackprotectorcheck : Intrinsic<[], [llvm_ptrptr_ty],
|
|
|
|
[IntrReadWriteArgMem]>;
|
2008-11-06 02:29:10 +00:00
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
//===------------------- Standard C Library Intrinsics --------------------===//
|
|
|
|
//
|
|
|
|
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_memcpy : Intrinsic<[],
|
Reapply address space patch after fixing an issue in MemCopyOptimizer.
Added support for address spaces and added a isVolatile field to memcpy, memmove, and memset,
e.g., llvm.memcpy.i32(i8*, i8*, i32, i32) -> llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i32, i1)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100304 91177308-0d34-0410-b5e6-96231b3b80d8
2010-04-04 03:10:48 +00:00
|
|
|
[llvm_anyptr_ty, llvm_anyptr_ty, llvm_anyint_ty,
|
|
|
|
llvm_i32_ty, llvm_i1_ty],
|
2013-07-06 00:29:58 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<0>, NoCapture<1>,
|
|
|
|
ReadOnly<1>]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_memmove : Intrinsic<[],
|
Reapply address space patch after fixing an issue in MemCopyOptimizer.
Added support for address spaces and added a isVolatile field to memcpy, memmove, and memset,
e.g., llvm.memcpy.i32(i8*, i8*, i32, i32) -> llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i32, i1)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100304 91177308-0d34-0410-b5e6-96231b3b80d8
2010-04-04 03:10:48 +00:00
|
|
|
[llvm_anyptr_ty, llvm_anyptr_ty, llvm_anyint_ty,
|
|
|
|
llvm_i32_ty, llvm_i1_ty],
|
2013-07-06 00:29:58 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<0>, NoCapture<1>,
|
|
|
|
ReadOnly<1>]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_memset : Intrinsic<[],
|
Reapply address space patch after fixing an issue in MemCopyOptimizer.
Added support for address spaces and added a isVolatile field to memcpy, memmove, and memset,
e.g., llvm.memcpy.i32(i8*, i8*, i32, i32) -> llvm.memcpy.p0i8.p0i8.i32(i8*, i8*, i32, i32, i1)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100304 91177308-0d34-0410-b5e6-96231b3b80d8
2010-04-04 03:10:48 +00:00
|
|
|
[llvm_anyptr_ty, llvm_i8_ty, llvm_anyint_ty,
|
|
|
|
llvm_i32_ty, llvm_i1_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<0>]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2014-03-06 00:18:15 +00:00
|
|
|
let Properties = [IntrNoMem] in {
|
|
|
|
def int_fma : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>,
|
|
|
|
LLVMMatchType<0>]>;
|
|
|
|
def int_fmuladd : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>,
|
|
|
|
LLVMMatchType<0>]>;
|
|
|
|
|
|
|
|
// These functions do not read memory, but are sensitive to the
|
|
|
|
// rounding mode. LLVM purposely does not model changes to the FP
|
|
|
|
// environment so they can be treated as readnone.
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_sqrt : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_powi : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>, llvm_i32_ty]>;
|
|
|
|
def int_sin : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2009-08-14 20:27:12 +00:00
|
|
|
def int_cos : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_pow : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>]>;
|
|
|
|
def int_log : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_log10: Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_log2 : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_exp : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_exp2 : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2012-05-28 21:48:37 +00:00
|
|
|
def int_fabs : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
Add a llvm.copysign intrinsic
This adds a llvm.copysign intrinsic; We already have Libfunc recognition for
copysign (which is turned into the FCOPYSIGN SDAG node). In order to
autovectorize calls to copysign in the loop vectorizer, we need a corresponding
intrinsic as well.
In addition to the expected changes to the language reference, the loop
vectorizer, BasicTTI, and the SDAG builder (the intrinsic is transformed into
an FCOPYSIGN node, just like the function call), this also adds FCOPYSIGN to a
few lists in LegalizeVector{Ops,Types} so that vector copysigns can be
expanded.
In TargetLoweringBase::initActions, I've made the default action for FCOPYSIGN
be Expand for vector types. This seems correct for all in-tree targets, and I
think is the right thing to do because, previously, there was no way to generate
vector-values FCOPYSIGN nodes (and most targets don't specify an action for
vector-typed FCOPYSIGN).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@188728 91177308-0d34-0410-b5e6-96231b3b80d8
2013-08-19 23:35:46 +00:00
|
|
|
def int_copysign : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>]>;
|
2012-07-26 17:43:27 +00:00
|
|
|
def int_floor : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2012-11-15 06:51:10 +00:00
|
|
|
def int_ceil : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_trunc : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_rint : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_nearbyint : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2013-08-07 22:49:12 +00:00
|
|
|
def int_round : Intrinsic<[llvm_anyfloat_ty], [LLVMMatchType<0>]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// NOTE: these are internal interfaces.
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_setjmp : Intrinsic<[llvm_i32_ty], [llvm_ptr_ty]>;
|
2012-10-19 20:43:54 +00:00
|
|
|
def int_longjmp : Intrinsic<[], [llvm_ptr_ty, llvm_i32_ty], [IntrNoReturn]>;
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_sigsetjmp : Intrinsic<[llvm_i32_ty] , [llvm_ptr_ty, llvm_i32_ty]>;
|
2012-10-19 20:43:54 +00:00
|
|
|
def int_siglongjmp : Intrinsic<[], [llvm_ptr_ty, llvm_i32_ty], [IntrNoReturn]>;
|
2006-03-03 02:33:15 +00:00
|
|
|
|
2009-10-27 00:52:25 +00:00
|
|
|
// Internal interface for object size checking
|
2013-10-07 18:06:48 +00:00
|
|
|
def int_objectsize : Intrinsic<[llvm_anyint_ty], [llvm_anyptr_ty, llvm_i1_ty],
|
2011-02-18 16:11:40 +00:00
|
|
|
[IntrNoMem]>,
|
2009-10-27 00:52:25 +00:00
|
|
|
GCCBuiltin<"__builtin_object_size">;
|
|
|
|
|
2011-07-06 18:22:43 +00:00
|
|
|
//===------------------------- Expect Intrinsics --------------------------===//
|
|
|
|
//
|
|
|
|
def int_expect : Intrinsic<[llvm_anyint_ty], [LLVMMatchType<0>,
|
|
|
|
LLVMMatchType<0>], [IntrNoMem]>;
|
|
|
|
|
2006-03-03 02:33:15 +00:00
|
|
|
//===-------------------- Bit Manipulation Intrinsics ---------------------===//
|
|
|
|
//
|
|
|
|
|
|
|
|
// None of these intrinsics accesses memory at all.
|
2006-04-10 22:02:59 +00:00
|
|
|
let Properties = [IntrNoMem] in {
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_bswap: Intrinsic<[llvm_anyint_ty], [LLVMMatchType<0>]>;
|
|
|
|
def int_ctpop: Intrinsic<[llvm_anyint_ty], [LLVMMatchType<0>]>;
|
2011-12-12 04:26:04 +00:00
|
|
|
def int_ctlz : Intrinsic<[llvm_anyint_ty], [LLVMMatchType<0>, llvm_i1_ty]>;
|
|
|
|
def int_cttz : Intrinsic<[llvm_anyint_ty], [LLVMMatchType<0>, llvm_i1_ty]>;
|
2007-04-04 23:48:25 +00:00
|
|
|
}
|
2006-03-03 02:33:15 +00:00
|
|
|
|
|
|
|
//===------------------------ Debugger Intrinsics -------------------------===//
|
|
|
|
//
|
|
|
|
|
2009-03-04 21:53:29 +00:00
|
|
|
// None of these intrinsics accesses memory at all...but that doesn't mean the
|
|
|
|
// optimizers can change them aggressively. Special handling needed in a few
|
|
|
|
// places.
|
2009-03-04 21:24:04 +00:00
|
|
|
let Properties = [IntrNoMem] in {
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_dbg_declare : Intrinsic<[],
|
Move the complex address expression out of DIVariable and into an extra
argument of the llvm.dbg.declare/llvm.dbg.value intrinsics.
Previously, DIVariable was a variable-length field that has an optional
reference to a Metadata array consisting of a variable number of
complex address expressions. In the case of OpPiece expressions this is
wasting a lot of storage in IR, because when an aggregate type is, e.g.,
SROA'd into all of its n individual members, the IR will contain n copies
of the DIVariable, all alike, only differing in the complex address
reference at the end.
By making the complex address into an extra argument of the
dbg.value/dbg.declare intrinsics, all of the pieces can reference the
same variable and the complex address expressions can be uniqued across
the CU, too.
Down the road, this will allow us to move other flags, such as
"indirection" out of the DIVariable, too.
The new intrinsics look like this:
declare void @llvm.dbg.declare(metadata %storage, metadata %var, metadata %expr)
declare void @llvm.dbg.value(metadata %storage, i64 %offset, metadata %var, metadata %expr)
This patch adds a new LLVM-local tag to DIExpressions, so we can detect
and pretty-print DIExpression metadata nodes.
What this patch doesn't do:
This patch does not touch the "Indirect" field in DIVariable; but moving
that into the expression would be a natural next step.
http://reviews.llvm.org/D4919
rdar://problem/17994491
Thanks to dblaikie and dexonsmith for reviewing this patch!
Note: I accidentally committed a bogus older version of this patch previously.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218787 91177308-0d34-0410-b5e6-96231b3b80d8
2014-10-01 18:55:02 +00:00
|
|
|
[llvm_metadata_ty,
|
|
|
|
llvm_metadata_ty,
|
|
|
|
llvm_metadata_ty]>;
|
2012-07-19 00:01:00 +00:00
|
|
|
def int_dbg_value : Intrinsic<[],
|
2009-12-07 19:36:34 +00:00
|
|
|
[llvm_metadata_ty, llvm_i64_ty,
|
Move the complex address expression out of DIVariable and into an extra
argument of the llvm.dbg.declare/llvm.dbg.value intrinsics.
Previously, DIVariable was a variable-length field that has an optional
reference to a Metadata array consisting of a variable number of
complex address expressions. In the case of OpPiece expressions this is
wasting a lot of storage in IR, because when an aggregate type is, e.g.,
SROA'd into all of its n individual members, the IR will contain n copies
of the DIVariable, all alike, only differing in the complex address
reference at the end.
By making the complex address into an extra argument of the
dbg.value/dbg.declare intrinsics, all of the pieces can reference the
same variable and the complex address expressions can be uniqued across
the CU, too.
Down the road, this will allow us to move other flags, such as
"indirection" out of the DIVariable, too.
The new intrinsics look like this:
declare void @llvm.dbg.declare(metadata %storage, metadata %var, metadata %expr)
declare void @llvm.dbg.value(metadata %storage, i64 %offset, metadata %var, metadata %expr)
This patch adds a new LLVM-local tag to DIExpressions, so we can detect
and pretty-print DIExpression metadata nodes.
What this patch doesn't do:
This patch does not touch the "Indirect" field in DIVariable; but moving
that into the expression would be a natural next step.
http://reviews.llvm.org/D4919
rdar://problem/17994491
Thanks to dblaikie and dexonsmith for reviewing this patch!
Note: I accidentally committed a bogus older version of this patch previously.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218787 91177308-0d34-0410-b5e6-96231b3b80d8
2014-10-01 18:55:02 +00:00
|
|
|
llvm_metadata_ty,
|
2009-12-07 19:36:34 +00:00
|
|
|
llvm_metadata_ty]>;
|
2009-03-04 21:24:04 +00:00
|
|
|
}
|
2006-03-13 22:38:32 +00:00
|
|
|
|
2007-02-06 18:02:54 +00:00
|
|
|
//===------------------ Exception Handling Intrinsics----------------------===//
|
|
|
|
//
|
2009-10-14 16:11:37 +00:00
|
|
|
|
2011-09-09 07:50:37 +00:00
|
|
|
// The result of eh.typeid.for depends on the enclosing function, but inside a
|
|
|
|
// given function it is 'const' and may be CSE'd etc.
|
|
|
|
def int_eh_typeid_for : Intrinsic<[llvm_i32_ty], [llvm_ptr_ty], [IntrNoMem]>;
|
2007-02-06 18:02:54 +00:00
|
|
|
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_eh_return_i32 : Intrinsic<[], [llvm_i32_ty, llvm_ptr_ty]>;
|
|
|
|
def int_eh_return_i64 : Intrinsic<[], [llvm_i64_ty, llvm_ptr_ty]>;
|
2007-07-14 14:06:15 +00:00
|
|
|
|
2013-06-14 16:15:29 +00:00
|
|
|
// __builtin_unwind_init is an undocumented GCC intrinsic that causes all
|
|
|
|
// callee-saved registers to be saved and restored (regardless of whether they
|
|
|
|
// are used) in the calling function. It is used by libgcc_eh.
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_eh_unwind_init: Intrinsic<[]>,
|
2007-07-14 14:06:15 +00:00
|
|
|
GCCBuiltin<"__builtin_unwind_init">;
|
|
|
|
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_eh_dwarf_cfa : Intrinsic<[llvm_ptr_ty], [llvm_i32_ty]>;
|
2007-07-14 14:06:15 +00:00
|
|
|
|
2009-05-12 23:59:14 +00:00
|
|
|
let Properties = [IntrNoMem] in {
|
2011-09-28 03:36:43 +00:00
|
|
|
def int_eh_sjlj_lsda : Intrinsic<[llvm_ptr_ty]>;
|
|
|
|
def int_eh_sjlj_callsite : Intrinsic<[], [llvm_i32_ty]>;
|
2009-08-12 23:03:43 +00:00
|
|
|
}
|
2011-10-10 17:08:47 +00:00
|
|
|
def int_eh_sjlj_functioncontext : Intrinsic<[], [llvm_ptr_ty]>;
|
|
|
|
def int_eh_sjlj_setjmp : Intrinsic<[llvm_i32_ty], [llvm_ptr_ty]>;
|
2012-10-19 20:43:54 +00:00
|
|
|
def int_eh_sjlj_longjmp : Intrinsic<[], [llvm_ptr_ty], [IntrNoReturn]>;
|
2009-05-12 23:59:14 +00:00
|
|
|
|
2007-06-15 20:50:54 +00:00
|
|
|
//===---------------- Generic Variable Attribute Intrinsics----------------===//
|
|
|
|
//
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_var_annotation : Intrinsic<[],
|
2008-11-13 09:08:33 +00:00
|
|
|
[llvm_ptr_ty, llvm_ptr_ty,
|
2009-08-14 20:27:12 +00:00
|
|
|
llvm_ptr_ty, llvm_i32_ty],
|
2008-11-20 07:23:34 +00:00
|
|
|
[], "llvm.var.annotation">;
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_ptr_annotation : Intrinsic<[LLVMAnyPointerType<llvm_anyint_ty>],
|
|
|
|
[LLVMMatchType<0>, llvm_ptr_ty, llvm_ptr_ty,
|
2009-08-14 20:27:12 +00:00
|
|
|
llvm_i32_ty],
|
2008-11-13 09:08:33 +00:00
|
|
|
[], "llvm.ptr.annotation">;
|
|
|
|
def int_annotation : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[LLVMMatchType<0>, llvm_ptr_ty,
|
|
|
|
llvm_ptr_ty, llvm_i32_ty],
|
|
|
|
[], "llvm.annotation">;
|
2007-06-15 20:50:54 +00:00
|
|
|
|
2007-07-27 12:58:54 +00:00
|
|
|
//===------------------------ Trampoline Intrinsics -----------------------===//
|
|
|
|
//
|
2011-09-06 13:37:06 +00:00
|
|
|
def int_init_trampoline : Intrinsic<[],
|
2008-11-13 09:08:33 +00:00
|
|
|
[llvm_ptr_ty, llvm_ptr_ty, llvm_ptr_ty],
|
2011-09-06 13:37:06 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<0>]>,
|
|
|
|
GCCBuiltin<"__builtin_init_trampoline">;
|
|
|
|
|
|
|
|
def int_adjust_trampoline : Intrinsic<[llvm_ptr_ty], [llvm_ptr_ty],
|
|
|
|
[IntrReadArgMem]>,
|
|
|
|
GCCBuiltin<"__builtin_adjust_trampoline">;
|
2007-07-27 12:58:54 +00:00
|
|
|
|
2008-11-21 00:05:31 +00:00
|
|
|
//===------------------------ Overflow Intrinsics -------------------------===//
|
|
|
|
//
|
|
|
|
|
|
|
|
// Expose the carry flag from add operations on two integrals.
|
|
|
|
def int_sadd_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-11-21 00:05:31 +00:00
|
|
|
def int_uadd_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-11-21 00:05:31 +00:00
|
|
|
|
2008-12-09 22:08:41 +00:00
|
|
|
def int_ssub_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-12-09 22:08:41 +00:00
|
|
|
def int_usub_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-12-09 22:08:41 +00:00
|
|
|
|
|
|
|
def int_smul_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-12-09 22:08:41 +00:00
|
|
|
def int_umul_with_overflow : Intrinsic<[llvm_anyint_ty, llvm_i1_ty],
|
2009-11-29 02:44:33 +00:00
|
|
|
[LLVMMatchType<0>, LLVMMatchType<0>],
|
|
|
|
[IntrNoMem]>;
|
2008-12-09 22:08:41 +00:00
|
|
|
|
2009-10-13 07:03:23 +00:00
|
|
|
//===------------------------- Memory Use Markers -------------------------===//
|
|
|
|
//
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_lifetime_start : Intrinsic<[],
|
2009-10-13 07:03:23 +00:00
|
|
|
[llvm_i64_ty, llvm_ptr_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<1>]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_lifetime_end : Intrinsic<[],
|
2009-10-13 07:03:23 +00:00
|
|
|
[llvm_i64_ty, llvm_ptr_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<1>]>;
|
2009-10-13 07:03:23 +00:00
|
|
|
def int_invariant_start : Intrinsic<[llvm_descriptor_ty],
|
|
|
|
[llvm_i64_ty, llvm_ptr_ty],
|
2010-11-30 04:13:41 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<1>]>;
|
2010-03-23 23:46:07 +00:00
|
|
|
def int_invariant_end : Intrinsic<[],
|
2009-10-13 07:03:23 +00:00
|
|
|
[llvm_descriptor_ty, llvm_i64_ty,
|
|
|
|
llvm_ptr_ty],
|
2010-08-05 23:36:21 +00:00
|
|
|
[IntrReadWriteArgMem, NoCapture<2>]>;
|
2009-10-13 07:03:23 +00:00
|
|
|
|
2013-10-31 17:18:14 +00:00
|
|
|
//===------------------------ Stackmap Intrinsics -------------------------===//
|
|
|
|
//
|
|
|
|
def int_experimental_stackmap : Intrinsic<[],
|
2014-02-20 23:57:31 +00:00
|
|
|
[llvm_i64_ty, llvm_i32_ty, llvm_vararg_ty],
|
|
|
|
[Throws]>;
|
2013-10-31 17:18:14 +00:00
|
|
|
def int_experimental_patchpoint_void : Intrinsic<[],
|
2013-12-13 18:37:10 +00:00
|
|
|
[llvm_i64_ty, llvm_i32_ty,
|
2013-10-31 17:18:14 +00:00
|
|
|
llvm_ptr_ty, llvm_i32_ty,
|
2014-10-17 17:39:00 +00:00
|
|
|
llvm_vararg_ty],
|
|
|
|
[Throws]>;
|
2013-10-31 17:18:14 +00:00
|
|
|
def int_experimental_patchpoint_i64 : Intrinsic<[llvm_i64_ty],
|
2013-12-13 18:37:10 +00:00
|
|
|
[llvm_i64_ty, llvm_i32_ty,
|
2013-10-31 17:18:14 +00:00
|
|
|
llvm_ptr_ty, llvm_i32_ty,
|
2014-10-17 17:39:00 +00:00
|
|
|
llvm_vararg_ty],
|
|
|
|
[Throws]>;
|
2013-10-31 17:18:14 +00:00
|
|
|
|
2007-11-15 23:25:33 +00:00
|
|
|
//===-------------------------- Other Intrinsics --------------------------===//
|
|
|
|
//
|
|
|
|
def int_flt_rounds : Intrinsic<[llvm_i32_ty]>,
|
|
|
|
GCCBuiltin<"__builtin_flt_rounds">;
|
2012-05-27 23:20:41 +00:00
|
|
|
def int_trap : Intrinsic<[], [], [IntrNoReturn]>,
|
2008-01-15 07:02:33 +00:00
|
|
|
GCCBuiltin<"__builtin_trap">;
|
2012-10-19 23:00:20 +00:00
|
|
|
def int_debugtrap : Intrinsic<[]>,
|
2012-05-14 18:58:10 +00:00
|
|
|
GCCBuiltin<"__builtin_debugtrap">;
|
2007-11-15 23:25:33 +00:00
|
|
|
|
2012-06-28 22:30:12 +00:00
|
|
|
// NOP: calls/invokes to this intrinsic are removed by codegen
|
|
|
|
def int_donothing : Intrinsic<[], [], [IntrNoMem]>;
|
|
|
|
|
2010-03-14 18:41:50 +00:00
|
|
|
// Intrisics to support half precision floating point format
|
2010-03-14 18:42:08 +00:00
|
|
|
let Properties = [IntrNoMem] in {
|
2014-07-17 10:51:23 +00:00
|
|
|
def int_convert_to_fp16 : Intrinsic<[llvm_i16_ty], [llvm_anyfloat_ty]>;
|
|
|
|
def int_convert_from_fp16 : Intrinsic<[llvm_anyfloat_ty], [llvm_i16_ty]>;
|
2010-03-14 18:42:08 +00:00
|
|
|
}
|
2010-03-14 18:41:50 +00:00
|
|
|
|
2008-11-10 20:54:11 +00:00
|
|
|
// These convert intrinsics are to support various conversions between
|
|
|
|
// various types with rounding and saturation. NOTE: avoid using these
|
|
|
|
// intrinsics as they might be removed sometime in the future and
|
|
|
|
// most targets don't support them.
|
2008-11-13 09:08:33 +00:00
|
|
|
def int_convertff : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[llvm_anyfloat_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertfsi : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertfui : Intrinsic<[llvm_anyfloat_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertsif : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyfloat_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertuif : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyfloat_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertss : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertsu : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertus : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
|
|
|
def int_convertuu : Intrinsic<[llvm_anyint_ty],
|
|
|
|
[llvm_anyint_ty, llvm_i32_ty, llvm_i32_ty]>;
|
2008-11-10 20:54:11 +00:00
|
|
|
|
2014-03-26 12:52:28 +00:00
|
|
|
// Clear cache intrinsic, default to ignore (ie. emit nothing)
|
|
|
|
// maps to void __clear_cache() on supporting platforms
|
|
|
|
def int_clear_cache : Intrinsic<[], [llvm_ptr_ty, llvm_ptr_ty],
|
|
|
|
[], "llvm.clear_cache">;
|
|
|
|
|
2006-03-13 22:38:32 +00:00
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Target-specific intrinsics
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2013-01-02 11:36:10 +00:00
|
|
|
include "llvm/IR/IntrinsicsPowerPC.td"
|
|
|
|
include "llvm/IR/IntrinsicsX86.td"
|
|
|
|
include "llvm/IR/IntrinsicsARM.td"
|
2014-05-24 12:50:23 +00:00
|
|
|
include "llvm/IR/IntrinsicsAArch64.td"
|
2013-01-02 11:36:10 +00:00
|
|
|
include "llvm/IR/IntrinsicsXCore.td"
|
|
|
|
include "llvm/IR/IntrinsicsHexagon.td"
|
|
|
|
include "llvm/IR/IntrinsicsNVVM.td"
|
|
|
|
include "llvm/IR/IntrinsicsMips.td"
|
|
|
|
include "llvm/IR/IntrinsicsR600.td"
|