//===-- GCNHazardRecognizers.h - GCN Hazard Recognizers ---------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file defines hazard recognizers for scheduling on GCN processors. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_AMDGPUHAZARDRECOGNIZERS_H #define LLVM_LIB_TARGET_AMDGPUHAZARDRECOGNIZERS_H #include "llvm/ADT/STLExtras.h" #include "llvm/CodeGen/ScheduleHazardRecognizer.h" #include <list> namespace llvm { class MachineFunction; class MachineInstr; class ScheduleDAG; class SIInstrInfo; class SISubtarget; class GCNHazardRecognizer final : public ScheduleHazardRecognizer { // This variable stores the instruction that has been emitted this cycle. It // will be added to EmittedInstrs, when AdvanceCycle() or RecedeCycle() is // called. MachineInstr *CurrCycleInstr; std::list<MachineInstr*> EmittedInstrs; const MachineFunction &MF; const SISubtarget &ST; int getWaitStatesSinceDef(unsigned Reg, function_ref<bool(MachineInstr *)> IsHazardDef = [](MachineInstr *) { return true; }); int checkSMEMSoftClauseHazards(MachineInstr *SMEM); int checkSMRDHazards(MachineInstr *SMRD); int checkVMEMHazards(MachineInstr* VMEM); int checkDPPHazards(MachineInstr *DPP); public: GCNHazardRecognizer(const MachineFunction &MF); // We can only issue one instruction per cycle. bool atIssueLimit() const override { return true; } void EmitInstruction(SUnit *SU) override; void EmitInstruction(MachineInstr *MI) override; HazardType getHazardType(SUnit *SU, int Stalls) override; void EmitNoop() override; unsigned PreEmitNoops(SUnit *SU) override; unsigned PreEmitNoops(MachineInstr *) override; void AdvanceCycle() override; void RecedeCycle() override; }; } // end namespace llvm #endif //LLVM_LIB_TARGET_AMDGPUHAZARDRECOGNIZERS_H