xref: /aosp_15_r20/external/llvm/lib/Target/ARM/ARMHazardRecognizer.h (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker //===-- ARMHazardRecognizer.h - ARM Hazard Recognizers ----------*- 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 // This file defines hazard recognizers for scheduling ARM functions.
11*9880d681SAndroid Build Coastguard Worker //
12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
13*9880d681SAndroid Build Coastguard Worker 
14*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_ARM_ARMHAZARDRECOGNIZER_H
15*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_ARM_ARMHAZARDRECOGNIZER_H
16*9880d681SAndroid Build Coastguard Worker 
17*9880d681SAndroid Build Coastguard Worker #include "llvm/CodeGen/ScoreboardHazardRecognizer.h"
18*9880d681SAndroid Build Coastguard Worker 
19*9880d681SAndroid Build Coastguard Worker namespace llvm {
20*9880d681SAndroid Build Coastguard Worker 
21*9880d681SAndroid Build Coastguard Worker class ARMBaseInstrInfo;
22*9880d681SAndroid Build Coastguard Worker class ARMBaseRegisterInfo;
23*9880d681SAndroid Build Coastguard Worker class ARMSubtarget;
24*9880d681SAndroid Build Coastguard Worker class MachineInstr;
25*9880d681SAndroid Build Coastguard Worker 
26*9880d681SAndroid Build Coastguard Worker /// ARMHazardRecognizer handles special constraints that are not expressed in
27*9880d681SAndroid Build Coastguard Worker /// the scheduling itinerary. This is only used during postRA scheduling. The
28*9880d681SAndroid Build Coastguard Worker /// ARM preRA scheduler uses an unspecialized instance of the
29*9880d681SAndroid Build Coastguard Worker /// ScoreboardHazardRecognizer.
30*9880d681SAndroid Build Coastguard Worker class ARMHazardRecognizer : public ScoreboardHazardRecognizer {
31*9880d681SAndroid Build Coastguard Worker   MachineInstr *LastMI;
32*9880d681SAndroid Build Coastguard Worker   unsigned FpMLxStalls;
33*9880d681SAndroid Build Coastguard Worker 
34*9880d681SAndroid Build Coastguard Worker public:
ARMHazardRecognizer(const InstrItineraryData * ItinData,const ScheduleDAG * DAG)35*9880d681SAndroid Build Coastguard Worker   ARMHazardRecognizer(const InstrItineraryData *ItinData,
36*9880d681SAndroid Build Coastguard Worker                       const ScheduleDAG *DAG)
37*9880d681SAndroid Build Coastguard Worker     : ScoreboardHazardRecognizer(ItinData, DAG, "post-RA-sched"),
38*9880d681SAndroid Build Coastguard Worker       LastMI(nullptr) {}
39*9880d681SAndroid Build Coastguard Worker 
40*9880d681SAndroid Build Coastguard Worker   HazardType getHazardType(SUnit *SU, int Stalls) override;
41*9880d681SAndroid Build Coastguard Worker   void Reset() override;
42*9880d681SAndroid Build Coastguard Worker   void EmitInstruction(SUnit *SU) override;
43*9880d681SAndroid Build Coastguard Worker   void AdvanceCycle() override;
44*9880d681SAndroid Build Coastguard Worker   void RecedeCycle() override;
45*9880d681SAndroid Build Coastguard Worker };
46*9880d681SAndroid Build Coastguard Worker 
47*9880d681SAndroid Build Coastguard Worker } // end namespace llvm
48*9880d681SAndroid Build Coastguard Worker 
49*9880d681SAndroid Build Coastguard Worker #endif
50