1
0
mirror of https://github.com/c64scene-ar/llvm-6502.git synced 2025-01-02 07:32:52 +00:00
llvm-6502/include/llvm/Target/TargetIntrinsicInfo.h
Mon P Wang 0d52ff1f7b Added support to have TableGen provide information if an intrinsic (core
or target) can be overloaded or not.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65404 91177308-0d34-0410-b5e6-96231b3b80d8
2009-02-24 23:17:49 +00:00

62 lines
1.9 KiB
C++

//===-- llvm/Target/TargetIntrinsicInfo.h - Instruction Info ----*- C++ -*-===//
//
// The LLVM Compiler Infrastructure
//
// This file is distributed under the University of Illinois Open Source
// License. See LICENSE.TXT for details.
//
//===----------------------------------------------------------------------===//
//
// This file describes the target intrinsic instructions to the code generator.
//
//===----------------------------------------------------------------------===//
#ifndef LLVM_TARGET_TARGETINTRINSICINFO_H
#define LLVM_TARGET_TARGETINTRINSICINFO_H
namespace llvm {
class Function;
class Module;
class Type;
//---------------------------------------------------------------------------
///
/// TargetIntrinsicInfo - Interface to description of machine instruction set
///
class TargetIntrinsicInfo {
const char **Intrinsics; // Raw array to allow static init'n
unsigned NumIntrinsics; // Number of entries in the desc array
TargetIntrinsicInfo(const TargetIntrinsicInfo &); // DO NOT IMPLEMENT
void operator=(const TargetIntrinsicInfo &); // DO NOT IMPLEMENT
public:
TargetIntrinsicInfo(const char **desc, unsigned num);
virtual ~TargetIntrinsicInfo();
unsigned getNumIntrinsics() const { return NumIntrinsics; }
virtual Function *getDeclaration(Module *M, const char *BuiltinName) const {
return 0;
}
// Returns the Function declaration for intrinsic BuiltinName. If the
// intrinsic can be overloaded, uses Tys to return the correct function.
virtual Function *getDeclaration(Module *M, const char *BuiltinName,
const Type **Tys, unsigned numTys) const {
return 0;
}
// Returns true if the Builtin can be overloaded.
virtual bool isOverloaded(Module *M, const char *BuiltinName) const {
return false;
}
virtual unsigned getIntrinsicID(Function *F) const { return 0; }
};
} // End llvm namespace
#endif