LLVM: llvm::PPCPostRASchedStrategy Class Reference (original) (raw)
A MachineSchedStrategy implementation for PowerPC post RA scheduling. More...
#include "[Target/PowerPC/PPCMachineScheduler.h](PPCMachineScheduler%5F8h%5Fsource.html)"
| Public Member Functions | |
|---|---|
| PPCPostRASchedStrategy (const MachineSchedContext *C) | |
| Public Member Functions inherited from llvm::PostGenericScheduler | |
| PostGenericScheduler (const MachineSchedContext *C) | |
| ~PostGenericScheduler () override=default | |
| void | initPolicy (MachineBasicBlock::iterator Begin, MachineBasicBlock::iterator End, unsigned NumRegionInstrs) override |
| Optionally override the per-region scheduling policy. | |
| bool | shouldTrackPressure () const override |
| PostRA scheduling does not track pressure. | |
| void | registerRoots () override |
| Notify this strategy that all roots have been released (including those that depend on EntrySU or ExitSU). | |
| SUnit * | pickNodeBidirectional (bool &IsTopNode) |
| Pick the best candidate node from either the top or bottom queue. | |
| void | scheduleTree (unsigned SubtreeID) override |
| Scheduler callback to notify that a new subtree is scheduled. | |
| void | schedNode (SUnit *SU, bool IsTopNode) override |
| Called after ScheduleDAGMI has scheduled an instruction and updated scheduled/remaining flags in the DAG nodes. | |
| void | releaseTopNode (SUnit *SU) override |
| When all predecessor dependencies have been resolved, free this node for top-down scheduling. | |
| void | releaseBottomNode (SUnit *SU) override |
| When all successor dependencies have been resolved, free this node for bottom-up scheduling. | |
| Public Member Functions inherited from llvm::MachineSchedStrategy | |
| virtual | ~MachineSchedStrategy ()=default |
| virtual void | dumpPolicy () const |
| virtual bool | shouldTrackLaneMasks () const |
| Returns true if lanemasks should be tracked. | |
| virtual bool | doMBBSchedRegionsTopDown () const |
| Protected Member Functions | |
|---|---|
| void | initialize (ScheduleDAGMI *Dag) override |
| Initialize the strategy after building the DAG for a new region. | |
| SUnit * | pickNode (bool &IsTopNode) override |
| Pick the next node to schedule. | |
| void | enterMBB (MachineBasicBlock *MBB) override |
| Tell the strategy that MBB is about to be processed. | |
| void | leaveMBB () override |
| Tell the strategy that current MBB is done. | |
| bool | tryCandidate (SchedCandidate &Cand, SchedCandidate &TryCand) override |
| Apply a set of heuristics to a new candidate for PostRA scheduling. | |
| bool | biasAddiCandidate (SchedCandidate &Cand, SchedCandidate &TryCand) const |
| Protected Member Functions inherited from llvm::PostGenericScheduler | |
| void | pickNodeFromQueue (SchedBoundary &Zone, SchedCandidate &Cand) |
| Protected Member Functions inherited from llvm::GenericSchedulerBase | |
| GenericSchedulerBase (const MachineSchedContext *C) | |
| LLVM_ABI void | setPolicy (CandPolicy &Policy, bool IsPostRA, SchedBoundary &CurrZone, SchedBoundary *OtherZone) |
| Set the CandPolicy given a scheduling zone given the current resources and latencies inside and outside the zone. | |
| MachineSchedPolicy | getPolicy () const override |
| void | traceCandidate (const SchedCandidate &Cand) |
A MachineSchedStrategy implementation for PowerPC post RA scheduling.
Definition at line 36 of file PPCMachineScheduler.h.
◆ biasAddiCandidate()
◆ enterMBB()
| void PPCPostRASchedStrategy::enterMBB ( MachineBasicBlock * MBB) | overrideprotectedvirtual |
|---|
◆ initialize()
| void PPCPostRASchedStrategy::initialize ( ScheduleDAGMI * DAG) | overrideprotectedvirtual |
|---|
◆ leaveMBB()
| void PPCPostRASchedStrategy::leaveMBB ( ) | overrideprotectedvirtual |
|---|
◆ pickNode()
| SUnit * PPCPostRASchedStrategy::pickNode ( bool & IsTopNode) | overrideprotectedvirtual |
|---|
◆ tryCandidate()
Apply a set of heuristics to a new candidate for PostRA scheduling.
Parameters
| Cand | provides the policy and current best candidate. |
|---|---|
| TryCand | refers to the next SUnit candidate, otherwise uninitialized. |
Returns
true if TryCand is better than Cand (Reason is NOT NoCand)
Reimplemented from llvm::PostGenericScheduler.
Definition at line 180 of file PPCMachineScheduler.cpp.
References llvm::GenericSchedulerBase::SchedCandidate::AtTop, biasAddiCandidate(), llvm::PostGenericScheduler::BotClusterID, llvm::GenericSchedulerBase::Cluster, llvm::GenericSchedulerBase::SchedResourceDelta::CritResources, llvm::GenericSchedulerBase::SchedResourceDelta::DemandedResources, llvm::isTheSameCluster(), llvm::GenericSchedulerBase::SchedCandidate::isValid(), llvm::GenericSchedulerBase::NoCand, llvm::SUnit::NodeNum, llvm::GenericSchedulerBase::NodeOrder, llvm::SUnit::ParentClusterIdx, llvm::GenericSchedulerBase::SchedCandidate::Policy, llvm::GenericSchedulerBase::SchedCandidate::Reason, llvm::GenericSchedulerBase::CandPolicy::ReduceLatency, llvm::GenericSchedulerBase::SchedCandidate::ResDelta, llvm::GenericSchedulerBase::ResourceDemand, llvm::GenericSchedulerBase::ResourceReduce, llvm::GenericSchedulerBase::Stall, llvm::GenericSchedulerBase::SchedCandidate::SU, llvm::PostGenericScheduler::Top, llvm::PostGenericScheduler::TopClusterID, llvm::tryGreater(), llvm::tryLatency(), and llvm::tryLess().
The documentation for this class was generated from the following files:
- lib/Target/PowerPC/PPCMachineScheduler.h
- lib/Target/PowerPC/PPCMachineScheduler.cpp