//===-- AMDGPUInstrInfo.h - AMDGPU Instruction Information ------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // /// \file /// Contains the definition of a TargetInstrInfo class that is common /// to all AMD GPUs. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_AMDGPU_AMDGPUINSTRINFO_H #define LLVM_LIB_TARGET_AMDGPU_AMDGPUINSTRINFO_H #include "AMDGPU.h" #include "Utils/AMDGPUBaseInfo.h" #include "llvm/CodeGen/TargetInstrInfo.h" namespace llvm { class GCNSubtarget; class MachineFunction; class MachineInstr; class MachineInstrBuilder; class AMDGPUInstrInfo { public: explicit AMDGPUInstrInfo(const GCNSubtarget &st); static bool isUniformMMO(const MachineMemOperand *MMO); }; namespace AMDGPU { struct RsrcIntrinsic { unsigned Intr; uint8_t RsrcArg; bool IsImage; }; const RsrcIntrinsic *lookupRsrcIntrinsic(unsigned Intr); struct D16ImageDimIntrinsic { unsigned Intr; unsigned D16HelperIntr; }; const D16ImageDimIntrinsic *lookupD16ImageDimIntrinsic(unsigned Intr); struct ImageDimIntrinsicInfo { unsigned Intr; unsigned BaseOpcode; MIMGDim Dim; }; const ImageDimIntrinsicInfo *getImageDimIntrinsicInfo(unsigned Intr); } // end AMDGPU namespace } // End llvm namespace #endif