2003-05-08 03:33:54 +00:00
|
|
|
//===-- llvm/Instrinsics.h - LLVM Intrinsic Function Handling ---*- C++ -*-===//
|
2003-10-20 20:19:47 +00:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file was developed by the LLVM research group and is distributed under
|
|
|
|
// the University of Illinois Open Source License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2003-05-08 03:33:54 +00:00
|
|
|
//
|
|
|
|
// This file defines a set of enums which allow processing of intrinsic
|
|
|
|
// functions. Values of these enum types are returned by
|
|
|
|
// Function::getIntrinsicID.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#ifndef LLVM_INTRINSICS_H
|
|
|
|
#define LLVM_INTRINSICS_H
|
|
|
|
|
2003-11-11 22:41:34 +00:00
|
|
|
namespace llvm {
|
|
|
|
|
|
|
|
/// Intrinsic Namespace - This namespace contains an enum with a value for
|
2003-06-03 15:30:13 +00:00
|
|
|
/// every intrinsic/builtin function known by LLVM. These enum values are
|
|
|
|
/// returned by Function::getIntrinsicID().
|
|
|
|
///
|
2003-11-11 22:41:34 +00:00
|
|
|
namespace Intrinsic {
|
2003-05-08 03:33:54 +00:00
|
|
|
enum ID {
|
|
|
|
not_intrinsic = 0, // Must be zero
|
2003-05-17 22:26:33 +00:00
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// Varargs handling intrinsics.
|
2004-03-13 00:24:00 +00:00
|
|
|
vastart, // Used to implement the va_start macro in C
|
|
|
|
vaend, // Used to implement the va_end macro in C
|
|
|
|
vacopy, // Used to implement the va_copy macro in C
|
2003-05-17 22:26:33 +00:00
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// Code generator intrinsics.
|
2004-02-14 02:47:17 +00:00
|
|
|
returnaddress, // Yields the return address of a dynamic call frame
|
|
|
|
frameaddress, // Yields the frame address of a dynamic call frame
|
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// setjmp/longjmp intrinsics.
|
2003-07-28 21:18:21 +00:00
|
|
|
setjmp, // Used to represent a setjmp call in C
|
|
|
|
longjmp, // Used to represent a longjmp call in C
|
2003-08-18 15:41:24 +00:00
|
|
|
sigsetjmp, // Used to represent a sigsetjmp call in C
|
|
|
|
siglongjmp, // Used to represent a siglongjmp call in C
|
2003-07-28 21:18:21 +00:00
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// Garbage Collection intrinsics.
|
|
|
|
gcroot, // Defines a new GC root on the stack
|
|
|
|
gcread, // Defines a read of a heap object (for read barriers)
|
|
|
|
gcwrite, // Defines a write to a heap object (for write barriers)
|
|
|
|
|
|
|
|
// Debugging intrinsics.
|
2004-01-05 05:35:34 +00:00
|
|
|
dbg_stoppoint, // Represents source lines and breakpointable places
|
|
|
|
dbg_region_start, // Start of a region
|
|
|
|
dbg_region_end, // End of a region
|
|
|
|
dbg_func_start, // Start of a function
|
2004-01-06 05:32:17 +00:00
|
|
|
dbg_declare, // Declare a local object
|
2004-01-05 05:35:34 +00:00
|
|
|
|
2004-02-12 17:57:11 +00:00
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// Standard libc functions.
|
|
|
|
memcpy, // Copy non-overlapping memory blocks
|
|
|
|
memmove, // Copy potentially overlapping memory blocks
|
|
|
|
memset, // Fill memory with a byte value
|
|
|
|
|
2004-06-11 02:29:43 +00:00
|
|
|
// libm related functions.
|
2004-06-15 21:52:58 +00:00
|
|
|
isunordered, // Return true if either argument is a NaN
|
2004-02-12 17:57:11 +00:00
|
|
|
|
2004-05-23 21:16:33 +00:00
|
|
|
// Input/Output intrinsics.
|
2004-04-08 20:26:21 +00:00
|
|
|
readport,
|
|
|
|
writeport,
|
2004-04-14 02:22:54 +00:00
|
|
|
readio,
|
|
|
|
writeio,
|
2004-04-08 20:26:21 +00:00
|
|
|
|
2003-07-28 21:18:21 +00:00
|
|
|
//===------------------------------------------------------------------===//
|
|
|
|
// This section defines intrinsic functions used to represent Alpha
|
2004-05-23 21:16:33 +00:00
|
|
|
// instructions.
|
2003-07-28 21:18:21 +00:00
|
|
|
//
|
|
|
|
alpha_ctlz, // CTLZ (count leading zero): counts the number of leading
|
|
|
|
// zeros in the given ulong value
|
2003-08-06 20:08:25 +00:00
|
|
|
|
2003-07-28 21:18:21 +00:00
|
|
|
alpha_cttz, // CTTZ (count trailing zero): counts the number of trailing
|
|
|
|
// zeros in the given ulong value
|
2003-08-06 20:08:25 +00:00
|
|
|
|
2003-07-28 21:18:21 +00:00
|
|
|
alpha_ctpop, // CTPOP (count population): counts the number of ones in
|
|
|
|
// the given ulong value
|
2003-08-06 20:08:25 +00:00
|
|
|
|
2003-07-28 21:18:21 +00:00
|
|
|
alpha_umulh, // UMULH (unsigned multiply quadword high): Takes two 64-bit
|
|
|
|
// (ulong) values, and returns the upper 64 bits of their
|
|
|
|
// 128 bit product as a ulong
|
2003-08-06 20:08:25 +00:00
|
|
|
|
|
|
|
alpha_vecop, // A generic vector operation. This function is used to
|
|
|
|
// represent various Alpha vector/multimedia instructions.
|
|
|
|
// It takes 4 parameters:
|
|
|
|
// - the first two are 2 ulong vectors
|
|
|
|
// - the third (uint) is the size (in bytes) of each
|
|
|
|
// vector element. Thus a value of 1 means that the two
|
|
|
|
// input vectors consist of 8 bytes
|
|
|
|
// - the fourth (uint) is the operation to be performed on
|
|
|
|
// the vectors. Its possible values are defined in the
|
|
|
|
// enumeration AlphaVecOps.
|
|
|
|
|
|
|
|
alpha_pup, // A pack/unpack operation. This function is used to
|
|
|
|
// represent Alpha pack/unpack operations.
|
|
|
|
// It takes 3 parameters:
|
|
|
|
// - the first is an ulong to pack/unpack
|
|
|
|
// - the second (uint) is the size of each component
|
|
|
|
// Valid values are 2 (word) or 4 (longword)
|
|
|
|
// - the third (uint) is the operation to be performed.
|
|
|
|
// Possible values defined in the enumeration
|
|
|
|
// AlphaPupOps
|
|
|
|
|
|
|
|
alpha_bytezap, // This intrinsic function takes two parameters: a ulong
|
|
|
|
// (64-bit) value and a ubyte value, and returns a ulong.
|
|
|
|
// Each bit in the ubyte corresponds to a byte in the
|
|
|
|
// ulong. If the bit is 0, the byte in the output equals
|
|
|
|
// the corresponding byte in the input, else the byte in
|
|
|
|
// the output is zero.
|
|
|
|
|
|
|
|
alpha_bytemanip,// This intrinsic function represents all Alpha byte
|
|
|
|
// manipulation instructions. It takes 3 parameters:
|
|
|
|
// - The first two are ulong inputs to operate on
|
|
|
|
// - The third (uint) is the operation to perform.
|
|
|
|
// Possible values defined in the enumeration
|
|
|
|
// AlphaByteManipOps
|
|
|
|
|
|
|
|
alpha_dfpbop, // This intrinsic function represents Alpha instructions
|
|
|
|
// that operate on two doubles and return a double. The
|
|
|
|
// first two parameters are the two double values to
|
|
|
|
// operate on, and the third is a uint that specifies the
|
|
|
|
// operation to perform. Its possible values are defined in
|
|
|
|
// the enumeration AlphaFloatingBinaryOps
|
|
|
|
|
|
|
|
alpha_dfpuop, // This intrinsic function represents operation on a single
|
|
|
|
// double precision floating point value. The first
|
|
|
|
// paramters is the value and the second is the operation.
|
|
|
|
// The possible values for the operations are defined in the
|
|
|
|
// enumeration AlphaFloatingUnaryOps
|
|
|
|
|
|
|
|
alpha_unordered,// This intrinsic function tests if two double precision
|
|
|
|
// floating point values are unordered. It has two
|
|
|
|
// parameters: the two values to be tested. It return a
|
|
|
|
// boolean true if the two are unordered, else false.
|
|
|
|
|
|
|
|
alpha_uqtodfp, // A generic function that converts a ulong to a double.
|
|
|
|
// How the conversion is performed is specified by the
|
|
|
|
// second parameter, the possible values for which are
|
|
|
|
// defined in the AlphaUqToDfpOps enumeration
|
|
|
|
|
|
|
|
alpha_uqtosfp, // A generic function that converts a ulong to a float.
|
|
|
|
// How the conversion is performed is specified by the
|
|
|
|
// second parameter, the possible values for which are
|
|
|
|
// defined in the AlphaUqToSfpOps enumeration
|
|
|
|
|
|
|
|
alpha_dfptosq, // A generic function that converts double to a long.
|
|
|
|
// How the conversion is performed is specified by the
|
|
|
|
// second parameter, the possible values for which are
|
|
|
|
// defined in the AlphaDfpToSqOps enumeration
|
|
|
|
|
|
|
|
alpha_sfptosq, // A generic function that converts a float to a long.
|
|
|
|
// How the conversion is performed is specified by the
|
|
|
|
// second parameter, the possible values for which are
|
|
|
|
// defined in the AlphaSfpToSq enumeration
|
2003-05-08 03:33:54 +00:00
|
|
|
};
|
2003-11-11 22:41:34 +00:00
|
|
|
|
|
|
|
} // End Intrinsic namespace
|
|
|
|
|
|
|
|
} // End llvm namespace
|
2003-05-08 03:33:54 +00:00
|
|
|
|
|
|
|
#endif
|