1//===- AMDILIntrinsicInfo.h - AMDGPU Intrinsic Information ------*- C++ -*-===// 2// 3// The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//==-----------------------------------------------------------------------===// 9// 10/// \file 11/// \brief Interface for the AMDGPU Implementation of the Intrinsic Info class. 12// 13//===-----------------------------------------------------------------------===// 14#ifndef AMDIL_INTRINSICS_H 15#define AMDIL_INTRINSICS_H 16 17#include "llvm/IR/Intrinsics.h" 18#include "llvm/Target/TargetIntrinsicInfo.h" 19 20namespace llvm { 21class TargetMachine; 22 23namespace AMDGPUIntrinsic { 24enum ID { 25 last_non_AMDGPU_intrinsic = Intrinsic::num_intrinsics - 1, 26#define GET_INTRINSIC_ENUM_VALUES 27#include "AMDGPUGenIntrinsics.inc" 28#undef GET_INTRINSIC_ENUM_VALUES 29 , num_AMDGPU_intrinsics 30}; 31 32} // end namespace AMDGPUIntrinsic 33 34class AMDGPUIntrinsicInfo : public TargetIntrinsicInfo { 35public: 36 AMDGPUIntrinsicInfo(TargetMachine *tm); 37 std::string getName(unsigned int IntrId, Type **Tys = 0, 38 unsigned int numTys = 0) const; 39 unsigned int lookupName(const char *Name, unsigned int Len) const; 40 bool isOverloaded(unsigned int IID) const; 41 Function *getDeclaration(Module *M, unsigned int ID, 42 Type **Tys = 0, 43 unsigned int numTys = 0) const; 44}; 45 46} // end namespace llvm 47 48#endif // AMDIL_INTRINSICS_H 49 50