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