1//===- AMDGPUIntrinsicInfo.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 LLVM_LIB_TARGET_R600_AMDGPUINTRINSICINFO_H 15#define LLVM_LIB_TARGET_R600_AMDGPUINTRINSICINFO_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(); 37 std::string getName(unsigned IntrId, Type **Tys = nullptr, 38 unsigned numTys = 0) const override; 39 unsigned lookupName(const char *Name, unsigned Len) const override; 40 bool isOverloaded(unsigned IID) const override; 41 Function *getDeclaration(Module *M, unsigned ID, 42 Type **Tys = nullptr, 43 unsigned numTys = 0) const override; 44}; 45 46} // end namespace llvm 47 48#endif 49