1*9880d681SAndroid Build Coastguard Worker //===-- AMDGPUInstrInfo.h - AMDGPU Instruction 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 Contains the definition of a TargetInstrInfo class that is common 12*9880d681SAndroid Build Coastguard Worker /// to all AMD GPUs. 13*9880d681SAndroid Build Coastguard Worker // 14*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_AMDGPU_AMDGPUINSTRINFO_H 17*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_AMDGPU_AMDGPUINSTRINFO_H 18*9880d681SAndroid Build Coastguard Worker 19*9880d681SAndroid Build Coastguard Worker #include "llvm/Target/TargetInstrInfo.h" 20*9880d681SAndroid Build Coastguard Worker 21*9880d681SAndroid Build Coastguard Worker #define GET_INSTRINFO_HEADER 22*9880d681SAndroid Build Coastguard Worker #define GET_INSTRINFO_ENUM 23*9880d681SAndroid Build Coastguard Worker #define GET_INSTRINFO_OPERAND_ENUM 24*9880d681SAndroid Build Coastguard Worker #include "AMDGPUGenInstrInfo.inc" 25*9880d681SAndroid Build Coastguard Worker 26*9880d681SAndroid Build Coastguard Worker #define OPCODE_IS_ZERO_INT AMDGPU::PRED_SETE_INT 27*9880d681SAndroid Build Coastguard Worker #define OPCODE_IS_NOT_ZERO_INT AMDGPU::PRED_SETNE_INT 28*9880d681SAndroid Build Coastguard Worker #define OPCODE_IS_ZERO AMDGPU::PRED_SETE 29*9880d681SAndroid Build Coastguard Worker #define OPCODE_IS_NOT_ZERO AMDGPU::PRED_SETNE 30*9880d681SAndroid Build Coastguard Worker 31*9880d681SAndroid Build Coastguard Worker namespace llvm { 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker class AMDGPUSubtarget; 34*9880d681SAndroid Build Coastguard Worker class MachineFunction; 35*9880d681SAndroid Build Coastguard Worker class MachineInstr; 36*9880d681SAndroid Build Coastguard Worker class MachineInstrBuilder; 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker class AMDGPUInstrInfo : public AMDGPUGenInstrInfo { 39*9880d681SAndroid Build Coastguard Worker private: 40*9880d681SAndroid Build Coastguard Worker const AMDGPUSubtarget &ST; 41*9880d681SAndroid Build Coastguard Worker 42*9880d681SAndroid Build Coastguard Worker virtual void anchor(); 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker public: 45*9880d681SAndroid Build Coastguard Worker explicit AMDGPUInstrInfo(const AMDGPUSubtarget &st); 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Worker bool enableClusterLoads() const override; 48*9880d681SAndroid Build Coastguard Worker 49*9880d681SAndroid Build Coastguard Worker bool shouldScheduleLoadsNear(SDNode *Load1, SDNode *Load2, 50*9880d681SAndroid Build Coastguard Worker int64_t Offset1, int64_t Offset2, 51*9880d681SAndroid Build Coastguard Worker unsigned NumLoads) const override; 52*9880d681SAndroid Build Coastguard Worker 53*9880d681SAndroid Build Coastguard Worker /// \brief Return a target-specific opcode if Opcode is a pseudo instruction. 54*9880d681SAndroid Build Coastguard Worker /// Return -1 if the target-specific opcode for the pseudo instruction does 55*9880d681SAndroid Build Coastguard Worker /// not exist. If Opcode is not a pseudo instruction, this is identity. 56*9880d681SAndroid Build Coastguard Worker int pseudoToMCOpcode(int Opcode) const; 57*9880d681SAndroid Build Coastguard Worker 58*9880d681SAndroid Build Coastguard Worker /// \brief Given a MIMG \p Opcode that writes all 4 channels, return the 59*9880d681SAndroid Build Coastguard Worker /// equivalent opcode that writes \p Channels Channels. 60*9880d681SAndroid Build Coastguard Worker int getMaskedMIMGOp(uint16_t Opcode, unsigned Channels) const; 61*9880d681SAndroid Build Coastguard Worker }; 62*9880d681SAndroid Build Coastguard Worker 63*9880d681SAndroid Build Coastguard Worker namespace AMDGPU { 64*9880d681SAndroid Build Coastguard Worker LLVM_READONLY 65*9880d681SAndroid Build Coastguard Worker int16_t getNamedOperandIdx(uint16_t Opcode, uint16_t NamedIndex); 66*9880d681SAndroid Build Coastguard Worker } // End namespace AMDGPU 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker } // End llvm namespace 69*9880d681SAndroid Build Coastguard Worker 70*9880d681SAndroid Build Coastguard Worker #define AMDGPU_FLAG_REGISTER_LOAD (UINT64_C(1) << 63) 71*9880d681SAndroid Build Coastguard Worker #define AMDGPU_FLAG_REGISTER_STORE (UINT64_C(1) << 62) 72*9880d681SAndroid Build Coastguard Worker 73*9880d681SAndroid Build Coastguard Worker #endif 74