//===-- AMDGPUInstrInfo.h - AMDGPU Instruction Information ------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // /// \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 "Utils/AMDGPUBaseInfo.h" namespace llvm { class GCNSubtarget; class MachineMemOperand; class MachineInstr; class AMDGPUInstrInfo { … }; namespace AMDGPU { /// Return the intrinsic ID for opcodes with the G_AMDGPU_INTRIN_ prefix. /// /// These opcodes have an Intrinsic::ID operand similar to a GIntrinsic. But /// they are not actual instances of GIntrinsics, so we cannot use /// GIntrinsic::getIntrinsicID() on them. Intrinsic::ID getIntrinsicID(const MachineInstr &I); struct RsrcIntrinsic { … }; const RsrcIntrinsic *lookupRsrcIntrinsic(unsigned Intr); struct D16ImageDimIntrinsic { … }; const D16ImageDimIntrinsic *lookupD16ImageDimIntrinsic(unsigned Intr); struct ImageDimIntrinsicInfo { … }; const ImageDimIntrinsicInfo *getImageDimIntrinsicInfo(unsigned Intr); const ImageDimIntrinsicInfo * getImageDimIntrinsicByBaseOpcode(unsigned BaseOpcode, unsigned Dim); } // end AMDGPU namespace } // End llvm namespace #endif